@ptsecurity/mosaic 15.9.6 → 15.9.7
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/_theming.scss +17 -10
- 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/esm2020/core/common-behaviors/common-module.mjs +17 -22
- package/esm2020/core/error/error-options.mjs +15 -1
- package/esm2020/core/version.mjs +2 -2
- package/esm2020/form-field/validate.directive.mjs +16 -7
- package/esm2020/toast/toast.component.mjs +4 -4
- package/fesm2015/ptsecurity-mosaic-core.mjs +32 -23
- package/fesm2015/ptsecurity-mosaic-core.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-form-field.mjs +13 -4
- package/fesm2015/ptsecurity-mosaic-form-field.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-toast.mjs +4 -3
- package/fesm2015/ptsecurity-mosaic-toast.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-core.mjs +32 -23
- package/fesm2020/ptsecurity-mosaic-core.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-form-field.mjs +12 -4
- package/fesm2020/ptsecurity-mosaic-form-field.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-toast.mjs +3 -3
- package/fesm2020/ptsecurity-mosaic-toast.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 +4 -4
- 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
package/_theming.scss
CHANGED
|
@@ -5995,10 +5995,6 @@ $backdrop-animation-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;
|
|
|
5995
5995
|
color: mc-color($foreground, text);
|
|
5996
5996
|
}
|
|
5997
5997
|
|
|
5998
|
-
.mc-theme-loaded-marker {
|
|
5999
|
-
display: none;
|
|
6000
|
-
}
|
|
6001
|
-
|
|
6002
5998
|
.mc-primary {
|
|
6003
5999
|
color: mc-color(map-get($theme, primary));
|
|
6004
6000
|
}
|
|
@@ -7984,7 +7980,11 @@ $mc-datepicker-today-fade-amount: 0.2;
|
|
|
7984
7980
|
border-color: map-get($form-field, state-hover-border);
|
|
7985
7981
|
}
|
|
7986
7982
|
|
|
7987
|
-
|
|
7983
|
+
/* stylelint-disable no-descending-specificity */
|
|
7984
|
+
// Invalid by McValidateDirective
|
|
7985
|
+
&.mc-form-field_has-validate-directive.ng-invalid,
|
|
7986
|
+
// Invalid by control ErrorStateMatcher
|
|
7987
|
+
&.mc-form-field_invalid {
|
|
7988
7988
|
& .mc-form-field__container {
|
|
7989
7989
|
border-color: map-get($form-field, state-invalid-border);
|
|
7990
7990
|
background-color: map-get($form-field, state-invalid-background);
|
|
@@ -7997,17 +7997,18 @@ $mc-datepicker-today-fade-amount: 0.2;
|
|
|
7997
7997
|
}
|
|
7998
7998
|
|
|
7999
7999
|
&.cdk-focused {
|
|
8000
|
-
|
|
8000
|
+
&.mc-form-field_has-validate-directive:not(.ng-invalid) .mc-form-field__container,
|
|
8001
|
+
&:not(.mc-form-field_invalid) .mc-form-field__container {
|
|
8001
8002
|
border-color: map-get(map-get($theme, states), focused-color);
|
|
8002
8003
|
box-shadow: 0 0 0 1px map-get(map-get($theme, states), focused-color);
|
|
8003
8004
|
}
|
|
8004
8005
|
|
|
8005
|
-
&.ng-invalid .mc-form-field__container
|
|
8006
|
+
&.mc-form-field_has-validate-directive.ng-invalid .mc-form-field__container,
|
|
8007
|
+
&.mc-form-field_invalid .mc-form-field__container {
|
|
8006
8008
|
box-shadow: 0 0 0 1px mc-color($error);
|
|
8007
8009
|
}
|
|
8008
8010
|
}
|
|
8009
8011
|
|
|
8010
|
-
/* stylelint-disable no-descending-specificity */
|
|
8011
8012
|
&.mc-disabled .mc-form-field__container {
|
|
8012
8013
|
border-color: map-get($form-field, border);
|
|
8013
8014
|
|
|
@@ -9174,7 +9175,10 @@ button {
|
|
|
9174
9175
|
.mc-select {
|
|
9175
9176
|
color: map-get($foreground, text);
|
|
9176
9177
|
|
|
9177
|
-
|
|
9178
|
+
// Invalid by McValidateDirective
|
|
9179
|
+
&.mc-control_has-validate-directive.ng-invalid,
|
|
9180
|
+
// Invalid by control ErrorStateMatcher
|
|
9181
|
+
&.mc-invalid {
|
|
9178
9182
|
color: mc-color($error);
|
|
9179
9183
|
}
|
|
9180
9184
|
|
|
@@ -10119,7 +10123,10 @@ button {
|
|
|
10119
10123
|
.mc-tree-select {
|
|
10120
10124
|
color: map-get($foreground, text);
|
|
10121
10125
|
|
|
10122
|
-
|
|
10126
|
+
// Invalid by McValidateDirective
|
|
10127
|
+
&.mc-control_has-validate-directive.ng-invalid,
|
|
10128
|
+
// Invalid by control ErrorStateMatcher
|
|
10129
|
+
&.mc-invalid {
|
|
10123
10130
|
color: mc-color($error);
|
|
10124
10131
|
}
|
|
10125
10132
|
|
|
@@ -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
|
}
|
|
68
63
|
/** @nocollapse */ McCommonModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: McCommonModule, deps: [{ token: MC_SANITY_CHECKS, optional: true }], target: i0.ɵɵFactoryTarget.NgModule });
|
|
69
64
|
/** @nocollapse */ McCommonModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: McCommonModule, imports: [BidiModule], exports: [BidiModule] });
|
|
@@ -80,4 +75,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLW1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL21vc2FpYy9jb3JlL2NvbW1vbi1iZWhhdmlvcnMvY29tbW9uLW1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxjQUFjLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBR3RGOzs7Ozs7R0FNRztBQUNILE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLElBQUksY0FBYyxDQUFVLGtCQUFrQixFQUFFO0lBQzVFLFVBQVUsRUFBRSxNQUFNO0lBQ2xCLE9BQU8sRUFBRSxxQkFBcUI7Q0FDakMsQ0FBQyxDQUFDO0FBRUg7Ozs7R0FJRztBQUNILE1BQU0sVUFBVSxxQkFBcUI7SUFDakMsT0FBTyxJQUFJLENBQUM7QUFDaEIsQ0FBQztBQUVEOzs7Ozs7O0dBT0c7QUFLSCxNQUFNLE9BQU8sY0FBYztJQVl2QixZQUEwRCxvQkFBNkI7UUFBN0IseUJBQW9CLEdBQXBCLG9CQUFvQixDQUFTO1FBWHZGLDRGQUE0RjtRQUNwRix3QkFBbUIsR0FBRyxLQUFLLENBQUM7UUFFcEMsNkNBQTZDO1FBQzdDLHVEQUF1RDtRQUMvQyxjQUFTLEdBQUcsT0FBTyxRQUFRLEtBQUssUUFBUSxJQUFJLFFBQVEsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7UUFFL0UsMkNBQTJDO1FBQzNDLHVEQUF1RDtRQUMvQyxZQUFPLEdBQUcsT0FBTyxNQUFNLEtBQUssUUFBUSxJQUFJLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7UUFHbkUsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxtQkFBbUIsRUFBRTtZQUN0RCxJQUFJLENBQUMscUJBQXFCLEVBQUUsQ0FBQztZQUM3QixJQUFJLENBQUMsbUJBQW1CLEdBQUcsSUFBSSxDQUFDO1NBQ25DO0lBQ0wsQ0FBQztJQUVELHdDQUF3QztJQUNoQyxnQkFBZ0I7UUFDcEIsT0FBTyxJQUFJLENBQUMsb0JBQW9CLElBQUksU0FBUyxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDekUsQ0FBQztJQUVELHdDQUF3QztJQUNoQyxTQUFTO1FBQ2IsMkJBQTJCO1FBQzNCLE9BQU8sSUFBSSxDQUFDLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7SUFDOUcsQ0FBQztJQUVPLHFCQUFxQjtRQUN6QixJQUFJLElBQUksQ0FBQyxTQUFTLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sRUFBRTtZQUMzQyxPQUFPLENBQUMsSUFBSSxDQUNSLDJEQUEyRDtnQkFDM0QsbURBQW1ELENBQ3RELENBQUM7U0FDTDtJQUNMLENBQUM7OzhIQXJDUSxjQUFjLGtCQVlTLGdCQUFnQjsrSEFadkMsY0FBYyxZQUhiLFVBQVUsYUFDVixVQUFVOytIQUVYLGNBQWMsWUFIYixVQUFVLEVBQ1YsVUFBVTsyRkFFWCxjQUFjO2tCQUoxQixRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRSxDQUFDLFVBQVUsQ0FBQztvQkFDckIsT0FBTyxFQUFFLENBQUMsVUFBVSxDQUFDO2lCQUN4Qjs7MEJBYWdCLFFBQVE7OzBCQUFJLE1BQU07MkJBQUMsZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmlkaU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9iaWRpJztcbmltcG9ydCB7IE5nTW9kdWxlLCBJbmplY3Rpb25Ub2tlbiwgT3B0aW9uYWwsIEluamVjdCwgaXNEZXZNb2RlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cblxuLyoqXG4gKiBJbmplY3Rpb24gdG9rZW4gdGhhdCBjb25maWd1cmVzIHdoZXRoZXIgdGhlIE1vc2FpYyBzYW5pdHkgY2hlY2tzIGFyZSBlbmFibGVkLlxuICpcbiAqIEBkZXByZWNhdGVkIE5vIGxvbmdlciB1c2VkIGFuZCB3aWxsIGJlIHJlbW92ZWQuXG4gKlxuICogQGRvY3MtcHJpdmF0ZVxuICovXG5leHBvcnQgY29uc3QgTUNfU0FOSVRZX0NIRUNLUyA9IG5ldyBJbmplY3Rpb25Ub2tlbjxib29sZWFuPignbWMtc2FuaXR5LWNoZWNrcycsIHtcbiAgICBwcm92aWRlZEluOiAncm9vdCcsXG4gICAgZmFjdG9yeTogbWNTYW5pdHlDaGVja3NGYWN0b3J5XG59KTtcblxuLyoqXG4gKiBAZGVwcmVjYXRlZCBObyBsb25nZXIgdXNlZCBhbmQgd2lsbCBiZSByZW1vdmVkLlxuICpcbiAqIEBkb2NzLXByaXZhdGVcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIG1jU2FuaXR5Q2hlY2tzRmFjdG9yeSgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdHJ1ZTtcbn1cblxuLyoqXG4gKiBNb2R1bGUgdGhhdCBjYXB0dXJlcyBhbnl0aGluZyB0aGF0IHNob3VsZCBiZSBsb2FkZWQgYW5kL29yIHJ1biBmb3IgKmFsbCogTW9zYWljXG4gKiBjb21wb25lbnRzLiBUaGlzIGluY2x1ZGVzIEJpZGksIGV0Yy5cbiAqXG4gKiBAZGVwcmVjYXRlZCBObyBsb25nZXIgdXNlZCBhbmQgd2lsbCBiZSByZW1vdmVkLlxuICpcbiAqIEBkb2NzLXByaXZhdGVcbiAqL1xuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbQmlkaU1vZHVsZV0sXG4gICAgZXhwb3J0czogW0JpZGlNb2R1bGVdXG59KVxuZXhwb3J0IGNsYXNzIE1jQ29tbW9uTW9kdWxlIHtcbiAgICAvLyBXaGV0aGVyIHdlJ3ZlIGRvbmUgdGhlIGdsb2JhbCBzYW5pdHkgY2hlY2tzIChlLmcuIGEgdGhlbWUgaXMgbG9hZGVkLCB0aGVyZSBpcyBhIGRvY3R5cGUpLlxuICAgIHByaXZhdGUgaGFzRG9uZUdsb2JhbENoZWNrcyA9IGZhbHNlO1xuXG4gICAgLy8gUmVmZXJlbmNlIHRvIHRoZSBnbG9iYWwgYGRvY3VtZW50YCBvYmplY3QuXG4gICAgLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOiBvcnRob2RveC1nZXR0ZXItYW5kLXNldHRlclxuICAgIHByaXZhdGUgX2RvY3VtZW50ID0gdHlwZW9mIGRvY3VtZW50ID09PSAnb2JqZWN0JyAmJiBkb2N1bWVudCA/IGRvY3VtZW50IDogbnVsbDtcblxuICAgIC8vIFJlZmVyZW5jZSB0byB0aGUgZ2xvYmFsICd3aW5kb3cnIG9iamVjdC5cbiAgICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6IG9ydGhvZG94LWdldHRlci1hbmQtc2V0dGVyXG4gICAgcHJpdmF0ZSBfd2luZG93ID0gdHlwZW9mIHdpbmRvdyA9PT0gJ29iamVjdCcgJiYgd2luZG93ID8gd2luZG93IDogbnVsbDtcblxuICAgIGNvbnN0cnVjdG9yKEBPcHRpb25hbCgpIEBJbmplY3QoTUNfU0FOSVRZX0NIRUNLUykgcHJpdmF0ZSBfc2FuaXR5Q2hlY2tzRW5hYmxlZDogYm9vbGVhbikge1xuICAgICAgICBpZiAodGhpcy5hcmVDaGVja3NFbmFibGVkKCkgJiYgIXRoaXMuaGFzRG9uZUdsb2JhbENoZWNrcykge1xuICAgICAgICAgICAgdGhpcy5jaGVja0RvY3R5cGVJc0RlZmluZWQoKTtcbiAgICAgICAgICAgIHRoaXMuaGFzRG9uZUdsb2JhbENoZWNrcyA9IHRydWU7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICAvLyBXaGV0aGVyIGFueSBzYW5pdHkgY2hlY2tzIGFyZSBlbmFibGVkXG4gICAgcHJpdmF0ZSBhcmVDaGVja3NFbmFibGVkKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5fc2FuaXR5Q2hlY2tzRW5hYmxlZCAmJiBpc0Rldk1vZGUoKSAmJiAhdGhpcy5pc1Rlc3RFbnYoKTtcbiAgICB9XG5cbiAgICAvLyBXaGV0aGVyIHRoZSBjb2RlIGlzIHJ1bm5pbmcgaW4gdGVzdHMuXG4gICAgcHJpdmF0ZSBpc1Rlc3RFbnYoKSB7XG4gICAgICAgIC8vIHRzbGludDpkaXNhYmxlLW5leHQtbGluZVxuICAgICAgICByZXR1cm4gdGhpcy5fd2luZG93ICYmICh0aGlzLl93aW5kb3dbJ19fa2FybWFfXyddIHx8IHRoaXMuX3dpbmRvd1snamFzbWluZSddIHx8IHRoaXMuX3dpbmRvd1snX19qZXN0X18nXSk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBjaGVja0RvY3R5cGVJc0RlZmluZWQoKTogdm9pZCB7XG4gICAgICAgIGlmICh0aGlzLl9kb2N1bWVudCAmJiAhdGhpcy5fZG9jdW1lbnQuZG9jdHlwZSkge1xuICAgICAgICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICAgICAgICAgICdDdXJyZW50IGRvY3VtZW50IGRvZXMgbm90IGhhdmUgYSBkb2N0eXBlLiBUaGlzIG1heSBjYXVzZSAnICtcbiAgICAgICAgICAgICAgICAnc29tZSBNb3NhaWMgY29tcG9uZW50cyBub3QgdG8gYmVoYXZlIGFzIGV4cGVjdGVkLidcbiAgICAgICAgICAgICk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
|
|
@@ -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
|
+
}
|
|
12
|
+
/** @nocollapse */ ShowOnFormSubmitErrorStateMatcher.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ShowOnFormSubmitErrorStateMatcher, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
13
|
+
/** @nocollapse */ ShowOnFormSubmitErrorStateMatcher.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ShowOnFormSubmitErrorStateMatcher });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", 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: "15.2.9", ngImpor
|
|
|
23
37
|
type: Injectable,
|
|
24
38
|
args: [{ providedIn: 'root' }]
|
|
25
39
|
}] });
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3Itb3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL21vc2FpYy9jb3JlL2Vycm9yL2Vycm9yLW9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFJM0M7OztHQUdHO0FBRUgsTUFBTSxPQUFPLGlDQUFpQztJQUMxQyxZQUFZLENBQUMsT0FBa0MsRUFBRSxJQUF3QztRQUNyRixPQUFPLENBQUMsQ0FBQyxDQUFDLE9BQU8sRUFBRSxPQUFPLElBQUksSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBQ25ELENBQUM7O2lKQUhRLGlDQUFpQztxSkFBakMsaUNBQWlDOzJGQUFqQyxpQ0FBaUM7a0JBRDdDLFVBQVU7O0FBT1gsNEVBQTRFO0FBRTVFLE1BQU0sT0FBTyw0QkFBNEI7SUFDckMsWUFBWSxDQUFDLE9BQWtDLEVBQUUsSUFBd0M7UUFDckYsT0FBTyxDQUFDLENBQUMsQ0FBQyxPQUFPLElBQUksT0FBTyxDQUFDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN6RixDQUFDOzs0SUFIUSw0QkFBNEI7Z0pBQTVCLDRCQUE0QjsyRkFBNUIsNEJBQTRCO2tCQUR4QyxVQUFVOztBQU9YLGdHQUFnRztBQUVoRyxNQUFNLE9BQU8saUJBQWlCO0lBQzFCLFlBQVksQ0FBQyxPQUFrQyxFQUFFLElBQXdDO1FBQ3JGLE9BQU8sQ0FBQyxDQUFDLENBQUMsT0FBTyxJQUFJLE9BQU8sQ0FBQyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDM0YsQ0FBQzs7aUlBSFEsaUJBQWlCO3FJQUFqQixpQkFBaUIsY0FESixNQUFNOzJGQUNuQixpQkFBaUI7a0JBRDdCLFVBQVU7bUJBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUdyb3VwRGlyZWN0aXZlLCBOZ0Zvcm0sIFVudHlwZWRGb3JtQ29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuXG4vKipcbiAqIEVycm9yIHN0YXRlIG1hdGNoZXIgdGhhdCBtYXRjaGVzIHdoZW4gYSBjb250cm9sIGlzIGludmFsaWQgYW5kIGZvcm0gaXMgc3VibWl0dGVkLlxuICogUmVxdWlyZXMgdXNlIEZvcm1Hcm91cERpcmVjdGl2ZSBvciBOZ0Zvcm0uXG4gKi9cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBTaG93T25Gb3JtU3VibWl0RXJyb3JTdGF0ZU1hdGNoZXIgaW1wbGVtZW50cyBFcnJvclN0YXRlTWF0Y2hlciB7XG4gICAgaXNFcnJvclN0YXRlKGNvbnRyb2w6IFVudHlwZWRGb3JtQ29udHJvbCB8IG51bGwsIGZvcm06IEZvcm1Hcm91cERpcmVjdGl2ZSB8IE5nRm9ybSB8IG51bGwpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuICEhKGNvbnRyb2w/LmludmFsaWQgJiYgZm9ybT8uc3VibWl0dGVkKTtcbiAgICB9XG59XG5cbi8qKiBFcnJvciBzdGF0ZSBtYXRjaGVyIHRoYXQgbWF0Y2hlcyB3aGVuIGEgY29udHJvbCBpcyBpbnZhbGlkIGFuZCBkaXJ0eS4gKi9cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBTaG93T25EaXJ0eUVycm9yU3RhdGVNYXRjaGVyIGltcGxlbWVudHMgRXJyb3JTdGF0ZU1hdGNoZXIge1xuICAgIGlzRXJyb3JTdGF0ZShjb250cm9sOiBVbnR5cGVkRm9ybUNvbnRyb2wgfCBudWxsLCBmb3JtOiBGb3JtR3JvdXBEaXJlY3RpdmUgfCBOZ0Zvcm0gfCBudWxsKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiAhIShjb250cm9sICYmIGNvbnRyb2wuaW52YWxpZCAmJiAoY29udHJvbC5kaXJ0eSB8fCAoZm9ybSAmJiBmb3JtLnN1Ym1pdHRlZCkpKTtcbiAgICB9XG59XG5cbi8qKiBQcm92aWRlciB0aGF0IGRlZmluZXMgaG93IGZvcm0gY29udHJvbHMgYmVoYXZlIHdpdGggcmVnYXJkcyB0byBkaXNwbGF5aW5nIGVycm9yIG1lc3NhZ2VzLiAqL1xuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiAncm9vdCcgfSlcbmV4cG9ydCBjbGFzcyBFcnJvclN0YXRlTWF0Y2hlciB7XG4gICAgaXNFcnJvclN0YXRlKGNvbnRyb2w6IFVudHlwZWRGb3JtQ29udHJvbCB8IG51bGwsIGZvcm06IEZvcm1Hcm91cERpcmVjdGl2ZSB8IE5nRm9ybSB8IG51bGwpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuICEhKGNvbnRyb2wgJiYgY29udHJvbC5pbnZhbGlkICYmIChjb250cm9sLnRvdWNoZWQgfHwgKGZvcm0gJiYgZm9ybS5zdWJtaXR0ZWQpKSk7XG4gICAgfVxufVxuIl19
|
package/esm2020/core/version.mjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { Version } from '@angular/core';
|
|
2
|
-
export const VERSION = new Version('15.9.
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
export const VERSION = new Version('15.9.7+sha-1976033');
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL21vc2FpYy9jb3JlL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUd4QyxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsSUFBSSxPQUFPLENBQUMsb0JBQW9CLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFZlcnNpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IG5ldyBWZXJzaW9uKCcxNS45Ljcrc2hhLTE5NzYwMzMnKTtcbiJdfQ==
|
|
@@ -1,12 +1,13 @@
|
|
|
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
|
-
constructor(formFieldControl, rawValidators, ngControl, parentForm, parentFormGroup, mcValidation, cdr) {
|
|
10
|
+
constructor(formFieldControl, rawValidators, ngControl, parentForm, parentFormGroup, mcValidation, cdr, parentFormField, elementRef) {
|
|
10
11
|
this.formFieldControl = formFieldControl;
|
|
11
12
|
this.rawValidators = rawValidators;
|
|
12
13
|
this.ngControl = ngControl;
|
|
@@ -14,6 +15,8 @@ export class McValidateDirective {
|
|
|
14
15
|
this.parentFormGroup = parentFormGroup;
|
|
15
16
|
this.mcValidation = mcValidation;
|
|
16
17
|
this.cdr = cdr;
|
|
18
|
+
this.parentFormField = parentFormField;
|
|
19
|
+
this.elementRef = elementRef;
|
|
17
20
|
}
|
|
18
21
|
get isNgModel() {
|
|
19
22
|
return this.ngControl instanceof NgModel;
|
|
@@ -35,6 +38,8 @@ export class McValidateDirective {
|
|
|
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
|
}
|
|
@@ -120,7 +125,7 @@ export class McValidateDirective {
|
|
|
120
125
|
});
|
|
121
126
|
}
|
|
122
127
|
}
|
|
123
|
-
/** @nocollapse */ McValidateDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", 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 });
|
|
128
|
+
/** @nocollapse */ McValidateDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", 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 });
|
|
124
129
|
/** @nocollapse */ McValidateDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", 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 });
|
|
125
130
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: McValidateDirective, decorators: [{
|
|
126
131
|
type: Directive,
|
|
@@ -137,7 +142,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
137
142
|
`,
|
|
138
143
|
exportAs: 'McValidate'
|
|
139
144
|
}]
|
|
140
|
-
}], ctorParameters: function () { return [{ type:
|
|
145
|
+
}], ctorParameters: function () { return [{ type: i3.McFormFieldControl, decorators: [{
|
|
141
146
|
type: Inject,
|
|
142
147
|
args: [forwardRef(() => McFormFieldControl)]
|
|
143
148
|
}] }, { type: undefined, decorators: [{
|
|
@@ -160,5 +165,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
160
165
|
}, {
|
|
161
166
|
type: Inject,
|
|
162
167
|
args: [MC_VALIDATION]
|
|
163
|
-
}] }, { type: i0.ChangeDetectorRef }
|
|
164
|
-
//# 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\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';\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 {\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\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    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.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"]}
|
|
168
|
+
}] }, { type: i0.ChangeDetectorRef }, { type: i2.McFormField, decorators: [{
|
|
169
|
+
type: Optional
|
|
170
|
+
}, {
|
|
171
|
+
type: Host
|
|
172
|
+
}] }, { type: i0.ElementRef }]; } });
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validate.directive.js","sourceRoot":"","sources":["../../../../packages/mosaic/form-field/validate.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAEH,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,UAAU,EACV,IAAI,EACJ,MAAM,EACN,QAAQ,EACR,IAAI,EACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAEH,eAAe,EACf,kBAAkB,EAClB,aAAa,EACb,SAAS,EACT,MAAM,EACN,OAAO,EACP,iBAAiB,EAIjB,oBAAoB,EACvB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAEH,aAAa,EAChB,MAAM,yBAAyB,CAAC;AAGjC,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;;;;;AAgB1D,MAAM,OAAO,mBAAmB;IAyB5B,YAC0D,gBAAyC,EAC7C,aAA0B,EAChD,SAAoB,EAC5B,UAAkB,EAClB,eAAmC,EACZ,YAAiC,EACpE,GAAsB,EACO,eAAmC,EACvD,UAAmC;QARE,qBAAgB,GAAhB,gBAAgB,CAAyB;QAC7C,kBAAa,GAAb,aAAa,CAAa;QAChD,cAAS,GAAT,SAAS,CAAW;QAC5B,eAAU,GAAV,UAAU,CAAQ;QAClB,oBAAe,GAAf,eAAe,CAAoB;QACZ,iBAAY,GAAZ,YAAY,CAAqB;QACpE,QAAG,GAAH,GAAG,CAAmB;QACO,oBAAe,GAAf,eAAe,CAAoB;QACvD,eAAU,GAAV,UAAU,CAAyB;IACpD,CAAC;IAlCL,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,SAAS,YAAY,OAAO,CAAC;IAC7C,CAAC;IAED,IAAI,iBAAiB;QACjB,OAAO,IAAI,CAAC,SAAS,YAAY,eAAe,CAAC;IACrD,CAAC;IAED,IAAI,aAAa;QACb,OAAO,IAAI,CAAC,SAAS,YAAY,oBAAoB,CAAC;IAC1D,CAAC;IAED,IAAI,iBAAiB;QACjB,OAAO,IAAI,CAAC,SAAS,EAAE,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC;IACrD,CAAC;IAED,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,eAAe,CAAC;IACnD,CAAC;IAED,IAAI,qBAAqB;QACrB,OAAO,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;IACjD,CAAC;IAcD,kBAAkB;QACd,IAAI,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE;YACjC,IAAI,CAAC,eAAe,EAAE,UAAU,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,sCAAsC,CAAC,CAAC;YACrG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,mCAAmC,CAAC,CAAC;YAEjF,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC9B;IACL,CAAC;IAED,aAAa,CAAC,OAAwB,EAAE,SAAsB;QAC1D,IAAI,CAAC,OAAO,EAAE;YAAE,OAAO;SAAE;QAEzB,OAAO,CAAC,eAAe,EAAE,CAAC;QAC1B,OAAO,CAAC,sBAAsB,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;QACrD,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;IACrC,CAAC;IAED;;;;OAIG;IACH,mBAAmB;QACf,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;YAAE,OAAO;SAAE;QAExC,IAAI,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE;YACvB,8CAA8C;YAC9C,MAAM,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;YAC5C,IAAI,CAAC,MAAM,CAAC,QAAQ,GAAG,CAAC,MAAa,EAAE,EAAE;gBACrC,IAAI,CAAC,iBAAkB,CAAC,sBAAsB,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;gBAErE,OAAO,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;YACpD,CAAC,CAAC;SACL;QAED,IAAI,IAAI,CAAC,SAAS,EAAE;YAChB,IAAI,CAAC,kCAAkC,EAAE,CAAC;SAC7C;aAAM,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,iBAAiB,EAAE;YACrD,IAAI,CAAC,iCAAiC,EAAE,CAAC;SAC5C;IACL,CAAC;IAED,kCAAkC;QAC9B,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YAAE,OAAO;SAAE;QAEpC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,SAAoB,EAAE,EAAE;YAChD,8CAA8C;YAC9C,MAAM,gBAAgB,GAAG,SAAS,CAAC,QAAQ,CAAC;YAE5C,IAAI,SAAS,YAAY,iBAAiB,EAAE;gBACxC,oCAAoC;gBACpC,SAAS,CAAC,QAAQ,GAAG,CAAC,OAAwB,EAA2B,EAAE;oBACvE,IAAI,IAAI,CAAC,qBAAqB,EAAE;wBAAE,OAAO,IAAI,CAAC;qBAAE;oBAEhD,OAAO,gBAAgB,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;gBACrD,CAAC,CAAC;aACL;iBAAM;gBACH,qCAAqC;gBACrC,SAAS,CAAC,QAAQ,GAAG,CAAC,OAAwB,EAA2B,EAAE;oBACvE,IAAI,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE;wBAAE,OAAO,IAAI,CAAC;qBAAE;oBAEnD,OAAO,gBAAgB,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;gBACrD,CAAC,CAAC;aACL;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,iCAAiC;QAC7B,MAAM,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC;QAE3D,yDAAyD;QACzD,IAAI,IAAI,CAAC,iBAAiB,CAAC,OAAO,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAO,CAAC,QAAQ,EAAE;YAC3E,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;gBACxB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,iBAAiB,EAAE,iBAAkB,CAAC,CAAC;gBAC/D,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC5B,CAAC,CAAC,CAAC;SACN;QAED,wBAAwB;QACxB,IAAI,CAAC,iBAAiB,CAAC,aAAc;aAChC,SAAS,CAAC,GAAG,EAAE;YACZ,oCAAoC;YACpC,IAAI,IAAI,CAAC,iBAAiB,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAO,CAAC,QAAQ,EAAE;gBAC3G,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,iBAAiB,EAAE,iBAAkB,CAAC,CAAC;aAClE;YAED,qCAAqC;YACrC,IAAI,IAAI,CAAC,iBAAiB,CAAC,OAAO,IAAI,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE;gBACjE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,iBAAiB,EAAE,iBAAkB,CAAC,CAAC;aAClE;QACL,CAAC,CAAC,CAAC;IACX,CAAC;;mIAhIQ,mBAAmB,kBA0BhB,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC,aAChB,aAAa,sLAIrB,aAAa;uHA/B5B,mBAAmB;2FAAnB,mBAAmB;kBAb/B,SAAS;mBAAC;oBACP,QAAQ,EAAE;;;;;;;;;KAST;oBACD,QAAQ,EAAE,YAAY;iBACzB;;0BA2BQ,MAAM;2BAAC,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;;0BAC3C,QAAQ;;0BAAI,IAAI;;0BAAI,MAAM;2BAAC,aAAa;;0BACxC,QAAQ;;0BAAI,IAAI;;0BAChB,QAAQ;;0BACR,QAAQ;;0BACR,QAAQ;;0BAAI,MAAM;2BAAC,aAAa;;0BAEhC,QAAQ;;0BAAI,IAAI","sourcesContent":["import {\n    AfterContentInit,\n    ChangeDetectorRef,\n    Directive,\n    ElementRef,\n    forwardRef,\n    Host,\n    Inject,\n    Optional,\n    Self\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';\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 {\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\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    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.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"]}
|
|
@@ -46,7 +46,7 @@ export class McToastComponent {
|
|
|
46
46
|
};
|
|
47
47
|
}
|
|
48
48
|
get hasDismiss() {
|
|
49
|
-
return this.data.hasDismiss
|
|
49
|
+
return this.data.hasDismiss ?? true;
|
|
50
50
|
}
|
|
51
51
|
get isFocusedOrHovered() {
|
|
52
52
|
return this.hovered.getValue() || this.focused.getValue();
|
|
@@ -76,7 +76,7 @@ export class McToastComponent {
|
|
|
76
76
|
}
|
|
77
77
|
}
|
|
78
78
|
/** @nocollapse */ McToastComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: McToastComponent, deps: [{ token: i1.McToastData }, { token: forwardRef(() => McToastService) }, { token: i0.ElementRef }, { token: i2.FocusMonitor }], target: i0.ɵɵFactoryTarget.Component });
|
|
79
|
-
/** @nocollapse */ McToastComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", 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 <
|
|
79
|
+
/** @nocollapse */ McToastComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", 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 });
|
|
80
80
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: McToastComponent, decorators: [{
|
|
81
81
|
type: Component,
|
|
82
82
|
args: [{ selector: 'mc-toast', host: {
|
|
@@ -89,9 +89,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", 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: function () { return [{ 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":"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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 === 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"]}
|