@ptsecurity/mosaic 17.5.2 → 17.5.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/core/common-behaviors/common-module.d.ts +15 -2
- package/core/error/error-options.d.ts +9 -0
- package/core/styles/theming/_theming.scss +0 -4
- package/esm2022/core/common-behaviors/common-module.mjs +17 -22
- package/esm2022/core/error/error-options.mjs +15 -1
- package/esm2022/core/version.mjs +2 -2
- package/esm2022/form-field/validate.directive.mjs +16 -7
- package/esm2022/toast/toast.component.mjs +4 -4
- package/esm2022/tree-select/tree-select.component.mjs +3 -3
- package/fesm2022/ptsecurity-mosaic-core.mjs +32 -23
- package/fesm2022/ptsecurity-mosaic-core.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-form-field.mjs +12 -4
- package/fesm2022/ptsecurity-mosaic-form-field.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-toast.mjs +3 -3
- package/fesm2022/ptsecurity-mosaic-toast.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-tree-select.mjs +2 -2
- package/fesm2022/ptsecurity-mosaic-tree-select.mjs.map +1 -1
- package/form-field/_form-field-theme.scss +9 -4
- package/form-field/validate.directive.d.ts +6 -3
- package/package.json +16 -16
- package/prebuilt-themes/dark-theme.css +1 -1
- package/prebuilt-themes/default-theme.css +1 -1
- package/select/_select-theme.scss +4 -1
- package/toast/toast.component.scss +4 -3
- package/tree-select/_tree-select-theme.scss +4 -1
|
@@ -1,13 +1,27 @@
|
|
|
1
1
|
import { InjectionToken } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "@angular/cdk/bidi";
|
|
4
|
+
/**
|
|
5
|
+
* Injection token that configures whether the Mosaic sanity checks are enabled.
|
|
6
|
+
*
|
|
7
|
+
* @deprecated No longer used and will be removed.
|
|
8
|
+
*
|
|
9
|
+
* @docs-private
|
|
10
|
+
*/
|
|
4
11
|
export declare const MC_SANITY_CHECKS: InjectionToken<boolean>;
|
|
12
|
+
/**
|
|
13
|
+
* @deprecated No longer used and will be removed.
|
|
14
|
+
*
|
|
15
|
+
* @docs-private
|
|
16
|
+
*/
|
|
5
17
|
export declare function mcSanityChecksFactory(): boolean;
|
|
6
18
|
/**
|
|
7
19
|
* Module that captures anything that should be loaded and/or run for *all* Mosaic
|
|
8
20
|
* components. This includes Bidi, etc.
|
|
9
21
|
*
|
|
10
|
-
*
|
|
22
|
+
* @deprecated No longer used and will be removed.
|
|
23
|
+
*
|
|
24
|
+
* @docs-private
|
|
11
25
|
*/
|
|
12
26
|
export declare class McCommonModule {
|
|
13
27
|
private _sanityChecksEnabled;
|
|
@@ -18,7 +32,6 @@ export declare class McCommonModule {
|
|
|
18
32
|
private areChecksEnabled;
|
|
19
33
|
private isTestEnv;
|
|
20
34
|
private checkDoctypeIsDefined;
|
|
21
|
-
private checkThemeIsPresent;
|
|
22
35
|
static ɵfac: i0.ɵɵFactoryDeclaration<McCommonModule, [{ optional: true; }]>;
|
|
23
36
|
static ɵmod: i0.ɵɵNgModuleDeclaration<McCommonModule, never, [typeof i1.BidiModule], [typeof i1.BidiModule]>;
|
|
24
37
|
static ɵinj: i0.ɵɵInjectorDeclaration<McCommonModule>;
|
|
@@ -1,5 +1,14 @@
|
|
|
1
1
|
import { FormGroupDirective, NgForm, UntypedFormControl } from '@angular/forms';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
+
/**
|
|
4
|
+
* Error state matcher that matches when a control is invalid and form is submitted.
|
|
5
|
+
* Requires use FormGroupDirective or NgForm.
|
|
6
|
+
*/
|
|
7
|
+
export declare class ShowOnFormSubmitErrorStateMatcher implements ErrorStateMatcher {
|
|
8
|
+
isErrorState(control: UntypedFormControl | null, form: FormGroupDirective | NgForm | null): boolean;
|
|
9
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ShowOnFormSubmitErrorStateMatcher, never>;
|
|
10
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<ShowOnFormSubmitErrorStateMatcher>;
|
|
11
|
+
}
|
|
3
12
|
/** Error state matcher that matches when a control is invalid and dirty. */
|
|
4
13
|
export declare class ShowOnDirtyErrorStateMatcher implements ErrorStateMatcher {
|
|
5
14
|
isErrorState(control: UntypedFormControl | null, form: FormGroupDirective | NgForm | null): boolean;
|
|
@@ -1,11 +1,22 @@
|
|
|
1
1
|
import { BidiModule } from '@angular/cdk/bidi';
|
|
2
2
|
import { NgModule, InjectionToken, Optional, Inject, isDevMode } from '@angular/core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
-
|
|
4
|
+
/**
|
|
5
|
+
* Injection token that configures whether the Mosaic sanity checks are enabled.
|
|
6
|
+
*
|
|
7
|
+
* @deprecated No longer used and will be removed.
|
|
8
|
+
*
|
|
9
|
+
* @docs-private
|
|
10
|
+
*/
|
|
5
11
|
export const MC_SANITY_CHECKS = new InjectionToken('mc-sanity-checks', {
|
|
6
12
|
providedIn: 'root',
|
|
7
13
|
factory: mcSanityChecksFactory
|
|
8
14
|
});
|
|
15
|
+
/**
|
|
16
|
+
* @deprecated No longer used and will be removed.
|
|
17
|
+
*
|
|
18
|
+
* @docs-private
|
|
19
|
+
*/
|
|
9
20
|
export function mcSanityChecksFactory() {
|
|
10
21
|
return true;
|
|
11
22
|
}
|
|
@@ -13,7 +24,9 @@ export function mcSanityChecksFactory() {
|
|
|
13
24
|
* Module that captures anything that should be loaded and/or run for *all* Mosaic
|
|
14
25
|
* components. This includes Bidi, etc.
|
|
15
26
|
*
|
|
16
|
-
*
|
|
27
|
+
* @deprecated No longer used and will be removed.
|
|
28
|
+
*
|
|
29
|
+
* @docs-private
|
|
17
30
|
*/
|
|
18
31
|
export class McCommonModule {
|
|
19
32
|
constructor(_sanityChecksEnabled) {
|
|
@@ -28,7 +41,6 @@ export class McCommonModule {
|
|
|
28
41
|
this._window = typeof window === 'object' && window ? window : null;
|
|
29
42
|
if (this.areChecksEnabled() && !this.hasDoneGlobalChecks) {
|
|
30
43
|
this.checkDoctypeIsDefined();
|
|
31
|
-
this.checkThemeIsPresent();
|
|
32
44
|
this.hasDoneGlobalChecks = true;
|
|
33
45
|
}
|
|
34
46
|
}
|
|
@@ -39,7 +51,7 @@ export class McCommonModule {
|
|
|
39
51
|
// Whether the code is running in tests.
|
|
40
52
|
isTestEnv() {
|
|
41
53
|
// tslint:disable-next-line
|
|
42
|
-
return this._window && (this._window['__karma__'] || this._window['jasmine']);
|
|
54
|
+
return this._window && (this._window['__karma__'] || this._window['jasmine'] || this._window['__jest__']);
|
|
43
55
|
}
|
|
44
56
|
checkDoctypeIsDefined() {
|
|
45
57
|
if (this._document && !this._document.doctype) {
|
|
@@ -47,23 +59,6 @@ export class McCommonModule {
|
|
|
47
59
|
'some Mosaic components not to behave as expected.');
|
|
48
60
|
}
|
|
49
61
|
}
|
|
50
|
-
checkThemeIsPresent() {
|
|
51
|
-
if (this._document && typeof getComputedStyle === 'function') {
|
|
52
|
-
const testElement = this._document.createElement('div');
|
|
53
|
-
testElement.classList.add('mc-theme-loaded-marker');
|
|
54
|
-
this._document.body.appendChild(testElement);
|
|
55
|
-
const computedStyle = getComputedStyle(testElement);
|
|
56
|
-
// In some situations, the computed style of the test element can be null. For example in
|
|
57
|
-
// Firefox, the computed style is null if an application is running inside of a hidden iframe.
|
|
58
|
-
// See: https://bugzilla.mozilla.org/show_bug.cgi?id=548397
|
|
59
|
-
if (computedStyle && computedStyle.display !== 'none') {
|
|
60
|
-
console.warn('Could not find Mosaic core theme. Most Mosaic ' +
|
|
61
|
-
'components may not work as expected. For more info refer ' +
|
|
62
|
-
'to the theming guide: link there');
|
|
63
|
-
}
|
|
64
|
-
this._document.body.removeChild(testElement);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
62
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.0", ngImport: i0, type: McCommonModule, deps: [{ token: MC_SANITY_CHECKS, optional: true }], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
68
63
|
/** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.2.0", ngImport: i0, type: McCommonModule, imports: [BidiModule], exports: [BidiModule] }); }
|
|
69
64
|
/** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.2.0", ngImport: i0, type: McCommonModule, imports: [BidiModule, BidiModule] }); }
|
|
@@ -80,4 +75,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.0", ngImpor
|
|
|
80
75
|
type: Inject,
|
|
81
76
|
args: [MC_SANITY_CHECKS]
|
|
82
77
|
}] }] });
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLW1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL21vc2FpYy9jb3JlL2NvbW1vbi1iZWhhdmlvcnMvY29tbW9uLW1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxjQUFjLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBR3RGOzs7Ozs7R0FNRztBQUNILE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLElBQUksY0FBYyxDQUFVLGtCQUFrQixFQUFFO0lBQzVFLFVBQVUsRUFBRSxNQUFNO0lBQ2xCLE9BQU8sRUFBRSxxQkFBcUI7Q0FDakMsQ0FBQyxDQUFDO0FBRUg7Ozs7R0FJRztBQUNILE1BQU0sVUFBVSxxQkFBcUI7SUFDakMsT0FBTyxJQUFJLENBQUM7QUFDaEIsQ0FBQztBQUVEOzs7Ozs7O0dBT0c7QUFLSCxNQUFNLE9BQU8sY0FBYztJQVl2QixZQUEwRCxvQkFBNkI7UUFBN0IseUJBQW9CLEdBQXBCLG9CQUFvQixDQUFTO1FBWHZGLDRGQUE0RjtRQUNwRix3QkFBbUIsR0FBRyxLQUFLLENBQUM7UUFFcEMsNkNBQTZDO1FBQzdDLHVEQUF1RDtRQUMvQyxjQUFTLEdBQUcsT0FBTyxRQUFRLEtBQUssUUFBUSxJQUFJLFFBQVEsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7UUFFL0UsMkNBQTJDO1FBQzNDLHVEQUF1RDtRQUMvQyxZQUFPLEdBQUcsT0FBTyxNQUFNLEtBQUssUUFBUSxJQUFJLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7UUFHbkUsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO1lBQ3ZELElBQUksQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO1lBQzdCLElBQUksQ0FBQyxtQkFBbUIsR0FBRyxJQUFJLENBQUM7UUFDcEMsQ0FBQztJQUNMLENBQUM7SUFFRCx3Q0FBd0M7SUFDaEMsZ0JBQWdCO1FBQ3BCLE9BQU8sSUFBSSxDQUFDLG9CQUFvQixJQUFJLFNBQVMsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ3pFLENBQUM7SUFFRCx3Q0FBd0M7SUFDaEMsU0FBUztRQUNiLDJCQUEyQjtRQUMzQixPQUFPLElBQUksQ0FBQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO0lBQzlHLENBQUM7SUFFTyxxQkFBcUI7UUFDekIsSUFBSSxJQUFJLENBQUMsU0FBUyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUM1QyxPQUFPLENBQUMsSUFBSSxDQUNSLDJEQUEyRDtnQkFDM0QsbURBQW1ELENBQ3RELENBQUM7UUFDTixDQUFDO0lBQ0wsQ0FBQztpSUFyQ1EsY0FBYyxrQkFZUyxnQkFBZ0I7a0lBWnZDLGNBQWMsWUFIYixVQUFVLGFBQ1YsVUFBVTtrSUFFWCxjQUFjLFlBSGIsVUFBVSxFQUNWLFVBQVU7OzJGQUVYLGNBQWM7a0JBSjFCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFLENBQUMsVUFBVSxDQUFDO29CQUNyQixPQUFPLEVBQUUsQ0FBQyxVQUFVLENBQUM7aUJBQ3hCOzswQkFhZ0IsUUFBUTs7MEJBQUksTUFBTTsyQkFBQyxnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCaWRpTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2JpZGknO1xuaW1wb3J0IHsgTmdNb2R1bGUsIEluamVjdGlvblRva2VuLCBPcHRpb25hbCwgSW5qZWN0LCBpc0Rldk1vZGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuXG4vKipcbiAqIEluamVjdGlvbiB0b2tlbiB0aGF0IGNvbmZpZ3VyZXMgd2hldGhlciB0aGUgTW9zYWljIHNhbml0eSBjaGVja3MgYXJlIGVuYWJsZWQuXG4gKlxuICogQGRlcHJlY2F0ZWQgTm8gbG9uZ2VyIHVzZWQgYW5kIHdpbGwgYmUgcmVtb3ZlZC5cbiAqXG4gKiBAZG9jcy1wcml2YXRlXG4gKi9cbmV4cG9ydCBjb25zdCBNQ19TQU5JVFlfQ0hFQ0tTID0gbmV3IEluamVjdGlvblRva2VuPGJvb2xlYW4+KCdtYy1zYW5pdHktY2hlY2tzJywge1xuICAgIHByb3ZpZGVkSW46ICdyb290JyxcbiAgICBmYWN0b3J5OiBtY1Nhbml0eUNoZWNrc0ZhY3Rvcnlcbn0pO1xuXG4vKipcbiAqIEBkZXByZWNhdGVkIE5vIGxvbmdlciB1c2VkIGFuZCB3aWxsIGJlIHJlbW92ZWQuXG4gKlxuICogQGRvY3MtcHJpdmF0ZVxuICovXG5leHBvcnQgZnVuY3Rpb24gbWNTYW5pdHlDaGVja3NGYWN0b3J5KCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0cnVlO1xufVxuXG4vKipcbiAqIE1vZHVsZSB0aGF0IGNhcHR1cmVzIGFueXRoaW5nIHRoYXQgc2hvdWxkIGJlIGxvYWRlZCBhbmQvb3IgcnVuIGZvciAqYWxsKiBNb3NhaWNcbiAqIGNvbXBvbmVudHMuIFRoaXMgaW5jbHVkZXMgQmlkaSwgZXRjLlxuICpcbiAqIEBkZXByZWNhdGVkIE5vIGxvbmdlciB1c2VkIGFuZCB3aWxsIGJlIHJlbW92ZWQuXG4gKlxuICogQGRvY3MtcHJpdmF0ZVxuICovXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtCaWRpTW9kdWxlXSxcbiAgICBleHBvcnRzOiBbQmlkaU1vZHVsZV1cbn0pXG5leHBvcnQgY2xhc3MgTWNDb21tb25Nb2R1bGUge1xuICAgIC8vIFdoZXRoZXIgd2UndmUgZG9uZSB0aGUgZ2xvYmFsIHNhbml0eSBjaGVja3MgKGUuZy4gYSB0aGVtZSBpcyBsb2FkZWQsIHRoZXJlIGlzIGEgZG9jdHlwZSkuXG4gICAgcHJpdmF0ZSBoYXNEb25lR2xvYmFsQ2hlY2tzID0gZmFsc2U7XG5cbiAgICAvLyBSZWZlcmVuY2UgdG8gdGhlIGdsb2JhbCBgZG9jdW1lbnRgIG9iamVjdC5cbiAgICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6IG9ydGhvZG94LWdldHRlci1hbmQtc2V0dGVyXG4gICAgcHJpdmF0ZSBfZG9jdW1lbnQgPSB0eXBlb2YgZG9jdW1lbnQgPT09ICdvYmplY3QnICYmIGRvY3VtZW50ID8gZG9jdW1lbnQgOiBudWxsO1xuXG4gICAgLy8gUmVmZXJlbmNlIHRvIHRoZSBnbG9iYWwgJ3dpbmRvdycgb2JqZWN0LlxuICAgIC8vIHRzbGludDpkaXNhYmxlLW5leHQtbGluZTogb3J0aG9kb3gtZ2V0dGVyLWFuZC1zZXR0ZXJcbiAgICBwcml2YXRlIF93aW5kb3cgPSB0eXBlb2Ygd2luZG93ID09PSAnb2JqZWN0JyAmJiB3aW5kb3cgPyB3aW5kb3cgOiBudWxsO1xuXG4gICAgY29uc3RydWN0b3IoQE9wdGlvbmFsKCkgQEluamVjdChNQ19TQU5JVFlfQ0hFQ0tTKSBwcml2YXRlIF9zYW5pdHlDaGVja3NFbmFibGVkOiBib29sZWFuKSB7XG4gICAgICAgIGlmICh0aGlzLmFyZUNoZWNrc0VuYWJsZWQoKSAmJiAhdGhpcy5oYXNEb25lR2xvYmFsQ2hlY2tzKSB7XG4gICAgICAgICAgICB0aGlzLmNoZWNrRG9jdHlwZUlzRGVmaW5lZCgpO1xuICAgICAgICAgICAgdGhpcy5oYXNEb25lR2xvYmFsQ2hlY2tzID0gdHJ1ZTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIC8vIFdoZXRoZXIgYW55IHNhbml0eSBjaGVja3MgYXJlIGVuYWJsZWRcbiAgICBwcml2YXRlIGFyZUNoZWNrc0VuYWJsZWQoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLl9zYW5pdHlDaGVja3NFbmFibGVkICYmIGlzRGV2TW9kZSgpICYmICF0aGlzLmlzVGVzdEVudigpO1xuICAgIH1cblxuICAgIC8vIFdoZXRoZXIgdGhlIGNvZGUgaXMgcnVubmluZyBpbiB0ZXN0cy5cbiAgICBwcml2YXRlIGlzVGVzdEVudigpIHtcbiAgICAgICAgLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lXG4gICAgICAgIHJldHVybiB0aGlzLl93aW5kb3cgJiYgKHRoaXMuX3dpbmRvd1snX19rYXJtYV9fJ10gfHwgdGhpcy5fd2luZG93WydqYXNtaW5lJ10gfHwgdGhpcy5fd2luZG93WydfX2plc3RfXyddKTtcbiAgICB9XG5cbiAgICBwcml2YXRlIGNoZWNrRG9jdHlwZUlzRGVmaW5lZCgpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuX2RvY3VtZW50ICYmICF0aGlzLl9kb2N1bWVudC5kb2N0eXBlKSB7XG4gICAgICAgICAgICBjb25zb2xlLndhcm4oXG4gICAgICAgICAgICAgICAgJ0N1cnJlbnQgZG9jdW1lbnQgZG9lcyBub3QgaGF2ZSBhIGRvY3R5cGUuIFRoaXMgbWF5IGNhdXNlICcgK1xuICAgICAgICAgICAgICAgICdzb21lIE1vc2FpYyBjb21wb25lbnRzIG5vdCB0byBiZWhhdmUgYXMgZXhwZWN0ZWQuJ1xuICAgICAgICAgICAgKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
|
|
@@ -1,5 +1,19 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
+
/**
|
|
4
|
+
* Error state matcher that matches when a control is invalid and form is submitted.
|
|
5
|
+
* Requires use FormGroupDirective or NgForm.
|
|
6
|
+
*/
|
|
7
|
+
export class ShowOnFormSubmitErrorStateMatcher {
|
|
8
|
+
isErrorState(control, form) {
|
|
9
|
+
return !!(control?.invalid && form?.submitted);
|
|
10
|
+
}
|
|
11
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.0", ngImport: i0, type: ShowOnFormSubmitErrorStateMatcher, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
12
|
+
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.2.0", ngImport: i0, type: ShowOnFormSubmitErrorStateMatcher }); }
|
|
13
|
+
}
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.0", ngImport: i0, type: ShowOnFormSubmitErrorStateMatcher, decorators: [{
|
|
15
|
+
type: Injectable
|
|
16
|
+
}] });
|
|
3
17
|
/** Error state matcher that matches when a control is invalid and dirty. */
|
|
4
18
|
export class ShowOnDirtyErrorStateMatcher {
|
|
5
19
|
isErrorState(control, form) {
|
|
@@ -23,4 +37,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.0", ngImpor
|
|
|
23
37
|
type: Injectable,
|
|
24
38
|
args: [{ providedIn: 'root' }]
|
|
25
39
|
}] });
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3Itb3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL21vc2FpYy9jb3JlL2Vycm9yL2Vycm9yLW9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFJM0M7OztHQUdHO0FBRUgsTUFBTSxPQUFPLGlDQUFpQztJQUMxQyxZQUFZLENBQUMsT0FBa0MsRUFBRSxJQUF3QztRQUNyRixPQUFPLENBQUMsQ0FBQyxDQUFDLE9BQU8sRUFBRSxPQUFPLElBQUksSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBQ25ELENBQUM7aUlBSFEsaUNBQWlDO3FJQUFqQyxpQ0FBaUM7OzJGQUFqQyxpQ0FBaUM7a0JBRDdDLFVBQVU7O0FBT1gsNEVBQTRFO0FBRTVFLE1BQU0sT0FBTyw0QkFBNEI7SUFDckMsWUFBWSxDQUFDLE9BQWtDLEVBQUUsSUFBd0M7UUFDckYsT0FBTyxDQUFDLENBQUMsQ0FBQyxPQUFPLElBQUksT0FBTyxDQUFDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN6RixDQUFDO2lJQUhRLDRCQUE0QjtxSUFBNUIsNEJBQTRCOzsyRkFBNUIsNEJBQTRCO2tCQUR4QyxVQUFVOztBQU9YLGdHQUFnRztBQUVoRyxNQUFNLE9BQU8saUJBQWlCO0lBQzFCLFlBQVksQ0FBQyxPQUFrQyxFQUFFLElBQXdDO1FBQ3JGLE9BQU8sQ0FBQyxDQUFDLENBQUMsT0FBTyxJQUFJLE9BQU8sQ0FBQyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDM0YsQ0FBQztpSUFIUSxpQkFBaUI7cUlBQWpCLGlCQUFpQixjQURKLE1BQU07OzJGQUNuQixpQkFBaUI7a0JBRDdCLFVBQVU7bUJBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUdyb3VwRGlyZWN0aXZlLCBOZ0Zvcm0sIFVudHlwZWRGb3JtQ29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuXG4vKipcbiAqIEVycm9yIHN0YXRlIG1hdGNoZXIgdGhhdCBtYXRjaGVzIHdoZW4gYSBjb250cm9sIGlzIGludmFsaWQgYW5kIGZvcm0gaXMgc3VibWl0dGVkLlxuICogUmVxdWlyZXMgdXNlIEZvcm1Hcm91cERpcmVjdGl2ZSBvciBOZ0Zvcm0uXG4gKi9cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBTaG93T25Gb3JtU3VibWl0RXJyb3JTdGF0ZU1hdGNoZXIgaW1wbGVtZW50cyBFcnJvclN0YXRlTWF0Y2hlciB7XG4gICAgaXNFcnJvclN0YXRlKGNvbnRyb2w6IFVudHlwZWRGb3JtQ29udHJvbCB8IG51bGwsIGZvcm06IEZvcm1Hcm91cERpcmVjdGl2ZSB8IE5nRm9ybSB8IG51bGwpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuICEhKGNvbnRyb2w/LmludmFsaWQgJiYgZm9ybT8uc3VibWl0dGVkKTtcbiAgICB9XG59XG5cbi8qKiBFcnJvciBzdGF0ZSBtYXRjaGVyIHRoYXQgbWF0Y2hlcyB3aGVuIGEgY29udHJvbCBpcyBpbnZhbGlkIGFuZCBkaXJ0eS4gKi9cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBTaG93T25EaXJ0eUVycm9yU3RhdGVNYXRjaGVyIGltcGxlbWVudHMgRXJyb3JTdGF0ZU1hdGNoZXIge1xuICAgIGlzRXJyb3JTdGF0ZShjb250cm9sOiBVbnR5cGVkRm9ybUNvbnRyb2wgfCBudWxsLCBmb3JtOiBGb3JtR3JvdXBEaXJlY3RpdmUgfCBOZ0Zvcm0gfCBudWxsKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiAhIShjb250cm9sICYmIGNvbnRyb2wuaW52YWxpZCAmJiAoY29udHJvbC5kaXJ0eSB8fCAoZm9ybSAmJiBmb3JtLnN1Ym1pdHRlZCkpKTtcbiAgICB9XG59XG5cbi8qKiBQcm92aWRlciB0aGF0IGRlZmluZXMgaG93IGZvcm0gY29udHJvbHMgYmVoYXZlIHdpdGggcmVnYXJkcyB0byBkaXNwbGF5aW5nIGVycm9yIG1lc3NhZ2VzLiAqL1xuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiAncm9vdCcgfSlcbmV4cG9ydCBjbGFzcyBFcnJvclN0YXRlTWF0Y2hlciB7XG4gICAgaXNFcnJvclN0YXRlKGNvbnRyb2w6IFVudHlwZWRGb3JtQ29udHJvbCB8IG51bGwsIGZvcm06IEZvcm1Hcm91cERpcmVjdGl2ZSB8IE5nRm9ybSB8IG51bGwpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuICEhKGNvbnRyb2wgJiYgY29udHJvbC5pbnZhbGlkICYmIChjb250cm9sLnRvdWNoZWQgfHwgKGZvcm0gJiYgZm9ybS5zdWJtaXR0ZWQpKSk7XG4gICAgfVxufVxuIl19
|
package/esm2022/core/version.mjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { Version } from '@angular/core';
|
|
2
|
-
export const VERSION = new Version('17.5.
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
export const VERSION = new Version('17.5.3+sha-8384d30');
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL21vc2FpYy9jb3JlL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUd4QyxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsSUFBSSxPQUFPLENBQUMsb0JBQW9CLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFZlcnNpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IG5ldyBWZXJzaW9uKCcxNy41LjMrc2hhLTgzODRkMzAnKTtcbiJdfQ==
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import { ChangeDetectorRef, Directive, forwardRef, Inject, Optional, Self } from '@angular/core';
|
|
1
|
+
import { ChangeDetectorRef, Directive, ElementRef, forwardRef, Host, Inject, Optional, Self } from '@angular/core';
|
|
2
2
|
import { FormControlName, FormGroupDirective, NG_VALIDATORS, NgControl, NgForm, NgModel, RequiredValidator, FormControlDirective } from '@angular/forms';
|
|
3
3
|
import { MC_VALIDATION } from '@ptsecurity/mosaic/core';
|
|
4
4
|
import { McFormFieldControl } from './form-field-control';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/forms";
|
|
7
|
-
import * as i2 from "./form-field
|
|
7
|
+
import * as i2 from "./form-field";
|
|
8
|
+
import * as i3 from "./form-field-control";
|
|
8
9
|
export class McValidateDirective {
|
|
9
10
|
get isNgModel() {
|
|
10
11
|
return this.ngControl instanceof NgModel;
|
|
@@ -24,7 +25,7 @@ export class McValidateDirective {
|
|
|
24
25
|
get hasNotSubmittedParent() {
|
|
25
26
|
return this.parent && !this.parent.submitted;
|
|
26
27
|
}
|
|
27
|
-
constructor(formFieldControl, rawValidators, ngControl, parentForm, parentFormGroup, mcValidation, cdr) {
|
|
28
|
+
constructor(formFieldControl, rawValidators, ngControl, parentForm, parentFormGroup, mcValidation, cdr, parentFormField, elementRef) {
|
|
28
29
|
this.formFieldControl = formFieldControl;
|
|
29
30
|
this.rawValidators = rawValidators;
|
|
30
31
|
this.ngControl = ngControl;
|
|
@@ -32,9 +33,13 @@ export class McValidateDirective {
|
|
|
32
33
|
this.parentFormGroup = parentFormGroup;
|
|
33
34
|
this.mcValidation = mcValidation;
|
|
34
35
|
this.cdr = cdr;
|
|
36
|
+
this.parentFormField = parentFormField;
|
|
37
|
+
this.elementRef = elementRef;
|
|
35
38
|
}
|
|
36
39
|
ngAfterContentInit() {
|
|
37
40
|
if (this.mcValidation.useValidation) {
|
|
41
|
+
this.parentFormField?.elementRef.nativeElement.classList.add('mc-form-field_has-validate-directive');
|
|
42
|
+
this.elementRef.nativeElement.classList.add('mc-control_has-validate-directive');
|
|
38
43
|
this.setMosaicValidation();
|
|
39
44
|
}
|
|
40
45
|
}
|
|
@@ -122,7 +127,7 @@ export class McValidateDirective {
|
|
|
122
127
|
}
|
|
123
128
|
});
|
|
124
129
|
}
|
|
125
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.0", ngImport: i0, type: McValidateDirective, deps: [{ token: forwardRef(() => McFormFieldControl) }, { token: NG_VALIDATORS, optional: true, self: true }, { token: i1.NgControl, optional: true, self: true }, { token: i1.NgForm, optional: true }, { token: i1.FormGroupDirective, optional: true }, { token: MC_VALIDATION, optional: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
130
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.0", ngImport: i0, type: McValidateDirective, deps: [{ token: forwardRef(() => McFormFieldControl) }, { token: NG_VALIDATORS, optional: true, self: true }, { token: i1.NgControl, optional: true, self: true }, { token: i1.NgForm, optional: true }, { token: i1.FormGroupDirective, optional: true }, { token: MC_VALIDATION, optional: true }, { token: i0.ChangeDetectorRef }, { token: i2.McFormField, host: true, optional: true }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
126
131
|
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.0", type: McValidateDirective, selector: "\n input[mcInput],\n input[mcInputPassword],\n input[mcTimepicker],\n input[mcDatepicker],\n textarea[mcTextarea],\n mc-select,\n mc-tree-select,\n mc-tag-list\n ", exportAs: ["McValidate"], ngImport: i0 }); }
|
|
127
132
|
}
|
|
128
133
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.0", ngImport: i0, type: McValidateDirective, decorators: [{
|
|
@@ -140,7 +145,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.0", ngImpor
|
|
|
140
145
|
`,
|
|
141
146
|
exportAs: 'McValidate'
|
|
142
147
|
}]
|
|
143
|
-
}], ctorParameters: () => [{ type:
|
|
148
|
+
}], ctorParameters: () => [{ type: i3.McFormFieldControl, decorators: [{
|
|
144
149
|
type: Inject,
|
|
145
150
|
args: [forwardRef(() => McFormFieldControl)]
|
|
146
151
|
}] }, { type: undefined, decorators: [{
|
|
@@ -163,5 +168,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.0", ngImpor
|
|
|
163
168
|
}, {
|
|
164
169
|
type: Inject,
|
|
165
170
|
args: [MC_VALIDATION]
|
|
166
|
-
}] }, { type: i0.ChangeDetectorRef }
|
|
167
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validate.directive.js","sourceRoot":"","sources":["../../../../packages/mosaic/form-field/validate.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    ChangeDetectorRef,\n    Directive,\n    forwardRef,\n    Inject,\n    Optional,\n    Self, OnDestroy\n} from '@angular/core';\nimport {\n    AbstractControl,\n    FormControlName,\n    FormGroupDirective,\n    NG_VALIDATORS,\n    NgControl,\n    NgForm,\n    NgModel,\n    RequiredValidator,\n    ValidationErrors,\n    Validator,\n    ValidatorFn,\n    FormControlDirective\n} from '@angular/forms';\nimport {\n    McValidationOptions,\n    MC_VALIDATION\n} from '@ptsecurity/mosaic/core';\nimport { Subscription } from 'rxjs';\n\n\nimport { McFormFieldControl } from './form-field-control';\n\n\n@Directive({\n    selector: `\n        input[mcInput],\n        input[mcInputPassword],\n        input[mcTimepicker],\n        input[mcDatepicker],\n        textarea[mcTextarea],\n        mc-select,\n        mc-tree-select,\n        mc-tag-list\n    `,\n    exportAs: 'McValidate'\n})\nexport class McValidateDirective implements AfterContentInit, OnDestroy {\n    get isNgModel(): boolean {\n        return this.ngControl instanceof NgModel;\n    }\n\n    get isFormControlName(): boolean {\n        return this.ngControl instanceof FormControlName;\n    }\n\n    get isFormControl(): boolean {\n        return this.ngControl instanceof FormControlDirective;\n    }\n\n    get validationControl(): any {\n        return this.ngControl?.control || this.ngControl;\n    }\n\n    get parent() {\n        return this.parentForm || this.parentFormGroup;\n    }\n\n    get hasNotSubmittedParent(): boolean {\n        return this.parent && !this.parent.submitted;\n    }\n    protected validationStatusChangesSubscription: Subscription;\n\n    constructor(\n        @Inject(forwardRef(() => McFormFieldControl)) private formFieldControl: McFormFieldControl<any>,\n        @Optional() @Self() @Inject(NG_VALIDATORS) public rawValidators: Validator[],\n        @Optional() @Self() private ngControl: NgControl,\n        @Optional() private parentForm: NgForm,\n        @Optional() private parentFormGroup: FormGroupDirective,\n        @Optional() @Inject(MC_VALIDATION) private mcValidation: McValidationOptions,\n        private cdr: ChangeDetectorRef\n    ) {}\n\n    ngAfterContentInit() {\n        if (this.mcValidation.useValidation) {\n            this.setMosaicValidation();\n        }\n    }\n\n    ngOnDestroy() {\n        this.validationStatusChangesSubscription?.unsubscribe();\n    }\n\n    setValidState(control: AbstractControl, validator: ValidatorFn): void {\n        if (!control) { return; }\n\n        control.clearValidators();\n        control.updateValueAndValidity({ emitEvent: false });\n        control.setValidators(validator);\n    }\n\n    /** This function do next:\n     * - run validation on submitting parent form\n     * - prevent validation in required validator if form doesn't submitted\n     * - if control has focus validation will be prevented\n     */\n    setMosaicValidation(): void {\n        if (!this.validationControl) { return; }\n\n        if (this.parent?.onSubmit) {\n            // tslint:disable-next-line: no-unbound-method\n            const originalSubmit = this.parent.onSubmit;\n            this.parent.onSubmit = ($event: Event) => {\n                this.validationControl!.updateValueAndValidity({ emitEvent: false });\n\n                return originalSubmit.call(this.parent, $event);\n            };\n        }\n\n        if (this.isNgModel) {\n            this.setMosaicValidationForModelControl();\n        } else if (this.isFormControl || this.isFormControlName) {\n            this.setMosaicValidationForFormControl();\n        }\n    }\n\n    setMosaicValidationForModelControl() {\n        if (!this.rawValidators) { return; }\n\n        this.rawValidators.forEach((validator: Validator) => {\n            // tslint:disable-next-line: no-unbound-method\n            const originalValidate = validator.validate;\n\n            if (validator instanceof RequiredValidator) {\n                // changed required validation logic\n                validator.validate = (control: AbstractControl): ValidationErrors | null => {\n                    if (this.hasNotSubmittedParent) { return null; }\n\n                    return originalValidate.call(validator, control);\n                };\n            } else {\n                // changed all other validation logic\n                validator.validate = (control: AbstractControl): ValidationErrors | null => {\n                    if (this.formFieldControl.focused) { return null; }\n\n                    return originalValidate.call(validator, control);\n                };\n            }\n        });\n    }\n\n    setMosaicValidationForFormControl() {\n        const originalValidator = this.validationControl.validator;\n\n        // changed required validation logic after initialization\n        if (this.validationControl.invalid && this.validationControl.errors!.required) {\n            Promise.resolve().then(() => {\n                this.setValidState(this.validationControl, originalValidator!);\n                this.cdr.markForCheck();\n            });\n        }\n\n        // check dynamic updates\n        this.validationStatusChangesSubscription = this.validationControl.statusChanges!\n            .subscribe(() => {\n                // changed required validation logic\n                if (this.validationControl.invalid && (this.hasNotSubmittedParent) && this.validationControl.errors!.required) {\n                    this.setValidState(this.validationControl, originalValidator!);\n                }\n\n                // changed all other validation logic\n                if (this.validationControl.invalid && this.formFieldControl.focused) {\n                    this.setValidState(this.validationControl, originalValidator!);\n                }\n            });\n    }\n}\n"]}
|
|
171
|
+
}] }, { type: i0.ChangeDetectorRef }, { type: i2.McFormField, decorators: [{
|
|
172
|
+
type: Optional
|
|
173
|
+
}, {
|
|
174
|
+
type: Host
|
|
175
|
+
}] }, { type: i0.ElementRef }] });
|
|
176
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validate.directive.js","sourceRoot":"","sources":["../../../../packages/mosaic/form-field/validate.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    ChangeDetectorRef,\n    Directive,\n    ElementRef,\n    forwardRef,\n    Host,\n    Inject,\n    Optional,\n    Self, OnDestroy\n} from '@angular/core';\nimport {\n    AbstractControl,\n    FormControlName,\n    FormGroupDirective,\n    NG_VALIDATORS,\n    NgControl,\n    NgForm,\n    NgModel,\n    RequiredValidator,\n    ValidationErrors,\n    Validator,\n    ValidatorFn,\n    FormControlDirective\n} from '@angular/forms';\nimport {\n    McValidationOptions,\n    MC_VALIDATION\n} from '@ptsecurity/mosaic/core';\nimport { Subscription } from 'rxjs';\n\nimport { McFormField } from './form-field';\nimport { McFormFieldControl } from './form-field-control';\n\n\n@Directive({\n    selector: `\n        input[mcInput],\n        input[mcInputPassword],\n        input[mcTimepicker],\n        input[mcDatepicker],\n        textarea[mcTextarea],\n        mc-select,\n        mc-tree-select,\n        mc-tag-list\n    `,\n    exportAs: 'McValidate'\n})\nexport class McValidateDirective implements AfterContentInit, OnDestroy {\n    get isNgModel(): boolean {\n        return this.ngControl instanceof NgModel;\n    }\n\n    get isFormControlName(): boolean {\n        return this.ngControl instanceof FormControlName;\n    }\n\n    get isFormControl(): boolean {\n        return this.ngControl instanceof FormControlDirective;\n    }\n\n    get validationControl(): any {\n        return this.ngControl?.control || this.ngControl;\n    }\n\n    get parent() {\n        return this.parentForm || this.parentFormGroup;\n    }\n\n    get hasNotSubmittedParent(): boolean {\n        return this.parent && !this.parent.submitted;\n    }\n    protected validationStatusChangesSubscription: Subscription;\n\n    constructor(\n        @Inject(forwardRef(() => McFormFieldControl)) private formFieldControl: McFormFieldControl<any>,\n        @Optional() @Self() @Inject(NG_VALIDATORS) public rawValidators: Validator[],\n        @Optional() @Self() private ngControl: NgControl,\n        @Optional() private parentForm: NgForm,\n        @Optional() private parentFormGroup: FormGroupDirective,\n        @Optional() @Inject(MC_VALIDATION) private mcValidation: McValidationOptions,\n        private cdr: ChangeDetectorRef,\n        @Optional() @Host() private readonly parentFormField: McFormField | null,\n        private readonly elementRef: ElementRef<HTMLElement>\n    ) { }\n\n    ngAfterContentInit() {\n        if (this.mcValidation.useValidation) {\n            this.parentFormField?.elementRef.nativeElement.classList.add('mc-form-field_has-validate-directive');\n            this.elementRef.nativeElement.classList.add('mc-control_has-validate-directive');\n\n            this.setMosaicValidation();\n        }\n    }\n\n    ngOnDestroy() {\n        this.validationStatusChangesSubscription?.unsubscribe();\n    }\n\n    setValidState(control: AbstractControl, validator: ValidatorFn): void {\n        if (!control) { return; }\n\n        control.clearValidators();\n        control.updateValueAndValidity({ emitEvent: false });\n        control.setValidators(validator);\n    }\n\n    /** This function do next:\n     * - run validation on submitting parent form\n     * - prevent validation in required validator if form doesn't submitted\n     * - if control has focus validation will be prevented\n     */\n    setMosaicValidation(): void {\n        if (!this.validationControl) { return; }\n\n        if (this.parent?.onSubmit) {\n            // tslint:disable-next-line: no-unbound-method\n            const originalSubmit = this.parent.onSubmit;\n            this.parent.onSubmit = ($event: Event) => {\n                this.validationControl!.updateValueAndValidity({ emitEvent: false });\n\n                return originalSubmit.call(this.parent, $event);\n            };\n        }\n\n        if (this.isNgModel) {\n            this.setMosaicValidationForModelControl();\n        } else if (this.isFormControl || this.isFormControlName) {\n            this.setMosaicValidationForFormControl();\n        }\n    }\n\n    setMosaicValidationForModelControl() {\n        if (!this.rawValidators) { return; }\n\n        this.rawValidators.forEach((validator: Validator) => {\n            // tslint:disable-next-line: no-unbound-method\n            const originalValidate = validator.validate;\n\n            if (validator instanceof RequiredValidator) {\n                // changed required validation logic\n                validator.validate = (control: AbstractControl): ValidationErrors | null => {\n                    if (this.hasNotSubmittedParent) { return null; }\n\n                    return originalValidate.call(validator, control);\n                };\n            } else {\n                // changed all other validation logic\n                validator.validate = (control: AbstractControl): ValidationErrors | null => {\n                    if (this.formFieldControl.focused) { return null; }\n\n                    return originalValidate.call(validator, control);\n                };\n            }\n        });\n    }\n\n    setMosaicValidationForFormControl() {\n        const originalValidator = this.validationControl.validator;\n\n        // changed required validation logic after initialization\n        if (this.validationControl.invalid && this.validationControl.errors!.required) {\n            Promise.resolve().then(() => {\n                this.setValidState(this.validationControl, originalValidator!);\n                this.cdr.markForCheck();\n            });\n        }\n\n        // check dynamic updates\n        this.validationStatusChangesSubscription = this.validationControl.statusChanges!\n            .subscribe(() => {\n                // changed required validation logic\n                if (this.validationControl.invalid && (this.hasNotSubmittedParent) && this.validationControl.errors!.required) {\n                    this.setValidState(this.validationControl, originalValidator!);\n                }\n\n                // changed all other validation logic\n                if (this.validationControl.invalid && this.formFieldControl.focused) {\n                    this.setValidState(this.validationControl, originalValidator!);\n                }\n            });\n    }\n}\n"]}
|
|
@@ -21,7 +21,7 @@ export class McToastComponent {
|
|
|
21
21
|
};
|
|
22
22
|
}
|
|
23
23
|
get hasDismiss() {
|
|
24
|
-
return this.data.hasDismiss
|
|
24
|
+
return this.data.hasDismiss ?? true;
|
|
25
25
|
}
|
|
26
26
|
get isFocusedOrHovered() {
|
|
27
27
|
return this.hovered.getValue() || this.focused.getValue();
|
|
@@ -75,7 +75,7 @@ export class McToastComponent {
|
|
|
75
75
|
this.focusMonitor.stopMonitoring(this.elementRef.nativeElement);
|
|
76
76
|
}
|
|
77
77
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.0", ngImport: i0, type: McToastComponent, deps: [{ token: i1.McToastData }, { token: forwardRef(() => McToastService) }, { token: i0.ElementRef }, { token: i2.FocusMonitor }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
78
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.0", type: McToastComponent, selector: "mc-toast", host: { listeners: { "@state.start": "onAnimation($event)", "@state.done": "onAnimation($event)", "mouseenter": "hovered.next(true)", "mouseleave": "hovered.next(false)", "keydown.esc": "close()" }, properties: { "class": "toastStyle", "class.mc-toast_dismissible": "hasDismiss", "@state": "animationState" }, classAttribute: "mc-toast" }, ngImport: i0, template: "<div class=\"mc-toast__wrapper\">\n <div class=\"mc-toast__icon-container\">\n <ng-container *ngIf=\"isTemplateRef(data.icon)\"\n [ngTemplateOutlet]=\"$any(data.icon)\"\n [ngTemplateOutletContext]=\"{ $implicit }\">\n </ng-container>\n\n <ng-container *ngIf=\"!data.icon\">\n <ng-container [ngSwitch]=\"data.style\">\n <ng-container *ngSwitchCase=\"'info'\">\n <i mc-icon=\"mc-info_16\" class=\"mc-toast__icon\"></i>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'success'\">\n <i mc-icon=\"mc-success_16\" class=\"mc-toast__icon\"></i>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'warning'\">\n <i mc-icon=\"mc-error_16\" class=\"mc-toast__icon\"></i>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'error'\">\n <i mc-icon=\"mc-error_16\" class=\"mc-toast__icon\"></i>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n\n <div class=\"mc-toast__container\">\n <div *ngIf=\"data.title\" class=\"mc-toast__title\">\n <ng-container *ngIf=\"isTemplateRef(data.title)\"\n [ngTemplateOutlet]=\"$any(data.title)\"\n [ngTemplateOutletContext]=\"{ $implicit }\">\n </ng-container>\n\n <ng-container *ngIf=\"!isTemplateRef(data.title)\">\n <
|
|
78
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.0", type: McToastComponent, selector: "mc-toast", host: { listeners: { "@state.start": "onAnimation($event)", "@state.done": "onAnimation($event)", "mouseenter": "hovered.next(true)", "mouseleave": "hovered.next(false)", "keydown.esc": "close()" }, properties: { "class": "toastStyle", "class.mc-toast_dismissible": "hasDismiss", "@state": "animationState" }, classAttribute: "mc-toast" }, ngImport: i0, template: "<div class=\"mc-toast__wrapper\">\n <div class=\"mc-toast__icon-container\">\n <ng-container *ngIf=\"isTemplateRef(data.icon)\"\n [ngTemplateOutlet]=\"$any(data.icon)\"\n [ngTemplateOutletContext]=\"{ $implicit }\">\n </ng-container>\n\n <ng-container *ngIf=\"!data.icon\">\n <ng-container [ngSwitch]=\"data.style\">\n <ng-container *ngSwitchCase=\"'info'\">\n <i mc-icon=\"mc-info_16\" class=\"mc-toast__icon\"></i>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'success'\">\n <i mc-icon=\"mc-success_16\" class=\"mc-toast__icon\"></i>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'warning'\">\n <i mc-icon=\"mc-error_16\" class=\"mc-toast__icon\"></i>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'error'\">\n <i mc-icon=\"mc-error_16\" class=\"mc-toast__icon\"></i>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n\n <div class=\"mc-toast__container\">\n <div *ngIf=\"data.title\" class=\"mc-toast__title\">\n <ng-container *ngIf=\"isTemplateRef(data.title)\"\n [ngTemplateOutlet]=\"$any(data.title)\"\n [ngTemplateOutletContext]=\"{ $implicit }\">\n </ng-container>\n\n <ng-container *ngIf=\"!isTemplateRef(data.title)\">\n <p>{{ data.title }}</p>\n </ng-container>\n </div>\n\n <div *ngIf=\"data.caption\" class=\"mc-toast__caption\">\n <ng-container *ngIf=\"isTemplateRef(data.caption)\"\n [ngTemplateOutlet]=\"$any(data.caption)\"\n [ngTemplateOutletContext]=\"{ $implicit }\">\n </ng-container>\n\n <ng-container *ngIf=\"!isTemplateRef(data.caption)\">{{ data.caption }}</ng-container>\n </div>\n\n <div *ngIf=\"data.content\" class=\"mc-toast__content\">\n <ng-container *ngIf=\"isTemplateRef(data.content)\"\n [ngTemplateOutlet]=\"$any(data.content)\"\n [ngTemplateOutletContext]=\"{ $implicit }\">\n </ng-container>\n\n <ng-container *ngIf=\"!isTemplateRef(data.content)\">{{ data.content }}</ng-container>\n </div>\n\n <div *ngIf=\"data.actions\" class=\"mc-toast__actions\">\n <ng-container *ngIf=\"isTemplateRef(data.actions)\"\n [ngTemplateOutlet]=\"$any(data.actions)\"\n [ngTemplateOutletContext]=\"{ $implicit }\">\n </ng-container>\n\n <ng-container *ngIf=\"!isTemplateRef(data.actions)\">{{ data.actions }}</ng-container>\n </div>\n </div>\n\n <button\n class=\"mc-button_transparent mc-toast__close\"\n mc-button\n *ngIf=\"hasDismiss\"\n (click)=\"close()\">\n\n <i class=\"mc-icon_light\" mc-icon=\"mc-close-L_16\" [color]=\"themePalette.Secondary\"></i>\n </button>\n</div>\n", styles: [".mc-toast{box-sizing:border-box;z-index:1070;max-height:200px;height:auto}.mc-toast__wrapper{box-sizing:border-box;display:flex;flex:1 1 auto;width:var(--mc-toast-size-width, 360px);padding-right:var(--mc-toast-size-padding-right, 16px);padding-left:var(--mc-toast-size-padding-left, 12px);border-width:var(--mc-toast-size-border-width, 1px);border-style:solid;border-radius:var(--mc-toast-size-border-radius, 3px)}.mc-toast__icon-container{padding-right:var(--mc-toast-size-icon-margin, 8px);padding-top:var(--mc-toast-size-padding-vertical, 12px);padding-bottom:var(--mc-toast-size-padding-vertical, 12px)}.mc-toast__container{width:100%;padding-top:var(--mc-toast-size-padding-vertical, 12px);padding-bottom:var(--mc-toast-size-padding-vertical, 12px)}.mc-toast__title>p{margin:0}.mc-toast__content{display:flex;flex-direction:column;white-space:pre-wrap}.mc-toast__actions{margin-top:var(--mc-toast-size-actionbar-margin, 8px)}.mc-toast__actions>*{margin-right:var(--mc-toast-size-actionbar-gap, 12px)}.mc-toast__close{width:var(--mc-toast-size-close-button-width, 32px);height:var(--mc-toast-size-close-button-width, 32px);margin-top:6px;margin-right:-8px}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i4.McIcon, selector: "[mc-icon]", inputs: ["color"] }, { kind: "directive", type: i4.McIconCSSStyler, selector: "[mc-icon]" }, { kind: "component", type: i5.McButton, selector: "[mc-button]", inputs: ["color", "tabIndex", "disabled"] }, { kind: "directive", type: i5.McButtonCssStyler, selector: "[mc-button]" }], animations: [mcToastAnimations.toastState], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
79
79
|
}
|
|
80
80
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.0", ngImport: i0, type: McToastComponent, decorators: [{
|
|
81
81
|
type: Component,
|
|
@@ -89,9 +89,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.0", ngImpor
|
|
|
89
89
|
'(mouseenter)': 'hovered.next(true)',
|
|
90
90
|
'(mouseleave)': 'hovered.next(false)',
|
|
91
91
|
'(keydown.esc)': 'close()'
|
|
92
|
-
}, animations: [mcToastAnimations.toastState], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<div class=\"mc-toast__wrapper\">\n <div class=\"mc-toast__icon-container\">\n <ng-container *ngIf=\"isTemplateRef(data.icon)\"\n [ngTemplateOutlet]=\"$any(data.icon)\"\n [ngTemplateOutletContext]=\"{ $implicit }\">\n </ng-container>\n\n <ng-container *ngIf=\"!data.icon\">\n <ng-container [ngSwitch]=\"data.style\">\n <ng-container *ngSwitchCase=\"'info'\">\n <i mc-icon=\"mc-info_16\" class=\"mc-toast__icon\"></i>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'success'\">\n <i mc-icon=\"mc-success_16\" class=\"mc-toast__icon\"></i>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'warning'\">\n <i mc-icon=\"mc-error_16\" class=\"mc-toast__icon\"></i>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'error'\">\n <i mc-icon=\"mc-error_16\" class=\"mc-toast__icon\"></i>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n\n <div class=\"mc-toast__container\">\n <div *ngIf=\"data.title\" class=\"mc-toast__title\">\n <ng-container *ngIf=\"isTemplateRef(data.title)\"\n [ngTemplateOutlet]=\"$any(data.title)\"\n [ngTemplateOutletContext]=\"{ $implicit }\">\n </ng-container>\n\n <ng-container *ngIf=\"!isTemplateRef(data.title)\">\n <
|
|
92
|
+
}, animations: [mcToastAnimations.toastState], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<div class=\"mc-toast__wrapper\">\n <div class=\"mc-toast__icon-container\">\n <ng-container *ngIf=\"isTemplateRef(data.icon)\"\n [ngTemplateOutlet]=\"$any(data.icon)\"\n [ngTemplateOutletContext]=\"{ $implicit }\">\n </ng-container>\n\n <ng-container *ngIf=\"!data.icon\">\n <ng-container [ngSwitch]=\"data.style\">\n <ng-container *ngSwitchCase=\"'info'\">\n <i mc-icon=\"mc-info_16\" class=\"mc-toast__icon\"></i>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'success'\">\n <i mc-icon=\"mc-success_16\" class=\"mc-toast__icon\"></i>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'warning'\">\n <i mc-icon=\"mc-error_16\" class=\"mc-toast__icon\"></i>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'error'\">\n <i mc-icon=\"mc-error_16\" class=\"mc-toast__icon\"></i>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n\n <div class=\"mc-toast__container\">\n <div *ngIf=\"data.title\" class=\"mc-toast__title\">\n <ng-container *ngIf=\"isTemplateRef(data.title)\"\n [ngTemplateOutlet]=\"$any(data.title)\"\n [ngTemplateOutletContext]=\"{ $implicit }\">\n </ng-container>\n\n <ng-container *ngIf=\"!isTemplateRef(data.title)\">\n <p>{{ data.title }}</p>\n </ng-container>\n </div>\n\n <div *ngIf=\"data.caption\" class=\"mc-toast__caption\">\n <ng-container *ngIf=\"isTemplateRef(data.caption)\"\n [ngTemplateOutlet]=\"$any(data.caption)\"\n [ngTemplateOutletContext]=\"{ $implicit }\">\n </ng-container>\n\n <ng-container *ngIf=\"!isTemplateRef(data.caption)\">{{ data.caption }}</ng-container>\n </div>\n\n <div *ngIf=\"data.content\" class=\"mc-toast__content\">\n <ng-container *ngIf=\"isTemplateRef(data.content)\"\n [ngTemplateOutlet]=\"$any(data.content)\"\n [ngTemplateOutletContext]=\"{ $implicit }\">\n </ng-container>\n\n <ng-container *ngIf=\"!isTemplateRef(data.content)\">{{ data.content }}</ng-container>\n </div>\n\n <div *ngIf=\"data.actions\" class=\"mc-toast__actions\">\n <ng-container *ngIf=\"isTemplateRef(data.actions)\"\n [ngTemplateOutlet]=\"$any(data.actions)\"\n [ngTemplateOutletContext]=\"{ $implicit }\">\n </ng-container>\n\n <ng-container *ngIf=\"!isTemplateRef(data.actions)\">{{ data.actions }}</ng-container>\n </div>\n </div>\n\n <button\n class=\"mc-button_transparent mc-toast__close\"\n mc-button\n *ngIf=\"hasDismiss\"\n (click)=\"close()\">\n\n <i class=\"mc-icon_light\" mc-icon=\"mc-close-L_16\" [color]=\"themePalette.Secondary\"></i>\n </button>\n</div>\n", styles: [".mc-toast{box-sizing:border-box;z-index:1070;max-height:200px;height:auto}.mc-toast__wrapper{box-sizing:border-box;display:flex;flex:1 1 auto;width:var(--mc-toast-size-width, 360px);padding-right:var(--mc-toast-size-padding-right, 16px);padding-left:var(--mc-toast-size-padding-left, 12px);border-width:var(--mc-toast-size-border-width, 1px);border-style:solid;border-radius:var(--mc-toast-size-border-radius, 3px)}.mc-toast__icon-container{padding-right:var(--mc-toast-size-icon-margin, 8px);padding-top:var(--mc-toast-size-padding-vertical, 12px);padding-bottom:var(--mc-toast-size-padding-vertical, 12px)}.mc-toast__container{width:100%;padding-top:var(--mc-toast-size-padding-vertical, 12px);padding-bottom:var(--mc-toast-size-padding-vertical, 12px)}.mc-toast__title>p{margin:0}.mc-toast__content{display:flex;flex-direction:column;white-space:pre-wrap}.mc-toast__actions{margin-top:var(--mc-toast-size-actionbar-margin, 8px)}.mc-toast__actions>*{margin-right:var(--mc-toast-size-actionbar-gap, 12px)}.mc-toast__close{width:var(--mc-toast-size-close-button-width, 32px);height:var(--mc-toast-size-close-button-width, 32px);margin-top:6px;margin-right:-8px}\n"] }]
|
|
93
93
|
}], ctorParameters: () => [{ type: i1.McToastData }, { type: i6.McToastService, decorators: [{
|
|
94
94
|
type: Inject,
|
|
95
95
|
args: [forwardRef(() => McToastService)]
|
|
96
96
|
}] }, { type: i0.ElementRef }, { type: i2.FocusMonitor }] });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.component.js","sourceRoot":"","sources":["../../../../packages/mosaic/toast/toast.component.ts","../../../../packages/mosaic/toast/toast.component.html"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAe,MAAM,mBAAmB,CAAC;AAC9D,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,UAAU,EACV,MAAM,EAEN,WAAW,EACX,iBAAiB,EACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACvD,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEnD,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;;;;;;;;AAG3C,IAAI,EAAE,GAAG,CAAC,CAAC;AAuBX,MAAM,OAAO,gBAAgB;IAczB,IAAI,UAAU;QACV,OAAO;YACH,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,MAAM,EAAE,CAAC,EAAE,IAAI;SAClD,CAAC;IACN,CAAC;IAED,IAAI,UAAU;QACV,OAAO,IAAI,CAAC,IAAI,CAAC,UAAU,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC;IAC5E,CAAC;IAED,IAAI,kBAAkB;QAClB,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;IAC9D,CAAC;IAID,YACa,IAAiB,EACyB,OAAuB,EACnE,UAAsB,EACrB,YAA0B;QAHzB,SAAI,GAAJ,IAAI,CAAa;QACyB,YAAO,GAAP,OAAO,CAAgB;QACnE,eAAU,GAAV,UAAU,CAAY;QACrB,iBAAY,GAAZ,YAAY,CAAc;QAjCtC,iBAAY,GAAG,YAAY,CAAC;QAE5B,mBAAc,GAAG,MAAM,CAAC;QAEf,YAAO,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAC9C,YAAO,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAEvD,OAAE,GAAG,EAAE,EAAE,CAAC;QAoBF,cAAS,GAAqB,IAAI,OAAO,EAAE,CAAC;QAQhD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QAEtB,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;QAEhC,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAC7C,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAE7C,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC;aAC5B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC;aACzD,SAAS,CAAC,GAAG,EAAE;YACZ,IAAI,IAAI,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC;gBAAC,OAAO;YAAC,CAAC;YAE/B,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;QAC7D,CAAC,CAAC,CAAC;IACX,CAAC;IAED,WAAW;QACP,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAExB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACzB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,KAAK;QACD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC/B,CAAC;IAED,aAAa,CAAC,KAAK;QACf,OAAO,KAAK,YAAY,WAAW,CAAC;IACxC,CAAC;IAED,WAAW,CAAC,MAAsB;QAC9B,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACxC,CAAC;IAEO,eAAe;QACnB,IAAI,CAAC,YAAY;aACZ,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,IAAI,CAAC;aAC5C,SAAS,CAAC,CAAC,MAAmB,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;IACzE,CAAC;IAEO,gBAAgB;QACpB,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;IACpE,CAAC;iIAnFQ,gBAAgB,6CAgCb,UAAU,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC;qHAhCnC,gBAAgB,oYC5C7B,ysGA4EA,k8DDpCgB,CAAC,iBAAiB,CAAC,UAAU,CAAC;;2FAIjC,gBAAgB;kBArB5B,SAAS;+BACI,UAAU,QAGd;wBACF,KAAK,EAAE,UAAU;wBACjB,SAAS,EAAE,YAAY;wBACvB,8BAA8B,EAAE,YAAY;wBAC5C,UAAU,EAAE,gBAAgB;wBAC5B,gBAAgB,EAAE,qBAAqB;wBACvC,eAAe,EAAE,qBAAqB;wBAEtC,cAAc,EAAE,oBAAoB;wBACpC,cAAc,EAAE,qBAAqB;wBAErC,eAAe,EAAE,SAAS;qBAC7B,cACW,CAAC,iBAAiB,CAAC,UAAU,CAAC,mBACzB,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI;;0BAkChC,MAAM;2BAAC,UAAU,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC","sourcesContent":["import { AnimationEvent } from '@angular/animations';\nimport { FocusMonitor, FocusOrigin } from '@angular/cdk/a11y';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    forwardRef,\n    Inject,\n    OnDestroy,\n    TemplateRef,\n    ViewEncapsulation\n} from '@angular/core';\nimport { ThemePalette } from '@ptsecurity/mosaic/core';\nimport { BehaviorSubject, merge, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\n\nimport { mcToastAnimations } from './toast-animations';\nimport { McToastService } from './toast.service';\nimport { McToastData } from './toast.type';\n\n\nlet id = 0;\n\n@Component({\n    selector: 'mc-toast',\n    templateUrl: './toast.component.html',\n    styleUrls: ['./toast.component.scss'],\n    host: {\n        class: 'mc-toast',\n        '[class]': 'toastStyle',\n        '[class.mc-toast_dismissible]': 'hasDismiss',\n        '[@state]': 'animationState',\n        '(@state.start)': 'onAnimation($event)',\n        '(@state.done)': 'onAnimation($event)',\n\n        '(mouseenter)': 'hovered.next(true)',\n        '(mouseleave)': 'hovered.next(false)',\n\n        '(keydown.esc)': 'close()'\n    },\n    animations: [mcToastAnimations.toastState],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None\n})\nexport class McToastComponent implements OnDestroy {\n    themePalette = ThemePalette;\n\n    animationState = 'void';\n\n    readonly hovered = new BehaviorSubject<boolean>(false);\n    readonly focused = new BehaviorSubject<boolean>(false);\n\n    id = id++;\n    ttl;\n    delay;\n\n    $implicit;\n\n    get toastStyle() {\n        return {\n            [`mc-toast_${this.data.style || 'info'}`]: true\n        };\n    }\n\n    get hasDismiss(): boolean {\n        return this.data.hasDismiss === undefined ? true : this.data.hasDismiss;\n    }\n\n    get isFocusedOrHovered(): boolean {\n        return this.hovered.getValue() || this.focused.getValue();\n    }\n\n    private destroyed: Subject<boolean> = new Subject();\n\n    constructor(\n        readonly data: McToastData,\n        @Inject(forwardRef(() => McToastService)) readonly service: McToastService,\n        public elementRef: ElementRef,\n        private focusMonitor: FocusMonitor\n    ) {\n        this.$implicit = this;\n\n        this.animationState = 'visible';\n\n        this.runFocusMonitor();\n\n        this.hovered.subscribe(this.service.hovered);\n        this.focused.subscribe(this.service.focused);\n\n        merge(this.hovered, this.focused)\n            .pipe(takeUntil(this.destroyed), filter((value) => value))\n            .subscribe(() => {\n                if (this.ttl === 0) { return; }\n\n                this.ttl = this.ttl < this.delay ? this.delay : this.ttl;\n            });\n    }\n\n    ngOnDestroy() {\n        this.stopFocusMonitor();\n\n        this.hovered.next(false);\n        this.focused.next(false);\n\n        this.destroyed.next(true);\n    }\n\n    close(): void {\n        this.service.hide(this.id);\n    }\n\n    isTemplateRef(value): boolean {\n        return value instanceof TemplateRef;\n    }\n\n    onAnimation($event: AnimationEvent) {\n        this.service.animation.next($event);\n    }\n\n    private runFocusMonitor() {\n        this.focusMonitor\n            .monitor(this.elementRef.nativeElement, true)\n            .subscribe((origin: FocusOrigin) => this.focused.next(!!origin));\n    }\n\n    private stopFocusMonitor() {\n        this.focusMonitor.stopMonitoring(this.elementRef.nativeElement);\n    }\n}\n","<div class=\"mc-toast__wrapper\">\n    <div class=\"mc-toast__icon-container\">\n        <ng-container *ngIf=\"isTemplateRef(data.icon)\"\n                      [ngTemplateOutlet]=\"$any(data.icon)\"\n                      [ngTemplateOutletContext]=\"{ $implicit }\">\n        </ng-container>\n\n        <ng-container *ngIf=\"!data.icon\">\n            <ng-container [ngSwitch]=\"data.style\">\n                <ng-container *ngSwitchCase=\"'info'\">\n                    <i mc-icon=\"mc-info_16\" class=\"mc-toast__icon\"></i>\n                </ng-container>\n\n                <ng-container *ngSwitchCase=\"'success'\">\n                    <i mc-icon=\"mc-success_16\" class=\"mc-toast__icon\"></i>\n                </ng-container>\n\n                <ng-container *ngSwitchCase=\"'warning'\">\n                    <i mc-icon=\"mc-error_16\" class=\"mc-toast__icon\"></i>\n                </ng-container>\n\n                <ng-container *ngSwitchCase=\"'error'\">\n                    <i mc-icon=\"mc-error_16\" class=\"mc-toast__icon\"></i>\n                </ng-container>\n            </ng-container>\n        </ng-container>\n    </div>\n\n    <div class=\"mc-toast__container\">\n        <div *ngIf=\"data.title\" class=\"mc-toast__title\">\n            <ng-container *ngIf=\"isTemplateRef(data.title)\"\n                          [ngTemplateOutlet]=\"$any(data.title)\"\n                          [ngTemplateOutletContext]=\"{ $implicit }\">\n            </ng-container>\n\n            <ng-container *ngIf=\"!isTemplateRef(data.title)\">\n                <button\n                    class=\"mc-button_transparent mc-toast__close\"\n                    mc-button\n                    *ngIf=\"hasDismiss\"\n                    (click)=\"close()\">\n\n                    <i class=\"mc-icon_light\" mc-icon=\"mc-close-L_16\" [color]=\"themePalette.Secondary\"></i>\n                </button>\n                <p>{{ data.title }}</p>\n            </ng-container>\n        </div>\n\n        <div *ngIf=\"data.caption\" class=\"mc-toast__caption\">\n            <ng-container *ngIf=\"isTemplateRef(data.caption)\"\n                          [ngTemplateOutlet]=\"$any(data.caption)\"\n                          [ngTemplateOutletContext]=\"{ $implicit }\">\n            </ng-container>\n\n            <ng-container *ngIf=\"!isTemplateRef(data.caption)\">{{ data.caption }}</ng-container>\n        </div>\n\n        <div *ngIf=\"data.content\" class=\"mc-toast__content\">\n            <ng-container *ngIf=\"isTemplateRef(data.content)\"\n                          [ngTemplateOutlet]=\"$any(data.content)\"\n                          [ngTemplateOutletContext]=\"{ $implicit }\">\n            </ng-container>\n\n            <ng-container *ngIf=\"!isTemplateRef(data.content)\">{{ data.content }}</ng-container>\n        </div>\n\n        <div *ngIf=\"data.actions\" class=\"mc-toast__actions\">\n            <ng-container *ngIf=\"isTemplateRef(data.actions)\"\n                          [ngTemplateOutlet]=\"$any(data.actions)\"\n                          [ngTemplateOutletContext]=\"{ $implicit }\">\n            </ng-container>\n\n            <ng-container *ngIf=\"!isTemplateRef(data.actions)\">{{ data.actions }}</ng-container>\n        </div>\n    </div>\n</div>\n"]}
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.component.js","sourceRoot":"","sources":["../../../../packages/mosaic/toast/toast.component.ts","../../../../packages/mosaic/toast/toast.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent } from '@angular/animations';\nimport { FocusMonitor, FocusOrigin } from '@angular/cdk/a11y';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    forwardRef,\n    Inject,\n    OnDestroy,\n    TemplateRef,\n    ViewEncapsulation\n} from '@angular/core';\nimport { ThemePalette } from '@ptsecurity/mosaic/core';\nimport { BehaviorSubject, merge, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\n\nimport { mcToastAnimations } from './toast-animations';\nimport { McToastService } from './toast.service';\nimport { McToastData } from './toast.type';\n\n\nlet id = 0;\n\n@Component({\n    selector: 'mc-toast',\n    templateUrl: './toast.component.html',\n    styleUrls: ['./toast.component.scss'],\n    host: {\n        class: 'mc-toast',\n        '[class]': 'toastStyle',\n        '[class.mc-toast_dismissible]': 'hasDismiss',\n        '[@state]': 'animationState',\n        '(@state.start)': 'onAnimation($event)',\n        '(@state.done)': 'onAnimation($event)',\n\n        '(mouseenter)': 'hovered.next(true)',\n        '(mouseleave)': 'hovered.next(false)',\n\n        '(keydown.esc)': 'close()'\n    },\n    animations: [mcToastAnimations.toastState],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None\n})\nexport class McToastComponent implements OnDestroy {\n    themePalette = ThemePalette;\n\n    animationState = 'void';\n\n    readonly hovered = new BehaviorSubject<boolean>(false);\n    readonly focused = new BehaviorSubject<boolean>(false);\n\n    id = id++;\n    ttl;\n    delay;\n\n    $implicit;\n\n    get toastStyle() {\n        return {\n            [`mc-toast_${this.data.style || 'info'}`]: true\n        };\n    }\n\n    get hasDismiss(): boolean {\n        return this.data.hasDismiss ?? true;\n    }\n\n    get isFocusedOrHovered(): boolean {\n        return this.hovered.getValue() || this.focused.getValue();\n    }\n\n    private destroyed: Subject<boolean> = new Subject();\n\n    constructor(\n        readonly data: McToastData,\n        @Inject(forwardRef(() => McToastService)) readonly service: McToastService,\n        public elementRef: ElementRef,\n        private focusMonitor: FocusMonitor\n    ) {\n        this.$implicit = this;\n\n        this.animationState = 'visible';\n\n        this.runFocusMonitor();\n\n        this.hovered.subscribe(this.service.hovered);\n        this.focused.subscribe(this.service.focused);\n\n        merge(this.hovered, this.focused)\n            .pipe(takeUntil(this.destroyed), filter((value) => value))\n            .subscribe(() => {\n                if (this.ttl === 0) { return; }\n\n                this.ttl = this.ttl < this.delay ? this.delay : this.ttl;\n            });\n    }\n\n    ngOnDestroy() {\n        this.stopFocusMonitor();\n\n        this.hovered.next(false);\n        this.focused.next(false);\n\n        this.destroyed.next(true);\n    }\n\n    close(): void {\n        this.service.hide(this.id);\n    }\n\n    isTemplateRef(value): boolean {\n        return value instanceof TemplateRef;\n    }\n\n    onAnimation($event: AnimationEvent) {\n        this.service.animation.next($event);\n    }\n\n    private runFocusMonitor() {\n        this.focusMonitor\n            .monitor(this.elementRef.nativeElement, true)\n            .subscribe((origin: FocusOrigin) => this.focused.next(!!origin));\n    }\n\n    private stopFocusMonitor() {\n        this.focusMonitor.stopMonitoring(this.elementRef.nativeElement);\n    }\n}\n","<div class=\"mc-toast__wrapper\">\n    <div class=\"mc-toast__icon-container\">\n        <ng-container *ngIf=\"isTemplateRef(data.icon)\"\n                      [ngTemplateOutlet]=\"$any(data.icon)\"\n                      [ngTemplateOutletContext]=\"{ $implicit }\">\n        </ng-container>\n\n        <ng-container *ngIf=\"!data.icon\">\n            <ng-container [ngSwitch]=\"data.style\">\n                <ng-container *ngSwitchCase=\"'info'\">\n                    <i mc-icon=\"mc-info_16\" class=\"mc-toast__icon\"></i>\n                </ng-container>\n\n                <ng-container *ngSwitchCase=\"'success'\">\n                    <i mc-icon=\"mc-success_16\" class=\"mc-toast__icon\"></i>\n                </ng-container>\n\n                <ng-container *ngSwitchCase=\"'warning'\">\n                    <i mc-icon=\"mc-error_16\" class=\"mc-toast__icon\"></i>\n                </ng-container>\n\n                <ng-container *ngSwitchCase=\"'error'\">\n                    <i mc-icon=\"mc-error_16\" class=\"mc-toast__icon\"></i>\n                </ng-container>\n            </ng-container>\n        </ng-container>\n    </div>\n\n    <div class=\"mc-toast__container\">\n        <div *ngIf=\"data.title\" class=\"mc-toast__title\">\n            <ng-container *ngIf=\"isTemplateRef(data.title)\"\n                          [ngTemplateOutlet]=\"$any(data.title)\"\n                          [ngTemplateOutletContext]=\"{ $implicit }\">\n            </ng-container>\n\n            <ng-container *ngIf=\"!isTemplateRef(data.title)\">\n                <p>{{ data.title }}</p>\n            </ng-container>\n        </div>\n\n        <div *ngIf=\"data.caption\" class=\"mc-toast__caption\">\n            <ng-container *ngIf=\"isTemplateRef(data.caption)\"\n                          [ngTemplateOutlet]=\"$any(data.caption)\"\n                          [ngTemplateOutletContext]=\"{ $implicit }\">\n            </ng-container>\n\n            <ng-container *ngIf=\"!isTemplateRef(data.caption)\">{{ data.caption }}</ng-container>\n        </div>\n\n        <div *ngIf=\"data.content\" class=\"mc-toast__content\">\n            <ng-container *ngIf=\"isTemplateRef(data.content)\"\n                          [ngTemplateOutlet]=\"$any(data.content)\"\n                          [ngTemplateOutletContext]=\"{ $implicit }\">\n            </ng-container>\n\n            <ng-container *ngIf=\"!isTemplateRef(data.content)\">{{ data.content }}</ng-container>\n        </div>\n\n        <div *ngIf=\"data.actions\" class=\"mc-toast__actions\">\n            <ng-container *ngIf=\"isTemplateRef(data.actions)\"\n                          [ngTemplateOutlet]=\"$any(data.actions)\"\n                          [ngTemplateOutletContext]=\"{ $implicit }\">\n            </ng-container>\n\n            <ng-container *ngIf=\"!isTemplateRef(data.actions)\">{{ data.actions }}</ng-container>\n        </div>\n    </div>\n\n    <button\n        class=\"mc-button_transparent mc-toast__close\"\n        mc-button\n        *ngIf=\"hasDismiss\"\n        (click)=\"close()\">\n\n        <i class=\"mc-icon_light\" mc-icon=\"mc-close-L_16\" [color]=\"themePalette.Secondary\"></i>\n    </button>\n</div>\n"]}
|