@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.
@@ -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
- * This module should be imported to each top-level component module (e.g., McTabsModule).
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;
@@ -43,10 +43,6 @@
43
43
  color: mc-css-variable(foreground-text, map.get($foreground, text));
44
44
  }
45
45
 
46
- .mc-theme-loaded-marker {
47
- display: none;
48
- }
49
-
50
46
  .mc-primary {
51
47
  color: mc-css-variable(primary-default, map.get($theme, primary, default));
52
48
  }
@@ -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
- // Injection token that configures whether the Mosaic sanity checks are enabled.
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
- * This module should be imported to each top-level component module (e.g., McTabsModule).
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLW1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL21vc2FpYy9jb3JlL2NvbW1vbi1iZWhhdmlvcnMvY29tbW9uLW1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxjQUFjLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBR3RGLGdGQUFnRjtBQUNoRixNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLGNBQWMsQ0FBVSxrQkFBa0IsRUFBRTtJQUM1RSxVQUFVLEVBQUUsTUFBTTtJQUNsQixPQUFPLEVBQUUscUJBQXFCO0NBQ2pDLENBQUMsQ0FBQztBQUVILE1BQU0sVUFBVSxxQkFBcUI7SUFDakMsT0FBTyxJQUFJLENBQUM7QUFDaEIsQ0FBQztBQUVEOzs7OztHQUtHO0FBS0gsTUFBTSxPQUFPLGNBQWM7SUFZdkIsWUFBMEQsb0JBQTZCO1FBQTdCLHlCQUFvQixHQUFwQixvQkFBb0IsQ0FBUztRQVh2Riw0RkFBNEY7UUFDcEYsd0JBQW1CLEdBQUcsS0FBSyxDQUFDO1FBRXBDLDZDQUE2QztRQUM3Qyx1REFBdUQ7UUFDL0MsY0FBUyxHQUFHLE9BQU8sUUFBUSxLQUFLLFFBQVEsSUFBSSxRQUFRLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO1FBRS9FLDJDQUEyQztRQUMzQyx1REFBdUQ7UUFDL0MsWUFBTyxHQUFHLE9BQU8sTUFBTSxLQUFLLFFBQVEsSUFBSSxNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO1FBR25FLElBQUksSUFBSSxDQUFDLGdCQUFnQixFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztZQUN2RCxJQUFJLENBQUMscUJBQXFCLEVBQUUsQ0FBQztZQUM3QixJQUFJLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztZQUMzQixJQUFJLENBQUMsbUJBQW1CLEdBQUcsSUFBSSxDQUFDO1FBQ3BDLENBQUM7SUFDTCxDQUFDO0lBRUQsd0NBQXdDO0lBQ2hDLGdCQUFnQjtRQUNwQixPQUFPLElBQUksQ0FBQyxvQkFBb0IsSUFBSSxTQUFTLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztJQUN6RSxDQUFDO0lBRUQsd0NBQXdDO0lBQ2hDLFNBQVM7UUFDYiwyQkFBMkI7UUFDM0IsT0FBTyxJQUFJLENBQUMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFDbEYsQ0FBQztJQUVPLHFCQUFxQjtRQUN6QixJQUFJLElBQUksQ0FBQyxTQUFTLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQzVDLE9BQU8sQ0FBQyxJQUFJLENBQ1IsMkRBQTJEO2dCQUMzRCxtREFBbUQsQ0FDdEQsQ0FBQztRQUNOLENBQUM7SUFDTCxDQUFDO0lBRU8sbUJBQW1CO1FBQ3ZCLElBQUksSUFBSSxDQUFDLFNBQVMsSUFBSSxPQUFPLGdCQUFnQixLQUFLLFVBQVUsRUFBRSxDQUFDO1lBQzNELE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBRXhELFdBQVcsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLHdCQUF3QixDQUFDLENBQUM7WUFDcEQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBRTdDLE1BQU0sYUFBYSxHQUFHLGdCQUFnQixDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBRXBELHlGQUF5RjtZQUN6Riw4RkFBOEY7WUFDOUYsMkRBQTJEO1lBQzNELElBQUksYUFBYSxJQUFJLGFBQWEsQ0FBQyxPQUFPLEtBQUssTUFBTSxFQUFFLENBQUM7Z0JBQ3BELE9BQU8sQ0FBQyxJQUFJLENBQ1IsZ0RBQWdEO29CQUNoRCwyREFBMkQ7b0JBQzNELGtDQUFrQyxDQUNyQyxDQUFDO1lBQ04sQ0FBQztZQUVELElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNqRCxDQUFDO0lBQ0wsQ0FBQztpSUE5RFEsY0FBYyxrQkFZUyxnQkFBZ0I7a0lBWnZDLGNBQWMsWUFIYixVQUFVLGFBQ1YsVUFBVTtrSUFFWCxjQUFjLFlBSGIsVUFBVSxFQUNWLFVBQVU7OzJGQUVYLGNBQWM7a0JBSjFCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFLENBQUMsVUFBVSxDQUFDO29CQUNyQixPQUFPLEVBQUUsQ0FBQyxVQUFVLENBQUM7aUJBQ3hCOzswQkFhZ0IsUUFBUTs7MEJBQUksTUFBTTsyQkFBQyxnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCaWRpTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2JpZGknO1xuaW1wb3J0IHsgTmdNb2R1bGUsIEluamVjdGlvblRva2VuLCBPcHRpb25hbCwgSW5qZWN0LCBpc0Rldk1vZGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuXG4vLyBJbmplY3Rpb24gdG9rZW4gdGhhdCBjb25maWd1cmVzIHdoZXRoZXIgdGhlIE1vc2FpYyBzYW5pdHkgY2hlY2tzIGFyZSBlbmFibGVkLlxuZXhwb3J0IGNvbnN0IE1DX1NBTklUWV9DSEVDS1MgPSBuZXcgSW5qZWN0aW9uVG9rZW48Ym9vbGVhbj4oJ21jLXNhbml0eS1jaGVja3MnLCB7XG4gICAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxuICAgIGZhY3Rvcnk6IG1jU2FuaXR5Q2hlY2tzRmFjdG9yeVxufSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBtY1Nhbml0eUNoZWNrc0ZhY3RvcnkoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRydWU7XG59XG5cbi8qKlxuICogTW9kdWxlIHRoYXQgY2FwdHVyZXMgYW55dGhpbmcgdGhhdCBzaG91bGQgYmUgbG9hZGVkIGFuZC9vciBydW4gZm9yICphbGwqIE1vc2FpY1xuICogY29tcG9uZW50cy4gVGhpcyBpbmNsdWRlcyBCaWRpLCBldGMuXG4gKlxuICogVGhpcyBtb2R1bGUgc2hvdWxkIGJlIGltcG9ydGVkIHRvIGVhY2ggdG9wLWxldmVsIGNvbXBvbmVudCBtb2R1bGUgKGUuZy4sIE1jVGFic01vZHVsZSkuXG4gKi9cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW0JpZGlNb2R1bGVdLFxuICAgIGV4cG9ydHM6IFtCaWRpTW9kdWxlXVxufSlcbmV4cG9ydCBjbGFzcyBNY0NvbW1vbk1vZHVsZSB7XG4gICAgLy8gV2hldGhlciB3ZSd2ZSBkb25lIHRoZSBnbG9iYWwgc2FuaXR5IGNoZWNrcyAoZS5nLiBhIHRoZW1lIGlzIGxvYWRlZCwgdGhlcmUgaXMgYSBkb2N0eXBlKS5cbiAgICBwcml2YXRlIGhhc0RvbmVHbG9iYWxDaGVja3MgPSBmYWxzZTtcblxuICAgIC8vIFJlZmVyZW5jZSB0byB0aGUgZ2xvYmFsIGBkb2N1bWVudGAgb2JqZWN0LlxuICAgIC8vIHRzbGludDpkaXNhYmxlLW5leHQtbGluZTogb3J0aG9kb3gtZ2V0dGVyLWFuZC1zZXR0ZXJcbiAgICBwcml2YXRlIF9kb2N1bWVudCA9IHR5cGVvZiBkb2N1bWVudCA9PT0gJ29iamVjdCcgJiYgZG9jdW1lbnQgPyBkb2N1bWVudCA6IG51bGw7XG5cbiAgICAvLyBSZWZlcmVuY2UgdG8gdGhlIGdsb2JhbCAnd2luZG93JyBvYmplY3QuXG4gICAgLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOiBvcnRob2RveC1nZXR0ZXItYW5kLXNldHRlclxuICAgIHByaXZhdGUgX3dpbmRvdyA9IHR5cGVvZiB3aW5kb3cgPT09ICdvYmplY3QnICYmIHdpbmRvdyA/IHdpbmRvdyA6IG51bGw7XG5cbiAgICBjb25zdHJ1Y3RvcihAT3B0aW9uYWwoKSBASW5qZWN0KE1DX1NBTklUWV9DSEVDS1MpIHByaXZhdGUgX3Nhbml0eUNoZWNrc0VuYWJsZWQ6IGJvb2xlYW4pIHtcbiAgICAgICAgaWYgKHRoaXMuYXJlQ2hlY2tzRW5hYmxlZCgpICYmICF0aGlzLmhhc0RvbmVHbG9iYWxDaGVja3MpIHtcbiAgICAgICAgICAgIHRoaXMuY2hlY2tEb2N0eXBlSXNEZWZpbmVkKCk7XG4gICAgICAgICAgICB0aGlzLmNoZWNrVGhlbWVJc1ByZXNlbnQoKTtcbiAgICAgICAgICAgIHRoaXMuaGFzRG9uZUdsb2JhbENoZWNrcyA9IHRydWU7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICAvLyBXaGV0aGVyIGFueSBzYW5pdHkgY2hlY2tzIGFyZSBlbmFibGVkXG4gICAgcHJpdmF0ZSBhcmVDaGVja3NFbmFibGVkKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5fc2FuaXR5Q2hlY2tzRW5hYmxlZCAmJiBpc0Rldk1vZGUoKSAmJiAhdGhpcy5pc1Rlc3RFbnYoKTtcbiAgICB9XG5cbiAgICAvLyBXaGV0aGVyIHRoZSBjb2RlIGlzIHJ1bm5pbmcgaW4gdGVzdHMuXG4gICAgcHJpdmF0ZSBpc1Rlc3RFbnYoKSB7XG4gICAgICAgIC8vIHRzbGludDpkaXNhYmxlLW5leHQtbGluZVxuICAgICAgICByZXR1cm4gdGhpcy5fd2luZG93ICYmICh0aGlzLl93aW5kb3dbJ19fa2FybWFfXyddIHx8IHRoaXMuX3dpbmRvd1snamFzbWluZSddKTtcbiAgICB9XG5cbiAgICBwcml2YXRlIGNoZWNrRG9jdHlwZUlzRGVmaW5lZCgpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuX2RvY3VtZW50ICYmICF0aGlzLl9kb2N1bWVudC5kb2N0eXBlKSB7XG4gICAgICAgICAgICBjb25zb2xlLndhcm4oXG4gICAgICAgICAgICAgICAgJ0N1cnJlbnQgZG9jdW1lbnQgZG9lcyBub3QgaGF2ZSBhIGRvY3R5cGUuIFRoaXMgbWF5IGNhdXNlICcgK1xuICAgICAgICAgICAgICAgICdzb21lIE1vc2FpYyBjb21wb25lbnRzIG5vdCB0byBiZWhhdmUgYXMgZXhwZWN0ZWQuJ1xuICAgICAgICAgICAgKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHByaXZhdGUgY2hlY2tUaGVtZUlzUHJlc2VudCgpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuX2RvY3VtZW50ICYmIHR5cGVvZiBnZXRDb21wdXRlZFN0eWxlID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgICAgICBjb25zdCB0ZXN0RWxlbWVudCA9IHRoaXMuX2RvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ2RpdicpO1xuXG4gICAgICAgICAgICB0ZXN0RWxlbWVudC5jbGFzc0xpc3QuYWRkKCdtYy10aGVtZS1sb2FkZWQtbWFya2VyJyk7XG4gICAgICAgICAgICB0aGlzLl9kb2N1bWVudC5ib2R5LmFwcGVuZENoaWxkKHRlc3RFbGVtZW50KTtcblxuICAgICAgICAgICAgY29uc3QgY29tcHV0ZWRTdHlsZSA9IGdldENvbXB1dGVkU3R5bGUodGVzdEVsZW1lbnQpO1xuXG4gICAgICAgICAgICAvLyBJbiBzb21lIHNpdHVhdGlvbnMsIHRoZSBjb21wdXRlZCBzdHlsZSBvZiB0aGUgdGVzdCBlbGVtZW50IGNhbiBiZSBudWxsLiBGb3IgZXhhbXBsZSBpblxuICAgICAgICAgICAgLy8gRmlyZWZveCwgdGhlIGNvbXB1dGVkIHN0eWxlIGlzIG51bGwgaWYgYW4gYXBwbGljYXRpb24gaXMgcnVubmluZyBpbnNpZGUgb2YgYSBoaWRkZW4gaWZyYW1lLlxuICAgICAgICAgICAgLy8gU2VlOiBodHRwczovL2J1Z3ppbGxhLm1vemlsbGEub3JnL3Nob3dfYnVnLmNnaT9pZD01NDgzOTdcbiAgICAgICAgICAgIGlmIChjb21wdXRlZFN0eWxlICYmIGNvbXB1dGVkU3R5bGUuZGlzcGxheSAhPT0gJ25vbmUnKSB7XG4gICAgICAgICAgICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICAgICAgICAgICAgICAnQ291bGQgbm90IGZpbmQgTW9zYWljIGNvcmUgdGhlbWUuIE1vc3QgTW9zYWljICcgK1xuICAgICAgICAgICAgICAgICAgICAnY29tcG9uZW50cyBtYXkgbm90IHdvcmsgYXMgZXhwZWN0ZWQuIEZvciBtb3JlIGluZm8gcmVmZXIgJyArXG4gICAgICAgICAgICAgICAgICAgICd0byB0aGUgdGhlbWluZyBndWlkZTogbGluayB0aGVyZSdcbiAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICB0aGlzLl9kb2N1bWVudC5ib2R5LnJlbW92ZUNoaWxkKHRlc3RFbGVtZW50KTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3Itb3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL21vc2FpYy9jb3JlL2Vycm9yL2Vycm9yLW9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFJM0MsNEVBQTRFO0FBRTVFLE1BQU0sT0FBTyw0QkFBNEI7SUFDckMsWUFBWSxDQUFDLE9BQWtDLEVBQUUsSUFBd0M7UUFDckYsT0FBTyxDQUFDLENBQUMsQ0FBQyxPQUFPLElBQUksT0FBTyxDQUFDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN6RixDQUFDO2lJQUhRLDRCQUE0QjtxSUFBNUIsNEJBQTRCOzsyRkFBNUIsNEJBQTRCO2tCQUR4QyxVQUFVOztBQU9YLGdHQUFnRztBQUVoRyxNQUFNLE9BQU8saUJBQWlCO0lBQzFCLFlBQVksQ0FBQyxPQUFrQyxFQUFFLElBQXdDO1FBQ3JGLE9BQU8sQ0FBQyxDQUFDLENBQUMsT0FBTyxJQUFJLE9BQU8sQ0FBQyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDM0YsQ0FBQztpSUFIUSxpQkFBaUI7cUlBQWpCLGlCQUFpQixjQURKLE1BQU07OzJGQUNuQixpQkFBaUI7a0JBRDdCLFVBQVU7bUJBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUdyb3VwRGlyZWN0aXZlLCBOZ0Zvcm0sIFVudHlwZWRGb3JtQ29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuXG4vKiogRXJyb3Igc3RhdGUgbWF0Y2hlciB0aGF0IG1hdGNoZXMgd2hlbiBhIGNvbnRyb2wgaXMgaW52YWxpZCBhbmQgZGlydHkuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgU2hvd09uRGlydHlFcnJvclN0YXRlTWF0Y2hlciBpbXBsZW1lbnRzIEVycm9yU3RhdGVNYXRjaGVyIHtcbiAgICBpc0Vycm9yU3RhdGUoY29udHJvbDogVW50eXBlZEZvcm1Db250cm9sIHwgbnVsbCwgZm9ybTogRm9ybUdyb3VwRGlyZWN0aXZlIHwgTmdGb3JtIHwgbnVsbCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gISEoY29udHJvbCAmJiBjb250cm9sLmludmFsaWQgJiYgKGNvbnRyb2wuZGlydHkgfHwgKGZvcm0gJiYgZm9ybS5zdWJtaXR0ZWQpKSk7XG4gICAgfVxufVxuXG4vKiogUHJvdmlkZXIgdGhhdCBkZWZpbmVzIGhvdyBmb3JtIGNvbnRyb2xzIGJlaGF2ZSB3aXRoIHJlZ2FyZHMgdG8gZGlzcGxheWluZyBlcnJvciBtZXNzYWdlcy4gKi9cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXG5leHBvcnQgY2xhc3MgRXJyb3JTdGF0ZU1hdGNoZXIge1xuICAgIGlzRXJyb3JTdGF0ZShjb250cm9sOiBVbnR5cGVkRm9ybUNvbnRyb2wgfCBudWxsLCBmb3JtOiBGb3JtR3JvdXBEaXJlY3RpdmUgfCBOZ0Zvcm0gfCBudWxsKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiAhIShjb250cm9sICYmIGNvbnRyb2wuaW52YWxpZCAmJiAoY29udHJvbC50b3VjaGVkIHx8IChmb3JtICYmIGZvcm0uc3VibWl0dGVkKSkpO1xuICAgIH1cbn1cbiJdfQ==
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3Itb3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL21vc2FpYy9jb3JlL2Vycm9yL2Vycm9yLW9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFJM0M7OztHQUdHO0FBRUgsTUFBTSxPQUFPLGlDQUFpQztJQUMxQyxZQUFZLENBQUMsT0FBa0MsRUFBRSxJQUF3QztRQUNyRixPQUFPLENBQUMsQ0FBQyxDQUFDLE9BQU8sRUFBRSxPQUFPLElBQUksSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBQ25ELENBQUM7aUlBSFEsaUNBQWlDO3FJQUFqQyxpQ0FBaUM7OzJGQUFqQyxpQ0FBaUM7a0JBRDdDLFVBQVU7O0FBT1gsNEVBQTRFO0FBRTVFLE1BQU0sT0FBTyw0QkFBNEI7SUFDckMsWUFBWSxDQUFDLE9BQWtDLEVBQUUsSUFBd0M7UUFDckYsT0FBTyxDQUFDLENBQUMsQ0FBQyxPQUFPLElBQUksT0FBTyxDQUFDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN6RixDQUFDO2lJQUhRLDRCQUE0QjtxSUFBNUIsNEJBQTRCOzsyRkFBNUIsNEJBQTRCO2tCQUR4QyxVQUFVOztBQU9YLGdHQUFnRztBQUVoRyxNQUFNLE9BQU8saUJBQWlCO0lBQzFCLFlBQVksQ0FBQyxPQUFrQyxFQUFFLElBQXdDO1FBQ3JGLE9BQU8sQ0FBQyxDQUFDLENBQUMsT0FBTyxJQUFJLE9BQU8sQ0FBQyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDM0YsQ0FBQztpSUFIUSxpQkFBaUI7cUlBQWpCLGlCQUFpQixjQURKLE1BQU07OzJGQUNuQixpQkFBaUI7a0JBRDdCLFVBQVU7bUJBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUdyb3VwRGlyZWN0aXZlLCBOZ0Zvcm0sIFVudHlwZWRGb3JtQ29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuXG4vKipcbiAqIEVycm9yIHN0YXRlIG1hdGNoZXIgdGhhdCBtYXRjaGVzIHdoZW4gYSBjb250cm9sIGlzIGludmFsaWQgYW5kIGZvcm0gaXMgc3VibWl0dGVkLlxuICogUmVxdWlyZXMgdXNlIEZvcm1Hcm91cERpcmVjdGl2ZSBvciBOZ0Zvcm0uXG4gKi9cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBTaG93T25Gb3JtU3VibWl0RXJyb3JTdGF0ZU1hdGNoZXIgaW1wbGVtZW50cyBFcnJvclN0YXRlTWF0Y2hlciB7XG4gICAgaXNFcnJvclN0YXRlKGNvbnRyb2w6IFVudHlwZWRGb3JtQ29udHJvbCB8IG51bGwsIGZvcm06IEZvcm1Hcm91cERpcmVjdGl2ZSB8IE5nRm9ybSB8IG51bGwpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuICEhKGNvbnRyb2w/LmludmFsaWQgJiYgZm9ybT8uc3VibWl0dGVkKTtcbiAgICB9XG59XG5cbi8qKiBFcnJvciBzdGF0ZSBtYXRjaGVyIHRoYXQgbWF0Y2hlcyB3aGVuIGEgY29udHJvbCBpcyBpbnZhbGlkIGFuZCBkaXJ0eS4gKi9cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBTaG93T25EaXJ0eUVycm9yU3RhdGVNYXRjaGVyIGltcGxlbWVudHMgRXJyb3JTdGF0ZU1hdGNoZXIge1xuICAgIGlzRXJyb3JTdGF0ZShjb250cm9sOiBVbnR5cGVkRm9ybUNvbnRyb2wgfCBudWxsLCBmb3JtOiBGb3JtR3JvdXBEaXJlY3RpdmUgfCBOZ0Zvcm0gfCBudWxsKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiAhIShjb250cm9sICYmIGNvbnRyb2wuaW52YWxpZCAmJiAoY29udHJvbC5kaXJ0eSB8fCAoZm9ybSAmJiBmb3JtLnN1Ym1pdHRlZCkpKTtcbiAgICB9XG59XG5cbi8qKiBQcm92aWRlciB0aGF0IGRlZmluZXMgaG93IGZvcm0gY29udHJvbHMgYmVoYXZlIHdpdGggcmVnYXJkcyB0byBkaXNwbGF5aW5nIGVycm9yIG1lc3NhZ2VzLiAqL1xuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiAncm9vdCcgfSlcbmV4cG9ydCBjbGFzcyBFcnJvclN0YXRlTWF0Y2hlciB7XG4gICAgaXNFcnJvclN0YXRlKGNvbnRyb2w6IFVudHlwZWRGb3JtQ29udHJvbCB8IG51bGwsIGZvcm06IEZvcm1Hcm91cERpcmVjdGl2ZSB8IE5nRm9ybSB8IG51bGwpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuICEhKGNvbnRyb2wgJiYgY29udHJvbC5pbnZhbGlkICYmIChjb250cm9sLnRvdWNoZWQgfHwgKGZvcm0gJiYgZm9ybS5zdWJtaXR0ZWQpKSk7XG4gICAgfVxufVxuIl19
@@ -1,3 +1,3 @@
1
1
  import { Version } from '@angular/core';
2
- export const VERSION = new Version('17.5.2+sha-a4d8486');
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL21vc2FpYy9jb3JlL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUd4QyxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsSUFBSSxPQUFPLENBQUMsb0JBQW9CLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFZlcnNpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IG5ldyBWZXJzaW9uKCcxNy41LjIrc2hhLWE0ZDg0ODYnKTtcbiJdfQ==
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-control";
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: i2.McFormFieldControl, decorators: [{
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 === undefined ? true : 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 <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", 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}.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{float:right;width:var(--mc-toast-size-close-button-width, 32px);height:var(--mc-toast-size-close-button-width, 32px);margin:-6px -8px -6px 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 }); }
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 <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", 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}.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{float:right;width:var(--mc-toast-size-close-button-width, 32px);height:var(--mc-toast-size-close-button-width, 32px);margin:-6px -8px -6px 8px}\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":"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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":"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,IAAI,IAAI,CAAC;IACxC,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,unGA6EA,k9DDrCgB,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 ?? 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"]}