@testgorilla/tgo-ui 3.9.5 → 3.10.1

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.
Files changed (46) hide show
  1. package/README.md +103 -95
  2. package/components/card/card.component.d.ts +9 -2
  3. package/components/icon-label/icon-label.component.d.ts +9 -2
  4. package/components/selectable-card/selectable-card.component.d.ts +34 -0
  5. package/components/selectable-card/selectable-card.component.module.d.ts +10 -0
  6. package/components/side-panel/side-panel.component.d.ts +5 -1
  7. package/components/side-panel/side-panel.model.d.ts +2 -0
  8. package/esm2022/components/ai-feedback/ai-feedback.component.mjs +3 -3
  9. package/esm2022/components/ai-feedback/ai-feedback.model.mjs +1 -1
  10. package/esm2022/components/ai-feedback/ai-feedback.module.mjs +1 -1
  11. package/esm2022/components/alert-banner/alert-banner.component.mjs +1 -1
  12. package/esm2022/components/card/card.component.mjs +13 -4
  13. package/esm2022/components/checklist/checklist.component.mjs +3 -3
  14. package/esm2022/components/checklist/checklist.model.mjs +1 -1
  15. package/esm2022/components/datepicker/datepicker.component.mjs +3 -3
  16. package/esm2022/components/icon/icon.config.mjs +1 -1
  17. package/esm2022/components/icon-label/icon-label.component.mjs +16 -4
  18. package/esm2022/components/progress-bar/progress-bar.component.mjs +1 -1
  19. package/esm2022/components/selectable-card/selectable-card.component.mjs +53 -0
  20. package/esm2022/components/selectable-card/selectable-card.component.module.mjs +20 -0
  21. package/esm2022/components/side-panel/side-panel.animations.mjs +1 -1
  22. package/esm2022/components/side-panel/side-panel.component.mjs +10 -5
  23. package/esm2022/components/side-panel/side-panel.model.mjs +2 -1
  24. package/esm2022/components/side-panel/side-panel.service.mjs +1 -1
  25. package/esm2022/pipes/ui-translate.pipe.mjs +1 -1
  26. package/esm2022/public-api.mjs +4 -1
  27. package/fesm2022/testgorilla-tgo-ui.mjs +106 -16
  28. package/fesm2022/testgorilla-tgo-ui.mjs.map +1 -1
  29. package/package.json +1 -1
  30. package/projects/tgo-canopy-ui/assets/i18n/en.json +821 -821
  31. package/projects/tgo-canopy-ui/assets/icons/Switch-tab.svg +3 -3
  32. package/projects/tgo-canopy-ui/assets/icons/rebrand/Credit-card-filled.svg +10 -10
  33. package/projects/tgo-canopy-ui/assets/icons/rebrand/Credit-card-in-line.svg +10 -10
  34. package/projects/tgo-canopy-ui/assets/icons/rebrand/Credit-filled.svg +3 -3
  35. package/projects/tgo-canopy-ui/assets/icons/rebrand/Credit-in-line.svg +3 -3
  36. package/projects/tgo-canopy-ui/assets/icons/rebrand/Invoice-filled.svg +3 -3
  37. package/projects/tgo-canopy-ui/assets/icons/rebrand/Invoice-in-line.svg +3 -3
  38. package/projects/tgo-canopy-ui/assets/icons/rebrand/Open-lock-filled.svg +3 -3
  39. package/projects/tgo-canopy-ui/assets/icons/rebrand/Open-lock-in-line.svg +3 -3
  40. package/projects/tgo-canopy-ui/assets/icons/rebrand/Switch-tab-filled.svg +3 -3
  41. package/projects/tgo-canopy-ui/assets/icons/rebrand/Switch-tab-in-line.svg +3 -3
  42. package/projects/tgo-canopy-ui/assets/icons/rebrand/Thumb-down-filled.svg +3 -3
  43. package/projects/tgo-canopy-ui/assets/icons/rebrand/Thumb-down-in-line.svg +3 -3
  44. package/projects/tgo-canopy-ui/assets/icons/rebrand/Thumb-up-filled.svg +3 -3
  45. package/projects/tgo-canopy-ui/assets/icons/rebrand/Thumb-up-in-line.svg +3 -3
  46. package/public-api.d.ts +2 -0
package/README.md CHANGED
@@ -1,95 +1,103 @@
1
- # TestGorilla UI Library
2
-
3
- # Test app
4
-
5
- To see the updates of the library in the client app, use commands below from package.json
6
-
7
- - build the updated version of canopy-ui with `build:tgo-ui (ng build tgo-ui)`
8
- - restart the client app with `start:client (ng serve)`
9
-
10
- # Foundations
11
-
12
- - Typography
13
- - Colors
14
-
15
- # Components
16
-
17
- - Alert Bars
18
- - Alert Banner
19
- - Banner Actions
20
- - Snackbar
21
- - Button
22
- - Elevation Shadow
23
- - Dialog
24
- - Confirm Dialog
25
- - Custom Dialog
26
- - File Upload
27
- - Forms
28
- - Checkbox
29
- - Datepicker
30
- - Dropdown
31
- - Input Field
32
- - Radio
33
- - Icon
34
- - Icon + Label
35
- - Logo
36
- - Overflow Menu
37
- - Progress Bar
38
- - Tag
39
- - Tooltip
40
-
41
- # Deprecated
42
-
43
- - Card
44
- - Create Account
45
- - Create Password
46
- - Forgot Password
47
- - Label
48
- - Login
49
- - NavBar
50
- - Navigation
51
- - Paginator
52
- - Table
53
-
54
- ## Visual Regression
55
-
56
- We use Playwright to capture visual differences. The relevant code is in the `visual-tests` folder.
57
-
58
- ### Updating Snapshots
59
-
60
- To ensure consistency with CI, update snapshots using Docker:
61
-
62
- ```
63
- docker run --rm --network host -v $(pwd):/work/ -w /work/ -it mcr.microsoft.com/playwright:latest /bin/bash
64
- npx playwright install
65
- npx playwright test visual-tests --config 'visual-tests/playwright.config.ts' --update-snapshots
66
- ```
67
-
68
- If you encounter the following error, it can be safely ignored. We need reports in a single directory for CI artifact storage:
69
-
70
- ```
71
- Configuration Error: HTML reporter output folder clashes with the tests output folder:
72
-
73
- html reporter folder: /work/test-results/html-report
74
- test results folder: /work/test-results
75
-
76
- HTML reporter will clear its output directory prior to being generated, which will lead to the artifact loss.
77
- ```
78
-
79
- ### Running Visual Tests
80
-
81
- Use Docker to align screenshots with the same OS:
82
-
83
- ```
84
- docker run --rm --network host -v $(pwd):/work/ -w /work/ -it mcr.microsoft.com/playwright:latest /bin/bash
85
- npx playwright install
86
- npx playwright test visual-tests --config 'visual-tests/playwright.config.ts'
87
- ```
88
-
89
- ### Running Visual Tests for a single file
90
-
91
- ```
92
- npx playwright test visual-tests --config ‘visual-tests/playwright.config.ts’ -g ‘test_name’
93
- npx playwright test visual-tests/path_to_test_file --config ‘visual-tests/playwright.config.ts’
94
- ```
95
-
1
+ # TestGorilla UI Library
2
+
3
+ # Test app
4
+
5
+ To see the updates of the library in the client app, use commands below from package.json
6
+
7
+ - build the updated version of canopy-ui with `build:tgo-ui (ng build tgo-ui)`
8
+ - restart the client app with `start:client (ng serve)`
9
+
10
+ # Foundations
11
+
12
+ - Typography
13
+ - Colors
14
+
15
+ # Components
16
+
17
+ - Alert Bars
18
+ - Alert Banner
19
+ - Banner Actions
20
+ - Snackbar
21
+ - Button
22
+ - Elevation Shadow
23
+ - Dialog
24
+ - Confirm Dialog
25
+ - Custom Dialog
26
+ - File Upload
27
+ - Forms
28
+ - Checkbox
29
+ - Datepicker
30
+ - Dropdown
31
+ - Input Field
32
+ - Radio
33
+ - Icon
34
+ - Icon + Label
35
+ - Logo
36
+ - Overflow Menu
37
+ - Progress Bar
38
+ - Tag
39
+ - Tooltip
40
+
41
+ # Deprecated
42
+
43
+ - Card
44
+ - Create Account
45
+ - Create Password
46
+ - Forgot Password
47
+ - Label
48
+ - Login
49
+ - NavBar
50
+ - Navigation
51
+ - Paginator
52
+ - Table
53
+
54
+ ## Visual Regression Testing
55
+
56
+ The project uses **Playwright** for visual regression testing to ensure UI components maintain their visual appearance across changes. Visual tests automatically capture screenshots of all Storybook stories and compare them against stored snapshots.
57
+
58
+ ### Commands
59
+
60
+ ```bash
61
+ # Run visual tests
62
+ npm run visual-test
63
+
64
+ # Update snapshots when visual changes are intentional
65
+ npm run visual-test:update-snapshots
66
+ ```
67
+
68
+ ### How It Works
69
+
70
+ 1. **Build Phase**: Storybook is built (`npm run build-storybook`) creating static files
71
+ 2. **Docker Execution**: Tests run in a Linux container using `mcr.microsoft.com/playwright:v1.46.1` for consistency
72
+ 3. **Server Setup**: HTTP server serves Storybook static files on port 4200
73
+ 4. **Test Execution**: Automatically discovers and tests all stories from Storybook's `index.json`
74
+ 5. **Screenshot Comparison**: Compares current screenshots against stored snapshots
75
+
76
+ ### Docker Configuration
77
+
78
+ The system uses Docker Compose with two services:
79
+
80
+ - **visual-tests**: Runs tests and compares with existing snapshots
81
+ - **update-snapshots**: Updates snapshots when visual changes are expected
82
+
83
+ Both services:
84
+ - Use official Microsoft Playwright image (`mcr.microsoft.com/playwright:v1.46.1`)
85
+ - Mount project directory and install dependencies
86
+ - Start HTTP server and wait for Storybook availability
87
+ - Execute tests with Desktop Chrome viewport (1920x1200, 2x device scale)
88
+
89
+ ### Cross-Platform Consistency
90
+
91
+ Visual tests run in Docker to ensure:
92
+ - Consistent font rendering across operating systems
93
+ - Identical browser behavior regardless of host OS
94
+ - Reproducible results in CI/CD environments
95
+ - Linux-based snapshots that match production environments
96
+
97
+ ### Troubleshooting
98
+
99
+ - **Tests failing locally**: Run `npm run visual-test:update-snapshots` if changes are intentional
100
+ - **Font rendering differences**: Always use Docker commands for consistency
101
+ - **Timeout issues**: Server waits up to 60 seconds for Storybook to be ready
102
+ - **Memory issues**: Docker services configured with 4GB heap size
103
+
@@ -53,10 +53,17 @@ export declare class CardComponent implements OnChanges, OnInit {
53
53
  /**
54
54
  * Marks card as readonly. Defaults "false".
55
55
  *
56
- * @type {CardVariant}
56
+ * @type {boolean}
57
57
  * @memberof CardComponent
58
58
  */
59
59
  allowSelect: boolean;
60
+ /**
61
+ * Marks card as focusable. Defaults "true".
62
+ *
63
+ * @type {boolean}
64
+ * @memberof CardComponent
65
+ */
66
+ allowFocus: boolean;
60
67
  /**
61
68
  * Emits when card is being selected
62
69
  */
@@ -71,5 +78,5 @@ export declare class CardComponent implements OnChanges, OnInit {
71
78
  get isSelected(): boolean;
72
79
  selectCard(): void;
73
80
  static ɵfac: i0.ɵɵFactoryDeclaration<CardComponent, [{ optional: true; }, null]>;
74
- static ɵcmp: i0.ɵɵComponentDeclaration<CardComponent, "ui-card", never, { "size": { "alias": "size"; "required": false; }; "variant": { "alias": "variant"; "required": false; }; "applicationTheme": { "alias": "applicationTheme"; "required": false; }; "errors": { "alias": "errors"; "required": false; }; "errorsSize": { "alias": "errorsSize"; "required": false; }; "selected": { "alias": "selected"; "required": false; }; "allowSelect": { "alias": "allowSelect"; "required": false; }; }, { "cardSelected": "cardSelected"; }, never, ["*"], false, never>;
81
+ static ɵcmp: i0.ɵɵComponentDeclaration<CardComponent, "ui-card", never, { "size": { "alias": "size"; "required": false; }; "variant": { "alias": "variant"; "required": false; }; "applicationTheme": { "alias": "applicationTheme"; "required": false; }; "errors": { "alias": "errors"; "required": false; }; "errorsSize": { "alias": "errorsSize"; "required": false; }; "selected": { "alias": "selected"; "required": false; }; "allowSelect": { "alias": "allowSelect"; "required": false; }; "allowFocus": { "alias": "allowFocus"; "required": false; }; }, { "cardSelected": "cardSelected"; }, never, ["*"], false, never>;
75
82
  }
@@ -1,6 +1,6 @@
1
1
  import { OnInit } from '@angular/core';
2
2
  import { IconName, IconSize } from '../../components/icon/icon.model';
3
- import { ApplicationTheme } from "../../models/application-theme.model";
3
+ import { ApplicationTheme } from '../../models/application-theme.model';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class IconLabelComponent implements OnInit {
6
6
  private readonly defaultAppTheme;
@@ -31,6 +31,13 @@ export declare class IconLabelComponent implements OnInit {
31
31
  * @memberof IconLabelComponent
32
32
  */
33
33
  iconColor?: string | undefined;
34
+ /**
35
+ * Indent between icon and label
36
+ *
37
+ * @type {string}
38
+ * @memberof IconLabelComponent
39
+ */
40
+ iconIndent?: string | undefined;
34
41
  /**
35
42
  *
36
43
  * Defines the application theme
@@ -42,5 +49,5 @@ export declare class IconLabelComponent implements OnInit {
42
49
  constructor(defaultAppTheme: ApplicationTheme);
43
50
  ngOnInit(): void;
44
51
  static ɵfac: i0.ɵɵFactoryDeclaration<IconLabelComponent, [{ optional: true; }]>;
45
- static ɵcmp: i0.ɵɵComponentDeclaration<IconLabelComponent, "ui-icon-label", never, { "iconSize": { "alias": "iconSize"; "required": false; }; "iconName": { "alias": "iconName"; "required": false; }; "text": { "alias": "text"; "required": false; }; "iconColor": { "alias": "iconColor"; "required": false; }; "applicationTheme": { "alias": "applicationTheme"; "required": false; }; }, {}, never, never, false, never>;
52
+ static ɵcmp: i0.ɵɵComponentDeclaration<IconLabelComponent, "ui-icon-label", never, { "iconSize": { "alias": "iconSize"; "required": false; }; "iconName": { "alias": "iconName"; "required": false; }; "text": { "alias": "text"; "required": false; }; "iconColor": { "alias": "iconColor"; "required": false; }; "iconIndent": { "alias": "iconIndent"; "required": false; }; "applicationTheme": { "alias": "applicationTheme"; "required": false; }; }, {}, never, never, false, never>;
46
53
  }
@@ -0,0 +1,34 @@
1
+ import { CardSize } from '../card/card.model';
2
+ import * as i0 from "@angular/core";
3
+ export declare class SelectableCardComponent {
4
+ /**
5
+ * Card size. Defaults to "medium".
6
+ */
7
+ size: import("@angular/core").InputSignal<CardSize>;
8
+ /**
9
+ * Whether the card is selected (input from parent).
10
+ */
11
+ selected: import("@angular/core").InputSignal<boolean>;
12
+ /**
13
+ * Whether the checkbox is disabled.
14
+ */
15
+ isCheckboxDisabled: import("@angular/core").InputSignal<boolean>;
16
+ /**
17
+ * Event emitted when the card is selected, with the current selected state.
18
+ */
19
+ cardSelected: import("@angular/core").OutputEmitterRef<boolean>;
20
+ /**
21
+ * Internal override for selected state (when user interacts).
22
+ */
23
+ private internalSelectedOverride;
24
+ /**
25
+ * Computed selected state that prioritizes user interaction over input.
26
+ */
27
+ isSelected: import("@angular/core").Signal<boolean>;
28
+ /**
29
+ * Handles card selection, toggles internal state and emits the new value.
30
+ */
31
+ handleSelect(): void;
32
+ static ɵfac: i0.ɵɵFactoryDeclaration<SelectableCardComponent, never>;
33
+ static ɵcmp: i0.ɵɵComponentDeclaration<SelectableCardComponent, "ui-selectable-card", never, { "size": { "alias": "size"; "required": false; "isSignal": true; }; "selected": { "alias": "selected"; "required": false; "isSignal": true; }; "isCheckboxDisabled": { "alias": "isCheckboxDisabled"; "required": false; "isSignal": true; }; }, { "cardSelected": "cardSelected"; }, never, ["[ui-selectable-card-label]", "[ui-selectable-card-content]"], false, never>;
34
+ }
@@ -0,0 +1,10 @@
1
+ import * as i0 from "@angular/core";
2
+ import * as i1 from "./selectable-card.component";
3
+ import * as i2 from "@angular/common";
4
+ import * as i3 from "../card/card.component.module";
5
+ import * as i4 from "../checkbox/checkbox.component.module";
6
+ export declare class SelectableCardComponentModule {
7
+ static ɵfac: i0.ɵɵFactoryDeclaration<SelectableCardComponentModule, never>;
8
+ static ɵmod: i0.ɵɵNgModuleDeclaration<SelectableCardComponentModule, [typeof i1.SelectableCardComponent], [typeof i2.CommonModule, typeof i3.CardComponentModule, typeof i4.CheckboxComponentModule], [typeof i1.SelectableCardComponent]>;
9
+ static ɵinj: i0.ɵɵInjectorDeclaration<SelectableCardComponentModule>;
10
+ }
@@ -1,5 +1,5 @@
1
1
  import { ElementRef, ViewContainerRef } from '@angular/core';
2
- import { SidePanelAnimationState, SidePanelConfig, SidePanelPosition } from './side-panel.model';
2
+ import { SidePanelAnimationState, SidePanelConfig, SidePanelPosition, SidePanelSize } from './side-panel.model';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class SidePanelComponent {
5
5
  sidePanelPosition: import("@angular/core").WritableSignal<SidePanelPosition>;
@@ -8,6 +8,10 @@ export declare class SidePanelComponent {
8
8
  backdrop: import("@angular/core").Signal<ElementRef<HTMLDivElement>>;
9
9
  language: import("@testgorilla/tgo-ui").Language;
10
10
  isOpen: import("@angular/core").WritableSignal<boolean>;
11
+ size: import("@angular/core").WritableSignal<SidePanelSize | undefined>;
12
+ isSmall: import("@angular/core").Signal<boolean>;
13
+ isMedium: import("@angular/core").Signal<boolean>;
14
+ isLarge: import("@angular/core").Signal<boolean>;
11
15
  animation: import("@angular/core").Signal<SidePanelAnimationState.Open | SidePanelAnimationState.ClosedRight | SidePanelAnimationState.ClosedLeft>;
12
16
  private sidePanelService;
13
17
  sidePanelConfig: SidePanelConfig;
@@ -6,6 +6,7 @@ export declare enum SidePanelAnimationState {
6
6
  ClosedRight = "closedRight",
7
7
  ClosedLeft = "closedLeft"
8
8
  }
9
+ export type SidePanelSize = 'small' | 'medium' | 'large';
9
10
  export declare class SidePanelConfig {
10
11
  title: string;
11
12
  position: SidePanelPosition;
@@ -14,6 +15,7 @@ export declare class SidePanelConfig {
14
15
  showCloseButton?: boolean;
15
16
  showHeader?: boolean;
16
17
  panelClass?: string;
18
+ size?: SidePanelSize;
17
19
  }
18
20
  export declare const defaultSidePanelConfig: SidePanelConfig;
19
21
  export declare const SIDE_PANEL_CONFIG: InjectionToken<SidePanelConfig>;
@@ -20,11 +20,11 @@ export class AiFeedbackComponent {
20
20
  this.selectedValue.emit(this.selected());
21
21
  }
22
22
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AiFeedbackComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
23
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AiFeedbackComponent, selector: "ui-ai-feedback", inputs: { selection: "selection", tooltipPosition: "tooltipPosition" }, outputs: { selectedValue: "selectedValue" }, ngImport: i0, template: "<div class=\"ai-feedback\" [attr.aria-label]=\"'AI_FEEDBACK.TITLE' | uiTranslate\">\n <span>{{ 'AI_FEEDBACK.TITLE' | uiTranslate | async}}</span>\n <div class=\"ai-feedback-buttons\">\n @if(selected() !== optionNo) {\n <ui-button\n [justIcon]=\"true\"\n [iconName]=\"'Thumb-up-in-line'\"\n [size]=\"'small'\"\n [tooltipPosition]=\"tooltipPosition\"\n [tooltip]=\"('COMMON.YES' | uiTranslate | async)!\"\n [ariaLabel]=\"('COMMON.YES' | uiTranslate | async)!\"\n [iconFilled]=\"selected() === optionYes\"\n (buttonClickEvent)=\"onSelectionChange(optionYes)\"\n variant=\"icon-button\"\n role=\"button\"\n ></ui-button>\n }\n\n @if(selected() !== optionYes) {\n <ui-button\n [justIcon]=\"true\"\n [iconName]=\"'Thumb-down-in-line'\"\n [iconFilled]=\"selected() === optionNo\"\n [tooltip]=\"('COMMON.NO' | uiTranslate | async)!\"\n [ariaLabel]=\"('COMMON.NO' | uiTranslate | async)!\"\n [size]=\"'small'\"\n (buttonClickEvent)=\"onSelectionChange(optionNo)\"\n variant=\"icon-button\"\n role=\"button\"\n ></ui-button>\n }\n </div>\n</div>\n", styles: [".bg-teal-60b{background:#1c443c}.bg-teal-30b{background:#31766a}.bg-teal-default{background:#46a997}.bg-teal-30w{background:#7ec3b6}.bg-teal-60w{background:#b5ddd5}.bg-teal-secondary{background:#cbd6cb}.bg-teal-90w{background:#ecf6f5}.bg-petrol-60b{background:#102930}.bg-petrol-30b{background:#1b4754}.bg-petrol-default{background:#276678}.bg-petrol-30w{background:#6894a0}.bg-petrol-60w{background:#a9c2c9}.bg-petrol-secondary{background:#c8d7de}.bg-petrol-90w{background:#e9f0f1}.bg-error-60b{background:#513131}.bg-error-30b{background:#8e5655}.bg-error-60w{background:#e3c3c6}.bg-error-secondary{background:#f0dad9}.bg-error-default{background:#cb7b7a}.bg-warning-secondary{background:#f0d6bb}.bg-warning-default{background:#cca45f}.bg-black{background:#000}.bg-dark{background:#888}.bg-medium{background:#e0e0e0}.bg-grey{background:#ededed}.bg-light{background:#f6f6f6}.bg-white{background:#fff}.bg-box-shadow{background:#00000014}.bg-navigation-subtitle{background:#528593}.bgc-teal-60b{background-color:#1c443c}.bgc-teal-30b{background-color:#31766a}.bgc-teal-default{background-color:#46a997}.bgc-teal-30w{background-color:#7ec3b6}.bgc-teal-60w{background-color:#b5ddd5}.bgc-teal-secondary{background-color:#cbd6cb}.bgc-teal-90w{background-color:#ecf6f5}.bgc-petrol-60b{background-color:#102930}.bgc-petrol-30b{background-color:#1b4754}.bgc-petrol-default{background-color:#276678}.bgc-petrol-30w{background-color:#6894a0}.bgc-petrol-60w{background-color:#a9c2c9}.bgc-petrol-secondary{background-color:#c8d7de}.bgc-petrol-90w{background-color:#e9f0f1}.bgc-error-60b{background-color:#513131}.bgc-error-30b{background-color:#8e5655}.bgc-error-60w{background-color:#e3c3c6}.bgc-error-secondary{background-color:#f0dad9}.bgc-error-default{background-color:#cb7b7a}.bgc-warning-secondary{background-color:#f0d6bb}.bgc-warning-default{background-color:#cca45f}.bgc-black{background-color:#000}.bgc-dark{background-color:#888}.bgc-medium{background-color:#e0e0e0}.bgc-grey{background-color:#ededed}.bgc-light{background-color:#f6f6f6}.bgc-white{background-color:#fff}.bgc-box-shadow{background-color:#00000014}.bgc-navigation-subtitle{background-color:#528593}.ai-feedback,.ai-feedback-buttons{display:flex;flex-flow:row nowrap;align-items:center}.ai-feedback>span{color:#666;margin-right:16px}.ai-feedback-buttons{justify-content:center}.ai-feedback-buttons>ui-button:first-child{margin-right:8px}\n"], dependencies: [{ kind: "component", type: i1.ButtonComponent, selector: "ui-button", inputs: ["size", "variant", "label", "iconPosition", "justIcon", "iconName", "disabled", "loading", "fullWidth", "url", "urlTarget", "value", "tooltip", "isPremium", "type", "companyColor", "buttonBadgeConfig", "applicationTheme", "disabledScaleOnClick", "ariaLabel", "ariaRequired", "ariaLabelledby", "ariaDescribedby", "preventDefault", "hasBackground", "tooltipPosition", "role", "iconFilled"], outputs: ["buttonClickEvent", "buttonHoverEvent"] }, { kind: "pipe", type: i2.UiTranslatePipe, name: "uiTranslate" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
23
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AiFeedbackComponent, selector: "ui-ai-feedback", inputs: { selection: "selection", tooltipPosition: "tooltipPosition" }, outputs: { selectedValue: "selectedValue" }, ngImport: i0, template: "<div class=\"ai-feedback\" [attr.aria-label]=\"'AI_FEEDBACK.TITLE' | uiTranslate\">\r\n <span>{{ 'AI_FEEDBACK.TITLE' | uiTranslate | async}}</span>\r\n <div class=\"ai-feedback-buttons\">\r\n @if(selected() !== optionNo) {\r\n <ui-button\r\n [justIcon]=\"true\"\r\n [iconName]=\"'Thumb-up-in-line'\"\r\n [size]=\"'small'\"\r\n [tooltipPosition]=\"tooltipPosition\"\r\n [tooltip]=\"('COMMON.YES' | uiTranslate | async)!\"\r\n [ariaLabel]=\"('COMMON.YES' | uiTranslate | async)!\"\r\n [iconFilled]=\"selected() === optionYes\"\r\n (buttonClickEvent)=\"onSelectionChange(optionYes)\"\r\n variant=\"icon-button\"\r\n role=\"button\"\r\n ></ui-button>\r\n }\r\n\r\n @if(selected() !== optionYes) {\r\n <ui-button\r\n [justIcon]=\"true\"\r\n [iconName]=\"'Thumb-down-in-line'\"\r\n [iconFilled]=\"selected() === optionNo\"\r\n [tooltip]=\"('COMMON.NO' | uiTranslate | async)!\"\r\n [ariaLabel]=\"('COMMON.NO' | uiTranslate | async)!\"\r\n [size]=\"'small'\"\r\n (buttonClickEvent)=\"onSelectionChange(optionNo)\"\r\n variant=\"icon-button\"\r\n role=\"button\"\r\n ></ui-button>\r\n }\r\n </div>\r\n</div>\r\n", styles: [".bg-teal-60b{background:#1c443c}.bg-teal-30b{background:#31766a}.bg-teal-default{background:#46a997}.bg-teal-30w{background:#7ec3b6}.bg-teal-60w{background:#b5ddd5}.bg-teal-secondary{background:#cbd6cb}.bg-teal-90w{background:#ecf6f5}.bg-petrol-60b{background:#102930}.bg-petrol-30b{background:#1b4754}.bg-petrol-default{background:#276678}.bg-petrol-30w{background:#6894a0}.bg-petrol-60w{background:#a9c2c9}.bg-petrol-secondary{background:#c8d7de}.bg-petrol-90w{background:#e9f0f1}.bg-error-60b{background:#513131}.bg-error-30b{background:#8e5655}.bg-error-60w{background:#e3c3c6}.bg-error-secondary{background:#f0dad9}.bg-error-default{background:#cb7b7a}.bg-warning-secondary{background:#f0d6bb}.bg-warning-default{background:#cca45f}.bg-black{background:#000}.bg-dark{background:#888}.bg-medium{background:#e0e0e0}.bg-grey{background:#ededed}.bg-light{background:#f6f6f6}.bg-white{background:#fff}.bg-box-shadow{background:#00000014}.bg-navigation-subtitle{background:#528593}.bgc-teal-60b{background-color:#1c443c}.bgc-teal-30b{background-color:#31766a}.bgc-teal-default{background-color:#46a997}.bgc-teal-30w{background-color:#7ec3b6}.bgc-teal-60w{background-color:#b5ddd5}.bgc-teal-secondary{background-color:#cbd6cb}.bgc-teal-90w{background-color:#ecf6f5}.bgc-petrol-60b{background-color:#102930}.bgc-petrol-30b{background-color:#1b4754}.bgc-petrol-default{background-color:#276678}.bgc-petrol-30w{background-color:#6894a0}.bgc-petrol-60w{background-color:#a9c2c9}.bgc-petrol-secondary{background-color:#c8d7de}.bgc-petrol-90w{background-color:#e9f0f1}.bgc-error-60b{background-color:#513131}.bgc-error-30b{background-color:#8e5655}.bgc-error-60w{background-color:#e3c3c6}.bgc-error-secondary{background-color:#f0dad9}.bgc-error-default{background-color:#cb7b7a}.bgc-warning-secondary{background-color:#f0d6bb}.bgc-warning-default{background-color:#cca45f}.bgc-black{background-color:#000}.bgc-dark{background-color:#888}.bgc-medium{background-color:#e0e0e0}.bgc-grey{background-color:#ededed}.bgc-light{background-color:#f6f6f6}.bgc-white{background-color:#fff}.bgc-box-shadow{background-color:#00000014}.bgc-navigation-subtitle{background-color:#528593}.ai-feedback,.ai-feedback-buttons{display:flex;flex-flow:row nowrap;align-items:center}.ai-feedback>span{color:#666;margin-right:16px}.ai-feedback-buttons{justify-content:center}.ai-feedback-buttons>ui-button:first-child{margin-right:8px}\n"], dependencies: [{ kind: "component", type: i1.ButtonComponent, selector: "ui-button", inputs: ["size", "variant", "label", "iconPosition", "justIcon", "iconName", "disabled", "loading", "fullWidth", "url", "urlTarget", "value", "tooltip", "isPremium", "type", "companyColor", "buttonBadgeConfig", "applicationTheme", "disabledScaleOnClick", "ariaLabel", "ariaRequired", "ariaLabelledby", "ariaDescribedby", "preventDefault", "hasBackground", "tooltipPosition", "role", "iconFilled"], outputs: ["buttonClickEvent", "buttonHoverEvent"] }, { kind: "pipe", type: i2.UiTranslatePipe, name: "uiTranslate" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
24
24
  }
25
25
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AiFeedbackComponent, decorators: [{
26
26
  type: Component,
27
- args: [{ selector: 'ui-ai-feedback', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"ai-feedback\" [attr.aria-label]=\"'AI_FEEDBACK.TITLE' | uiTranslate\">\n <span>{{ 'AI_FEEDBACK.TITLE' | uiTranslate | async}}</span>\n <div class=\"ai-feedback-buttons\">\n @if(selected() !== optionNo) {\n <ui-button\n [justIcon]=\"true\"\n [iconName]=\"'Thumb-up-in-line'\"\n [size]=\"'small'\"\n [tooltipPosition]=\"tooltipPosition\"\n [tooltip]=\"('COMMON.YES' | uiTranslate | async)!\"\n [ariaLabel]=\"('COMMON.YES' | uiTranslate | async)!\"\n [iconFilled]=\"selected() === optionYes\"\n (buttonClickEvent)=\"onSelectionChange(optionYes)\"\n variant=\"icon-button\"\n role=\"button\"\n ></ui-button>\n }\n\n @if(selected() !== optionYes) {\n <ui-button\n [justIcon]=\"true\"\n [iconName]=\"'Thumb-down-in-line'\"\n [iconFilled]=\"selected() === optionNo\"\n [tooltip]=\"('COMMON.NO' | uiTranslate | async)!\"\n [ariaLabel]=\"('COMMON.NO' | uiTranslate | async)!\"\n [size]=\"'small'\"\n (buttonClickEvent)=\"onSelectionChange(optionNo)\"\n variant=\"icon-button\"\n role=\"button\"\n ></ui-button>\n }\n </div>\n</div>\n", styles: [".bg-teal-60b{background:#1c443c}.bg-teal-30b{background:#31766a}.bg-teal-default{background:#46a997}.bg-teal-30w{background:#7ec3b6}.bg-teal-60w{background:#b5ddd5}.bg-teal-secondary{background:#cbd6cb}.bg-teal-90w{background:#ecf6f5}.bg-petrol-60b{background:#102930}.bg-petrol-30b{background:#1b4754}.bg-petrol-default{background:#276678}.bg-petrol-30w{background:#6894a0}.bg-petrol-60w{background:#a9c2c9}.bg-petrol-secondary{background:#c8d7de}.bg-petrol-90w{background:#e9f0f1}.bg-error-60b{background:#513131}.bg-error-30b{background:#8e5655}.bg-error-60w{background:#e3c3c6}.bg-error-secondary{background:#f0dad9}.bg-error-default{background:#cb7b7a}.bg-warning-secondary{background:#f0d6bb}.bg-warning-default{background:#cca45f}.bg-black{background:#000}.bg-dark{background:#888}.bg-medium{background:#e0e0e0}.bg-grey{background:#ededed}.bg-light{background:#f6f6f6}.bg-white{background:#fff}.bg-box-shadow{background:#00000014}.bg-navigation-subtitle{background:#528593}.bgc-teal-60b{background-color:#1c443c}.bgc-teal-30b{background-color:#31766a}.bgc-teal-default{background-color:#46a997}.bgc-teal-30w{background-color:#7ec3b6}.bgc-teal-60w{background-color:#b5ddd5}.bgc-teal-secondary{background-color:#cbd6cb}.bgc-teal-90w{background-color:#ecf6f5}.bgc-petrol-60b{background-color:#102930}.bgc-petrol-30b{background-color:#1b4754}.bgc-petrol-default{background-color:#276678}.bgc-petrol-30w{background-color:#6894a0}.bgc-petrol-60w{background-color:#a9c2c9}.bgc-petrol-secondary{background-color:#c8d7de}.bgc-petrol-90w{background-color:#e9f0f1}.bgc-error-60b{background-color:#513131}.bgc-error-30b{background-color:#8e5655}.bgc-error-60w{background-color:#e3c3c6}.bgc-error-secondary{background-color:#f0dad9}.bgc-error-default{background-color:#cb7b7a}.bgc-warning-secondary{background-color:#f0d6bb}.bgc-warning-default{background-color:#cca45f}.bgc-black{background-color:#000}.bgc-dark{background-color:#888}.bgc-medium{background-color:#e0e0e0}.bgc-grey{background-color:#ededed}.bgc-light{background-color:#f6f6f6}.bgc-white{background-color:#fff}.bgc-box-shadow{background-color:#00000014}.bgc-navigation-subtitle{background-color:#528593}.ai-feedback,.ai-feedback-buttons{display:flex;flex-flow:row nowrap;align-items:center}.ai-feedback>span{color:#666;margin-right:16px}.ai-feedback-buttons{justify-content:center}.ai-feedback-buttons>ui-button:first-child{margin-right:8px}\n"] }]
27
+ args: [{ selector: 'ui-ai-feedback', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"ai-feedback\" [attr.aria-label]=\"'AI_FEEDBACK.TITLE' | uiTranslate\">\r\n <span>{{ 'AI_FEEDBACK.TITLE' | uiTranslate | async}}</span>\r\n <div class=\"ai-feedback-buttons\">\r\n @if(selected() !== optionNo) {\r\n <ui-button\r\n [justIcon]=\"true\"\r\n [iconName]=\"'Thumb-up-in-line'\"\r\n [size]=\"'small'\"\r\n [tooltipPosition]=\"tooltipPosition\"\r\n [tooltip]=\"('COMMON.YES' | uiTranslate | async)!\"\r\n [ariaLabel]=\"('COMMON.YES' | uiTranslate | async)!\"\r\n [iconFilled]=\"selected() === optionYes\"\r\n (buttonClickEvent)=\"onSelectionChange(optionYes)\"\r\n variant=\"icon-button\"\r\n role=\"button\"\r\n ></ui-button>\r\n }\r\n\r\n @if(selected() !== optionYes) {\r\n <ui-button\r\n [justIcon]=\"true\"\r\n [iconName]=\"'Thumb-down-in-line'\"\r\n [iconFilled]=\"selected() === optionNo\"\r\n [tooltip]=\"('COMMON.NO' | uiTranslate | async)!\"\r\n [ariaLabel]=\"('COMMON.NO' | uiTranslate | async)!\"\r\n [size]=\"'small'\"\r\n (buttonClickEvent)=\"onSelectionChange(optionNo)\"\r\n variant=\"icon-button\"\r\n role=\"button\"\r\n ></ui-button>\r\n }\r\n </div>\r\n</div>\r\n", styles: [".bg-teal-60b{background:#1c443c}.bg-teal-30b{background:#31766a}.bg-teal-default{background:#46a997}.bg-teal-30w{background:#7ec3b6}.bg-teal-60w{background:#b5ddd5}.bg-teal-secondary{background:#cbd6cb}.bg-teal-90w{background:#ecf6f5}.bg-petrol-60b{background:#102930}.bg-petrol-30b{background:#1b4754}.bg-petrol-default{background:#276678}.bg-petrol-30w{background:#6894a0}.bg-petrol-60w{background:#a9c2c9}.bg-petrol-secondary{background:#c8d7de}.bg-petrol-90w{background:#e9f0f1}.bg-error-60b{background:#513131}.bg-error-30b{background:#8e5655}.bg-error-60w{background:#e3c3c6}.bg-error-secondary{background:#f0dad9}.bg-error-default{background:#cb7b7a}.bg-warning-secondary{background:#f0d6bb}.bg-warning-default{background:#cca45f}.bg-black{background:#000}.bg-dark{background:#888}.bg-medium{background:#e0e0e0}.bg-grey{background:#ededed}.bg-light{background:#f6f6f6}.bg-white{background:#fff}.bg-box-shadow{background:#00000014}.bg-navigation-subtitle{background:#528593}.bgc-teal-60b{background-color:#1c443c}.bgc-teal-30b{background-color:#31766a}.bgc-teal-default{background-color:#46a997}.bgc-teal-30w{background-color:#7ec3b6}.bgc-teal-60w{background-color:#b5ddd5}.bgc-teal-secondary{background-color:#cbd6cb}.bgc-teal-90w{background-color:#ecf6f5}.bgc-petrol-60b{background-color:#102930}.bgc-petrol-30b{background-color:#1b4754}.bgc-petrol-default{background-color:#276678}.bgc-petrol-30w{background-color:#6894a0}.bgc-petrol-60w{background-color:#a9c2c9}.bgc-petrol-secondary{background-color:#c8d7de}.bgc-petrol-90w{background-color:#e9f0f1}.bgc-error-60b{background-color:#513131}.bgc-error-30b{background-color:#8e5655}.bgc-error-60w{background-color:#e3c3c6}.bgc-error-secondary{background-color:#f0dad9}.bgc-error-default{background-color:#cb7b7a}.bgc-warning-secondary{background-color:#f0d6bb}.bgc-warning-default{background-color:#cca45f}.bgc-black{background-color:#000}.bgc-dark{background-color:#888}.bgc-medium{background-color:#e0e0e0}.bgc-grey{background-color:#ededed}.bgc-light{background-color:#f6f6f6}.bgc-white{background-color:#fff}.bgc-box-shadow{background-color:#00000014}.bgc-navigation-subtitle{background-color:#528593}.ai-feedback,.ai-feedback-buttons{display:flex;flex-flow:row nowrap;align-items:center}.ai-feedback>span{color:#666;margin-right:16px}.ai-feedback-buttons{justify-content:center}.ai-feedback-buttons>ui-button:first-child{margin-right:8px}\n"] }]
28
28
  }], propDecorators: { selection: [{
29
29
  type: Input
30
30
  }], tooltipPosition: [{
@@ -32,4 +32,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
32
32
  }], selectedValue: [{
33
33
  type: Output
34
34
  }] } });
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWktZmVlZGJhY2suY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGdvLWNhbm9weS11aS9jb21wb25lbnRzL2FpLWZlZWRiYWNrL2FpLWZlZWRiYWNrLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rnby1jYW5vcHktdWkvY29tcG9uZW50cy9haS1mZWVkYmFjay9haS1mZWVkYmFjay5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFVeEcsTUFBTSxPQUFPLG1CQUFtQjtJQU5oQztRQVdXLG9CQUFlLEdBQW9CLE9BQU8sQ0FBQztRQUUxQyxrQkFBYSxHQUFzQyxJQUFJLFlBQVksRUFBdUIsQ0FBQztRQUVyRyxhQUFRLEdBQUcsTUFBTSxDQUFzQixJQUFJLENBQUMsQ0FBQztRQUNwQyxjQUFTLEdBQXdCLEtBQUssQ0FBQztRQUN2QyxhQUFRLEdBQXdCLElBQUksQ0FBQztLQVEvQztJQWxCQyxJQUFhLFNBQVMsQ0FBQyxTQUE4QjtRQUNuRCxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQVVELGlCQUFpQixDQUFDLFNBQThCO1FBQzlDLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLEVBQUUsS0FBSyxTQUFTLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO1FBQ2xFLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRTVCLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO0lBQzNDLENBQUM7K0dBbEJVLG1CQUFtQjttR0FBbkIsbUJBQW1CLDJLQ1ZoQyx3ckNBaUNBOzs0RkR2QmEsbUJBQW1CO2tCQU4vQixTQUFTOytCQUNFLGdCQUFnQixtQkFHVCx1QkFBdUIsQ0FBQyxNQUFNOzhCQUdsQyxTQUFTO3NCQUFyQixLQUFLO2dCQUlHLGVBQWU7c0JBQXZCLEtBQUs7Z0JBRUksYUFBYTtzQkFBdEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCwgc2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBaUZlZWRiYWNrU2VsZWN0aW9uIH0gZnJvbSAnLi9haS1mZWVkYmFjay5tb2RlbCc7XG5pbXBvcnQgeyBUb29sdGlwUG9zaXRpb24gfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndWktYWktZmVlZGJhY2snLFxuICB0ZW1wbGF0ZVVybDogJy4vYWktZmVlZGJhY2suY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vYWktZmVlZGJhY2suY29tcG9uZW50LnNjc3MnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgQWlGZWVkYmFja0NvbXBvbmVudCB7XG4gIEBJbnB1dCgpIHNldCBzZWxlY3Rpb24oc2VsZWN0aW9uOiBBaUZlZWRiYWNrU2VsZWN0aW9uKSB7XG4gICAgdGhpcy5zZWxlY3RlZC5zZXQoc2VsZWN0aW9uIHx8IG51bGwpO1xuICB9XG5cbiAgQElucHV0KCkgdG9vbHRpcFBvc2l0aW9uOiBUb29sdGlwUG9zaXRpb24gPSAnYWJvdmUnO1xuXG4gIEBPdXRwdXQoKSBzZWxlY3RlZFZhbHVlOiBFdmVudEVtaXR0ZXI8QWlGZWVkYmFja1NlbGVjdGlvbj4gPSBuZXcgRXZlbnRFbWl0dGVyPEFpRmVlZGJhY2tTZWxlY3Rpb24+KCk7XG5cbiAgc2VsZWN0ZWQgPSBzaWduYWw8QWlGZWVkYmFja1NlbGVjdGlvbj4obnVsbCk7XG4gIHJlYWRvbmx5IG9wdGlvblllczogQWlGZWVkYmFja1NlbGVjdGlvbiA9ICd5ZXMnO1xuICByZWFkb25seSBvcHRpb25ObzogQWlGZWVkYmFja1NlbGVjdGlvbiA9ICdubyc7XG5cbiAgb25TZWxlY3Rpb25DaGFuZ2Uoc2VsZWN0aW9uOiBBaUZlZWRiYWNrU2VsZWN0aW9uKTogdm9pZCB7XG4gICAgY29uc3QgbmV3VmFsdWUgPSB0aGlzLnNlbGVjdGVkKCkgPT09IHNlbGVjdGlvbiA/IG51bGwgOiBzZWxlY3Rpb247XG4gICAgdGhpcy5zZWxlY3RlZC5zZXQobmV3VmFsdWUpO1xuXG4gICAgdGhpcy5zZWxlY3RlZFZhbHVlLmVtaXQodGhpcy5zZWxlY3RlZCgpKTtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImFpLWZlZWRiYWNrXCIgW2F0dHIuYXJpYS1sYWJlbF09XCInQUlfRkVFREJBQ0suVElUTEUnIHwgdWlUcmFuc2xhdGVcIj5cbiAgPHNwYW4+e3sgJ0FJX0ZFRURCQUNLLlRJVExFJyB8IHVpVHJhbnNsYXRlIHwgYXN5bmN9fTwvc3Bhbj5cbiAgPGRpdiBjbGFzcz1cImFpLWZlZWRiYWNrLWJ1dHRvbnNcIj5cbiAgICBAaWYoc2VsZWN0ZWQoKSAhPT0gb3B0aW9uTm8pIHtcbiAgICAgIDx1aS1idXR0b25cbiAgICAgICAgW2p1c3RJY29uXT1cInRydWVcIlxuICAgICAgICBbaWNvbk5hbWVdPVwiJ1RodW1iLXVwLWluLWxpbmUnXCJcbiAgICAgICAgW3NpemVdPVwiJ3NtYWxsJ1wiXG4gICAgICAgIFt0b29sdGlwUG9zaXRpb25dPVwidG9vbHRpcFBvc2l0aW9uXCJcbiAgICAgICAgW3Rvb2x0aXBdPVwiKCdDT01NT04uWUVTJyB8IHVpVHJhbnNsYXRlIHwgYXN5bmMpIVwiXG4gICAgICAgIFthcmlhTGFiZWxdPVwiKCdDT01NT04uWUVTJyB8IHVpVHJhbnNsYXRlIHwgYXN5bmMpIVwiXG4gICAgICAgIFtpY29uRmlsbGVkXT1cInNlbGVjdGVkKCkgPT09IG9wdGlvblllc1wiXG4gICAgICAgIChidXR0b25DbGlja0V2ZW50KT1cIm9uU2VsZWN0aW9uQ2hhbmdlKG9wdGlvblllcylcIlxuICAgICAgICB2YXJpYW50PVwiaWNvbi1idXR0b25cIlxuICAgICAgICByb2xlPVwiYnV0dG9uXCJcbiAgICAgID48L3VpLWJ1dHRvbj5cbiAgICB9XG5cbiAgICBAaWYoc2VsZWN0ZWQoKSAhPT0gb3B0aW9uWWVzKSB7XG4gICAgICA8dWktYnV0dG9uXG4gICAgICAgIFtqdXN0SWNvbl09XCJ0cnVlXCJcbiAgICAgICAgW2ljb25OYW1lXT1cIidUaHVtYi1kb3duLWluLWxpbmUnXCJcbiAgICAgICAgW2ljb25GaWxsZWRdPVwic2VsZWN0ZWQoKSA9PT0gb3B0aW9uTm9cIlxuICAgICAgICBbdG9vbHRpcF09XCIoJ0NPTU1PTi5OTycgfCB1aVRyYW5zbGF0ZSB8IGFzeW5jKSFcIlxuICAgICAgICBbYXJpYUxhYmVsXT1cIignQ09NTU9OLk5PJyB8IHVpVHJhbnNsYXRlIHwgYXN5bmMpIVwiXG4gICAgICAgIFtzaXplXT1cIidzbWFsbCdcIlxuICAgICAgICAoYnV0dG9uQ2xpY2tFdmVudCk9XCJvblNlbGVjdGlvbkNoYW5nZShvcHRpb25ObylcIlxuICAgICAgICB2YXJpYW50PVwiaWNvbi1idXR0b25cIlxuICAgICAgICByb2xlPVwiYnV0dG9uXCJcbiAgICAgID48L3VpLWJ1dHRvbj5cbiAgICAgfVxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWktZmVlZGJhY2suY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGdvLWNhbm9weS11aS9jb21wb25lbnRzL2FpLWZlZWRiYWNrL2FpLWZlZWRiYWNrLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rnby1jYW5vcHktdWkvY29tcG9uZW50cy9haS1mZWVkYmFjay9haS1mZWVkYmFjay5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFVeEcsTUFBTSxPQUFPLG1CQUFtQjtJQU5oQztRQVdXLG9CQUFlLEdBQW9CLE9BQU8sQ0FBQztRQUUxQyxrQkFBYSxHQUFzQyxJQUFJLFlBQVksRUFBdUIsQ0FBQztRQUVyRyxhQUFRLEdBQUcsTUFBTSxDQUFzQixJQUFJLENBQUMsQ0FBQztRQUNwQyxjQUFTLEdBQXdCLEtBQUssQ0FBQztRQUN2QyxhQUFRLEdBQXdCLElBQUksQ0FBQztLQVEvQztJQWxCQyxJQUFhLFNBQVMsQ0FBQyxTQUE4QjtRQUNuRCxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQVVELGlCQUFpQixDQUFDLFNBQThCO1FBQzlDLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLEVBQUUsS0FBSyxTQUFTLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO1FBQ2xFLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRTVCLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO0lBQzNDLENBQUM7K0dBbEJVLG1CQUFtQjttR0FBbkIsbUJBQW1CLDJLQ1ZoQywwdkNBaUNBOzs0RkR2QmEsbUJBQW1CO2tCQU4vQixTQUFTOytCQUNFLGdCQUFnQixtQkFHVCx1QkFBdUIsQ0FBQyxNQUFNOzhCQUdsQyxTQUFTO3NCQUFyQixLQUFLO2dCQUlHLGVBQWU7c0JBQXZCLEtBQUs7Z0JBRUksYUFBYTtzQkFBdEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCwgc2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFpRmVlZGJhY2tTZWxlY3Rpb24gfSBmcm9tICcuL2FpLWZlZWRiYWNrLm1vZGVsJztcclxuaW1wb3J0IHsgVG9vbHRpcFBvc2l0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbHRpcCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3VpLWFpLWZlZWRiYWNrJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vYWktZmVlZGJhY2suY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsOiAnLi9haS1mZWVkYmFjay5jb21wb25lbnQuc2NzcycsXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBaUZlZWRiYWNrQ29tcG9uZW50IHtcclxuICBASW5wdXQoKSBzZXQgc2VsZWN0aW9uKHNlbGVjdGlvbjogQWlGZWVkYmFja1NlbGVjdGlvbikge1xyXG4gICAgdGhpcy5zZWxlY3RlZC5zZXQoc2VsZWN0aW9uIHx8IG51bGwpO1xyXG4gIH1cclxuXHJcbiAgQElucHV0KCkgdG9vbHRpcFBvc2l0aW9uOiBUb29sdGlwUG9zaXRpb24gPSAnYWJvdmUnO1xyXG5cclxuICBAT3V0cHV0KCkgc2VsZWN0ZWRWYWx1ZTogRXZlbnRFbWl0dGVyPEFpRmVlZGJhY2tTZWxlY3Rpb24+ID0gbmV3IEV2ZW50RW1pdHRlcjxBaUZlZWRiYWNrU2VsZWN0aW9uPigpO1xyXG5cclxuICBzZWxlY3RlZCA9IHNpZ25hbDxBaUZlZWRiYWNrU2VsZWN0aW9uPihudWxsKTtcclxuICByZWFkb25seSBvcHRpb25ZZXM6IEFpRmVlZGJhY2tTZWxlY3Rpb24gPSAneWVzJztcclxuICByZWFkb25seSBvcHRpb25ObzogQWlGZWVkYmFja1NlbGVjdGlvbiA9ICdubyc7XHJcblxyXG4gIG9uU2VsZWN0aW9uQ2hhbmdlKHNlbGVjdGlvbjogQWlGZWVkYmFja1NlbGVjdGlvbik6IHZvaWQge1xyXG4gICAgY29uc3QgbmV3VmFsdWUgPSB0aGlzLnNlbGVjdGVkKCkgPT09IHNlbGVjdGlvbiA/IG51bGwgOiBzZWxlY3Rpb247XHJcbiAgICB0aGlzLnNlbGVjdGVkLnNldChuZXdWYWx1ZSk7XHJcblxyXG4gICAgdGhpcy5zZWxlY3RlZFZhbHVlLmVtaXQodGhpcy5zZWxlY3RlZCgpKTtcclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImFpLWZlZWRiYWNrXCIgW2F0dHIuYXJpYS1sYWJlbF09XCInQUlfRkVFREJBQ0suVElUTEUnIHwgdWlUcmFuc2xhdGVcIj5cclxuICA8c3Bhbj57eyAnQUlfRkVFREJBQ0suVElUTEUnIHwgdWlUcmFuc2xhdGUgfCBhc3luY319PC9zcGFuPlxyXG4gIDxkaXYgY2xhc3M9XCJhaS1mZWVkYmFjay1idXR0b25zXCI+XHJcbiAgICBAaWYoc2VsZWN0ZWQoKSAhPT0gb3B0aW9uTm8pIHtcclxuICAgICAgPHVpLWJ1dHRvblxyXG4gICAgICAgIFtqdXN0SWNvbl09XCJ0cnVlXCJcclxuICAgICAgICBbaWNvbk5hbWVdPVwiJ1RodW1iLXVwLWluLWxpbmUnXCJcclxuICAgICAgICBbc2l6ZV09XCInc21hbGwnXCJcclxuICAgICAgICBbdG9vbHRpcFBvc2l0aW9uXT1cInRvb2x0aXBQb3NpdGlvblwiXHJcbiAgICAgICAgW3Rvb2x0aXBdPVwiKCdDT01NT04uWUVTJyB8IHVpVHJhbnNsYXRlIHwgYXN5bmMpIVwiXHJcbiAgICAgICAgW2FyaWFMYWJlbF09XCIoJ0NPTU1PTi5ZRVMnIHwgdWlUcmFuc2xhdGUgfCBhc3luYykhXCJcclxuICAgICAgICBbaWNvbkZpbGxlZF09XCJzZWxlY3RlZCgpID09PSBvcHRpb25ZZXNcIlxyXG4gICAgICAgIChidXR0b25DbGlja0V2ZW50KT1cIm9uU2VsZWN0aW9uQ2hhbmdlKG9wdGlvblllcylcIlxyXG4gICAgICAgIHZhcmlhbnQ9XCJpY29uLWJ1dHRvblwiXHJcbiAgICAgICAgcm9sZT1cImJ1dHRvblwiXHJcbiAgICAgID48L3VpLWJ1dHRvbj5cclxuICAgIH1cclxuXHJcbiAgICBAaWYoc2VsZWN0ZWQoKSAhPT0gb3B0aW9uWWVzKSB7XHJcbiAgICAgIDx1aS1idXR0b25cclxuICAgICAgICBbanVzdEljb25dPVwidHJ1ZVwiXHJcbiAgICAgICAgW2ljb25OYW1lXT1cIidUaHVtYi1kb3duLWluLWxpbmUnXCJcclxuICAgICAgICBbaWNvbkZpbGxlZF09XCJzZWxlY3RlZCgpID09PSBvcHRpb25Ob1wiXHJcbiAgICAgICAgW3Rvb2x0aXBdPVwiKCdDT01NT04uTk8nIHwgdWlUcmFuc2xhdGUgfCBhc3luYykhXCJcclxuICAgICAgICBbYXJpYUxhYmVsXT1cIignQ09NTU9OLk5PJyB8IHVpVHJhbnNsYXRlIHwgYXN5bmMpIVwiXHJcbiAgICAgICAgW3NpemVdPVwiJ3NtYWxsJ1wiXHJcbiAgICAgICAgKGJ1dHRvbkNsaWNrRXZlbnQpPVwib25TZWxlY3Rpb25DaGFuZ2Uob3B0aW9uTm8pXCJcclxuICAgICAgICB2YXJpYW50PVwiaWNvbi1idXR0b25cIlxyXG4gICAgICAgIHJvbGU9XCJidXR0b25cIlxyXG4gICAgICA+PC91aS1idXR0b24+XHJcbiAgICAgfVxyXG4gIDwvZGl2PlxyXG48L2Rpdj5cclxuIl19
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWktZmVlZGJhY2subW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90Z28tY2Fub3B5LXVpL2NvbXBvbmVudHMvYWktZmVlZGJhY2svYWktZmVlZGJhY2subW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIEFpRmVlZGJhY2tTZWxlY3Rpb24gPSAneWVzJyB8ICdubycgfCBudWxsO1xuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWktZmVlZGJhY2subW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90Z28tY2Fub3B5LXVpL2NvbXBvbmVudHMvYWktZmVlZGJhY2svYWktZmVlZGJhY2subW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIEFpRmVlZGJhY2tTZWxlY3Rpb24gPSAneWVzJyB8ICdubycgfCBudWxsO1xyXG4iXX0=
@@ -17,4 +17,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
17
17
  exports: [AiFeedbackComponent],
18
18
  }]
19
19
  }] });
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWktZmVlZGJhY2subW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGdvLWNhbm9weS11aS9jb21wb25lbnRzL2FpLWZlZWRiYWNrL2FpLWZlZWRiYWNrLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzlELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNoRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUMxRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0saUJBQWlCLENBQUM7O0FBTzVDLE1BQU0sT0FBTyxnQkFBZ0I7K0dBQWhCLGdCQUFnQjtnSEFBaEIsZ0JBQWdCLGlCQUpaLG1CQUFtQixhQUN4QixxQkFBcUIsRUFBRSxlQUFlLEVBQUUsU0FBUyxhQUNqRCxtQkFBbUI7Z0hBRWxCLGdCQUFnQixZQUhqQixxQkFBcUI7OzRGQUdwQixnQkFBZ0I7a0JBTDVCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsbUJBQW1CLENBQUM7b0JBQ25DLE9BQU8sRUFBRSxDQUFDLHFCQUFxQixFQUFFLGVBQWUsRUFBRSxTQUFTLENBQUM7b0JBQzVELE9BQU8sRUFBRSxDQUFDLG1CQUFtQixDQUFDO2lCQUMvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBaUZlZWRiYWNrQ29tcG9uZW50IH0gZnJvbSAnLi9haS1mZWVkYmFjay5jb21wb25lbnQnO1xuaW1wb3J0IHsgVWlUcmFuc2xhdGVQaXBlIH0gZnJvbSAnLi4vLi4vcGlwZXMvdWktdHJhbnNsYXRlLnBpcGUnO1xuaW1wb3J0IHsgQnV0dG9uQ29tcG9uZW50TW9kdWxlIH0gZnJvbSAnLi4vYnV0dG9uL2J1dHRvbi5jb21wb25lbnQubW9kdWxlJztcbmltcG9ydCB7IEFzeW5jUGlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW0FpRmVlZGJhY2tDb21wb25lbnRdLFxuICBpbXBvcnRzOiBbQnV0dG9uQ29tcG9uZW50TW9kdWxlLCBVaVRyYW5zbGF0ZVBpcGUsIEFzeW5jUGlwZV0sXG4gIGV4cG9ydHM6IFtBaUZlZWRiYWNrQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgQWlGZWVkYmFja01vZHVsZSB7fVxuIl19
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWktZmVlZGJhY2subW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGdvLWNhbm9weS11aS9jb21wb25lbnRzL2FpLWZlZWRiYWNrL2FpLWZlZWRiYWNrLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzlELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNoRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUMxRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0saUJBQWlCLENBQUM7O0FBTzVDLE1BQU0sT0FBTyxnQkFBZ0I7K0dBQWhCLGdCQUFnQjtnSEFBaEIsZ0JBQWdCLGlCQUpaLG1CQUFtQixhQUN4QixxQkFBcUIsRUFBRSxlQUFlLEVBQUUsU0FBUyxhQUNqRCxtQkFBbUI7Z0hBRWxCLGdCQUFnQixZQUhqQixxQkFBcUI7OzRGQUdwQixnQkFBZ0I7a0JBTDVCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsbUJBQW1CLENBQUM7b0JBQ25DLE9BQU8sRUFBRSxDQUFDLHFCQUFxQixFQUFFLGVBQWUsRUFBRSxTQUFTLENBQUM7b0JBQzVELE9BQU8sRUFBRSxDQUFDLG1CQUFtQixDQUFDO2lCQUMvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFpRmVlZGJhY2tDb21wb25lbnQgfSBmcm9tICcuL2FpLWZlZWRiYWNrLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFVpVHJhbnNsYXRlUGlwZSB9IGZyb20gJy4uLy4uL3BpcGVzL3VpLXRyYW5zbGF0ZS5waXBlJztcclxuaW1wb3J0IHsgQnV0dG9uQ29tcG9uZW50TW9kdWxlIH0gZnJvbSAnLi4vYnV0dG9uL2J1dHRvbi5jb21wb25lbnQubW9kdWxlJztcclxuaW1wb3J0IHsgQXN5bmNQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbQWlGZWVkYmFja0NvbXBvbmVudF0sXHJcbiAgaW1wb3J0czogW0J1dHRvbkNvbXBvbmVudE1vZHVsZSwgVWlUcmFuc2xhdGVQaXBlLCBBc3luY1BpcGVdLFxyXG4gIGV4cG9ydHM6IFtBaUZlZWRiYWNrQ29tcG9uZW50XSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEFpRmVlZGJhY2tNb2R1bGUge31cclxuIl19
@@ -195,4 +195,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
195
195
  type: HostBinding,
196
196
  args: ['class.display-none']
197
197
  }] } });
198
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alert-banner.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/alert-banner/alert-banner.component.ts","../../../../../projects/tgo-canopy-ui/components/alert-banner/alert-banner.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, style, transition, trigger } from '@angular/animations';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  HostBinding,\n  Inject,\n  Input,\n  OnChanges,\n  OnInit,\n  Optional,\n  SimpleChanges,\n} from '@angular/core';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { IconName } from '../../components/icon/icon.model';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { AlertBarType, AlertVariant } from '../../utils/alert-bar.model';\nimport { alertBarsUtil } from '../../utils/alert-bars.utils';\nimport { LinkTargetType } from './alert-banner.model';\n\n@Component({\n  selector: 'ui-alert-banner',\n  templateUrl: './alert-banner.component.html',\n  styleUrls: ['./alert-banner.component.scss'],\n  animations: [\n    trigger('openClose', [\n      transition(':enter', [animate('0.2s ease-out', style({ opacity: 1 }))]),\n      transition(':leave', [animate('0.2s ease-in', style({ opacity: 0 }))]),\n    ]),\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AlertBannerComponent implements OnInit, OnChanges {\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private domSanitizer: DomSanitizer\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  /**\n   * Alert Banner type\n   *\n   * @type {AlertBarType}\n   * @default 'success'\n   * @memberof AlertBannerComponent\n   */\n  @Input() alertType: AlertBarType = 'success';\n\n  /**\n   * Alert Banner variant\n   *\n   * @type {AlertVariant}\n   * @default 'banner'\n   * @memberof AlertBannerComponent\n   */\n  @Input() alertVariant: AlertVariant = 'banner';\n\n  /**\n   * Alert banner message\n   *\n   * @memberof AlertBannerComponent\n   */\n  @Input() set message(msg: string) {\n    this._message = this.domSanitizer.bypassSecurityTrustHtml(msg);\n  }\n\n  /**\n   * Include dismmiss button\n   *\n   * @default true\n   * @memberof AlertBannerComponent\n   */\n  @Input() includeDismissButton = true;\n\n  /**\n   * Include shadow or not\n   *\n   * @default false\n   * @memberof AlertBannerComponent\n   */\n  @Input() shadow = false;\n\n  /**\n   * Link text that will appended at the end of message\n   *\n   * @default ''\n   * @memberof AlertBannerComponent\n   */\n  @Input() linkText? = '';\n\n  /**\n   * Link url\n   *\n   * @memberof AlertBannerComponent\n   */\n  @Input() linkUrl?: string;\n\n  /**\n   * Link target\n   *\n   * @type {@type {LinkTargetType}}\n   * @default '_blank'\n   * @memberof AlertBannerComponent\n   */\n  @Input() linkTarget?: LinkTargetType = '_blank';\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @default 'light'\n   * @memberof AlertBannerComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Sets the full width\n   *\n   * @type {boolean}\n   * @memberof AlertBannerComponent\n   */\n  @Input() isFullWidth: boolean | undefined;\n\n  /**\n   * Close button tooltip\n   *\n   * @type {string}\n   * @default ''\n   * @memberof AlertBannerComponent\n   */\n  @Input() closeButtonTooltip = '';\n\n  /**\n   * Shows icon\n   *\n   * @type {boolean}\n   * @default true\n   * @memberof AlertBannerComponent\n   */\n  @Input() hasIcon = true;\n\n  /**\n   * Sets the alert banner position\n   *\n   * @type {boolean}\n   * @default false\n   * @memberof AlertBannerComponent\n   */\n  @Input() fixed = false;\n\n  /**\n   * A string representing the ARIA requirement for accessibility.\n   * This attribute is used to indicate whether an input field is required for form submission.\n   * @type {string}\n   * @memberof AlertBannerComponent\n   */\n  @Input() ariaDescribedby = '';\n\n  @Input() set secondaryAlerts(alerts: string[]) {\n    this._secondaryAlerts = alerts.map(alert => this.domSanitizer.bypassSecurityTrustHtml(alert));\n  }\n\n  @HostBinding('class.display-none') get isDismissed() {\n    return this.dismissAlertBanner;\n  }\n\n  iconName: IconName;\n  visible = true;\n  fullWidth: boolean;\n  position: string;\n  cssClass: string;\n  _message: SafeHtml = '';\n  _secondaryAlerts: SafeHtml[] = [];\n  dismissAlertBanner = false;\n\n  ngOnInit(): void {\n    this.updateBanner();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    // eslint-disable-next-line dot-notation\n    if (changes['alertType']) {\n     this.updateBanner();\n    }\n  }\n\n  private updateBanner(): void {\n    this.iconName = alertBarsUtil.setIcon(this.alertType);\n    this.position = alertBarsUtil.setPosition(this.fixed);\n    this.fullWidth = this.isFullWidth ?? this.alertVariant === 'banner';\n    this.cssClass = alertBarsUtil.setCssClass(this.fullWidth, this.alertType, this.position, this.alertVariant);\n  }\n\n  //Hide snackbar when dismiss button is clicked\n  dismissClick() {\n    this.visible = false;\n    setTimeout(() => {\n      this.dismissAlertBanner = true;\n    }, 200);\n  }\n}\n","<div\n  [ngClass]=\"cssClass\"\n  [@openClose]\n  *ngIf=\"visible\"\n  role=\"alert\"\n  class=\"alert-container\"\n  [attr.theme]=\"applicationTheme\"\n  [class.shadow]=\"alertVariant === 'callout' && shadow\"\n  [attr.aria-live]=\"(alertType === 'error' || alertType === 'warning') ? 'assertive' : 'polite'\"\n  [attr.aria-describedby]=\"'describedby'\"\n  [attr.aria-labelledby]=\"'labelledby'\"\n  [tabIndex]=\"0\"\n>\n  <span style=\"position: absolute; left: -9999px\" id=\"labelledby\">{{ ('ALERT_BANNER.' + (alertType | uppercase)) | uiTranslate | async }}</span>\n  <span [style.display]=\"'none'\" id=\"describedby\">{{ ariaDescribedby }}</span>\n  <div class=\"primary-alert-container\">\n    <div class=\"alert-text\">\n      @if (hasIcon) {\n        <ui-icon class=\"left-icon\" [name]=\"iconName\" size=\"24\" [applicationTheme]=\"applicationTheme\"></ui-icon>\n      }\n      <span [innerHTML]=\"_message\"></span>\n      <a *ngIf=\"!!linkText\" [target]=\"linkTarget\" [href]=\"linkUrl\">{{ linkText }}</a>\n    </div>\n    <ui-button\n      *ngIf=\"includeDismissButton && applicationTheme === 'classic'\"\n      variant=\"text\"\n      [justIcon]=\"true\"\n      class=\"close\"\n      iconName=\"Close\"\n      (buttonClickEvent)=\"dismissClick()\"\n    ></ui-button>\n    <ui-button\n      *ngIf=\"includeDismissButton && applicationTheme !== 'classic' && alertVariant !== 'callout'\"\n      class=\"right-icon\"\n      [variant]=\"'icon-button'\"\n      [applicationTheme]=\"applicationTheme\"\n      [iconName]=\"'Close'\"\n      [size]=\"'small'\"\n      [justIcon]=\"true\"\n      [tooltip]=\"(closeButtonTooltip || ('COMMON.CLOSE' | uiTranslate | async))!\"\n      (click)=\"dismissClick()\"\n    ></ui-button>\n  </div>\n  <div class=\"secondary-alerts-container\">\n    <div class=\"alert-text\" *ngFor=\"let alert of _secondaryAlerts\">\n      <ui-icon class=\"left-icon\" [name]=\"'Stop-filled'\" [applicationTheme]=\"applicationTheme\"></ui-icon>\n      <span [innerHTML]=\"alert\"></span>\n    </div>\n  </div>\n</div>\n"]}
198
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alert-banner.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/alert-banner/alert-banner.component.ts","../../../../../projects/tgo-canopy-ui/components/alert-banner/alert-banner.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC1E,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,WAAW,EACX,MAAM,EACN,KAAK,EAGL,QAAQ,GAET,MAAM,eAAe,CAAC;AAKvB,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;;;;;;;AAe7D,MAAM,OAAO,oBAAoB;IAC/B,YAC6E,eAAiC,EACpG,YAA0B;QADyC,oBAAe,GAAf,eAAe,CAAkB;QACpG,iBAAY,GAAZ,YAAY,CAAc;QAOpC;;;;;;WAMG;QACM,cAAS,GAAiB,SAAS,CAAC;QAE7C;;;;;;WAMG;QACM,iBAAY,GAAiB,QAAQ,CAAC;QAW/C;;;;;WAKG;QACM,yBAAoB,GAAG,IAAI,CAAC;QAErC;;;;;WAKG;QACM,WAAM,GAAG,KAAK,CAAC;QAExB;;;;;WAKG;QACM,aAAQ,GAAI,EAAE,CAAC;QASxB;;;;;;WAMG;QACM,eAAU,GAAoB,QAAQ,CAAC;QAEhD;;;;;;;WAOG;QACM,qBAAgB,GAAqB,OAAO,CAAC;QAUtD;;;;;;WAMG;QACM,uBAAkB,GAAG,EAAE,CAAC;QAEjC;;;;;;WAMG;QACM,YAAO,GAAG,IAAI,CAAC;QAExB;;;;;;WAMG;QACM,UAAK,GAAG,KAAK,CAAC;QAEvB;;;;;WAKG;QACM,oBAAe,GAAG,EAAE,CAAC;QAW9B,YAAO,GAAG,IAAI,CAAC;QAIf,aAAQ,GAAa,EAAE,CAAC;QACxB,qBAAgB,GAAe,EAAE,CAAC;QAClC,uBAAkB,GAAG,KAAK,CAAC;QA5IzB,IAAI,eAAe,EAAE,CAAC;YACpB,IAAI,CAAC,gBAAgB,GAAG,eAAe,CAAC;QAC1C,CAAC;IACH,CAAC;IAoBD;;;;OAIG;IACH,IAAa,OAAO,CAAC,GAAW;QAC9B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,uBAAuB,CAAC,GAAG,CAAC,CAAC;IACjE,CAAC;IA+FD,IAAa,eAAe,CAAC,MAAgB;QAC3C,IAAI,CAAC,gBAAgB,GAAG,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC,CAAC;IAChG,CAAC;IAED,IAAuC,WAAW;QAChD,OAAO,IAAI,CAAC,kBAAkB,CAAC;IACjC,CAAC;IAWD,QAAQ;QACN,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,wCAAwC;QACxC,IAAI,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC;YAC1B,IAAI,CAAC,YAAY,EAAE,CAAC;QACrB,CAAC;IACH,CAAC;IAEO,YAAY;QAClB,IAAI,CAAC,QAAQ,GAAG,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACtD,IAAI,CAAC,QAAQ,GAAG,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACtD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,YAAY,KAAK,QAAQ,CAAC;QACpE,IAAI,CAAC,QAAQ,GAAG,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;IAC9G,CAAC;IAED,8CAA8C;IAC9C,YAAY;QACV,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QACjC,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;+GA3KU,oBAAoB,kBAET,oCAAoC;mGAF/C,oBAAoB,kkBC/BjC,qgEAkDA,u/OD3Bc;YACV,OAAO,CAAC,WAAW,EAAE;gBACnB,UAAU,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,eAAe,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;gBACvE,UAAU,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,cAAc,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;aACvE,CAAC;SACH;;4FAGU,oBAAoB;kBAZhC,SAAS;+BACE,iBAAiB,cAGf;wBACV,OAAO,CAAC,WAAW,EAAE;4BACnB,UAAU,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,eAAe,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;4BACvE,UAAU,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,cAAc,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;yBACvE,CAAC;qBACH,mBACgB,uBAAuB,CAAC,MAAM;;0BAI5C,QAAQ;;0BAAI,MAAM;2BAAC,oCAAoC;oEAejD,SAAS;sBAAjB,KAAK;gBASG,YAAY;sBAApB,KAAK;gBAOO,OAAO;sBAAnB,KAAK;gBAUG,oBAAoB;sBAA5B,KAAK;gBAQG,MAAM;sBAAd,KAAK;gBAQG,QAAQ;sBAAhB,KAAK;gBAOG,OAAO;sBAAf,KAAK;gBASG,UAAU;sBAAlB,KAAK;gBAUG,gBAAgB;sBAAxB,KAAK;gBAQG,WAAW;sBAAnB,KAAK;gBASG,kBAAkB;sBAA1B,KAAK;gBASG,OAAO;sBAAf,KAAK;gBASG,KAAK;sBAAb,KAAK;gBAQG,eAAe;sBAAvB,KAAK;gBAEO,eAAe;sBAA3B,KAAK;gBAIiC,WAAW;sBAAjD,WAAW;uBAAC,oBAAoB","sourcesContent":["import { animate, style, transition, trigger } from '@angular/animations';\r\nimport {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  HostBinding,\r\n  Inject,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Optional,\r\n  SimpleChanges,\r\n} from '@angular/core';\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\nimport { IconName } from '../../components/icon/icon.model';\r\nimport { ApplicationTheme } from '../../models/application-theme.model';\r\nimport { AlertBarType, AlertVariant } from '../../utils/alert-bar.model';\r\nimport { alertBarsUtil } from '../../utils/alert-bars.utils';\r\nimport { LinkTargetType } from './alert-banner.model';\r\n\r\n@Component({\r\n  selector: 'ui-alert-banner',\r\n  templateUrl: './alert-banner.component.html',\r\n  styleUrls: ['./alert-banner.component.scss'],\r\n  animations: [\r\n    trigger('openClose', [\r\n      transition(':enter', [animate('0.2s ease-out', style({ opacity: 1 }))]),\r\n      transition(':leave', [animate('0.2s ease-in', style({ opacity: 0 }))]),\r\n    ]),\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class AlertBannerComponent implements OnInit, OnChanges {\r\n  constructor(\r\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\r\n    private domSanitizer: DomSanitizer\r\n  ) {\r\n    if (defaultAppTheme) {\r\n      this.applicationTheme = defaultAppTheme;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Alert Banner type\r\n   *\r\n   * @type {AlertBarType}\r\n   * @default 'success'\r\n   * @memberof AlertBannerComponent\r\n   */\r\n  @Input() alertType: AlertBarType = 'success';\r\n\r\n  /**\r\n   * Alert Banner variant\r\n   *\r\n   * @type {AlertVariant}\r\n   * @default 'banner'\r\n   * @memberof AlertBannerComponent\r\n   */\r\n  @Input() alertVariant: AlertVariant = 'banner';\r\n\r\n  /**\r\n   * Alert banner message\r\n   *\r\n   * @memberof AlertBannerComponent\r\n   */\r\n  @Input() set message(msg: string) {\r\n    this._message = this.domSanitizer.bypassSecurityTrustHtml(msg);\r\n  }\r\n\r\n  /**\r\n   * Include dismmiss button\r\n   *\r\n   * @default true\r\n   * @memberof AlertBannerComponent\r\n   */\r\n  @Input() includeDismissButton = true;\r\n\r\n  /**\r\n   * Include shadow or not\r\n   *\r\n   * @default false\r\n   * @memberof AlertBannerComponent\r\n   */\r\n  @Input() shadow = false;\r\n\r\n  /**\r\n   * Link text that will appended at the end of message\r\n   *\r\n   * @default ''\r\n   * @memberof AlertBannerComponent\r\n   */\r\n  @Input() linkText? = '';\r\n\r\n  /**\r\n   * Link url\r\n   *\r\n   * @memberof AlertBannerComponent\r\n   */\r\n  @Input() linkUrl?: string;\r\n\r\n  /**\r\n   * Link target\r\n   *\r\n   * @type {@type {LinkTargetType}}\r\n   * @default '_blank'\r\n   * @memberof AlertBannerComponent\r\n   */\r\n  @Input() linkTarget?: LinkTargetType = '_blank';\r\n\r\n  /**\r\n   *\r\n   * Defines the application theme\r\n   *\r\n   * @type {ApplicationTheme}\r\n   * @default 'light'\r\n   * @memberof AlertBannerComponent\r\n   */\r\n  @Input() applicationTheme: ApplicationTheme = 'light';\r\n\r\n  /**\r\n   * Sets the full width\r\n   *\r\n   * @type {boolean}\r\n   * @memberof AlertBannerComponent\r\n   */\r\n  @Input() isFullWidth: boolean | undefined;\r\n\r\n  /**\r\n   * Close button tooltip\r\n   *\r\n   * @type {string}\r\n   * @default ''\r\n   * @memberof AlertBannerComponent\r\n   */\r\n  @Input() closeButtonTooltip = '';\r\n\r\n  /**\r\n   * Shows icon\r\n   *\r\n   * @type {boolean}\r\n   * @default true\r\n   * @memberof AlertBannerComponent\r\n   */\r\n  @Input() hasIcon = true;\r\n\r\n  /**\r\n   * Sets the alert banner position\r\n   *\r\n   * @type {boolean}\r\n   * @default false\r\n   * @memberof AlertBannerComponent\r\n   */\r\n  @Input() fixed = false;\r\n\r\n  /**\r\n   * A string representing the ARIA requirement for accessibility.\r\n   * This attribute is used to indicate whether an input field is required for form submission.\r\n   * @type {string}\r\n   * @memberof AlertBannerComponent\r\n   */\r\n  @Input() ariaDescribedby = '';\r\n\r\n  @Input() set secondaryAlerts(alerts: string[]) {\r\n    this._secondaryAlerts = alerts.map(alert => this.domSanitizer.bypassSecurityTrustHtml(alert));\r\n  }\r\n\r\n  @HostBinding('class.display-none') get isDismissed() {\r\n    return this.dismissAlertBanner;\r\n  }\r\n\r\n  iconName: IconName;\r\n  visible = true;\r\n  fullWidth: boolean;\r\n  position: string;\r\n  cssClass: string;\r\n  _message: SafeHtml = '';\r\n  _secondaryAlerts: SafeHtml[] = [];\r\n  dismissAlertBanner = false;\r\n\r\n  ngOnInit(): void {\r\n    this.updateBanner();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    // eslint-disable-next-line dot-notation\r\n    if (changes['alertType']) {\r\n     this.updateBanner();\r\n    }\r\n  }\r\n\r\n  private updateBanner(): void {\r\n    this.iconName = alertBarsUtil.setIcon(this.alertType);\r\n    this.position = alertBarsUtil.setPosition(this.fixed);\r\n    this.fullWidth = this.isFullWidth ?? this.alertVariant === 'banner';\r\n    this.cssClass = alertBarsUtil.setCssClass(this.fullWidth, this.alertType, this.position, this.alertVariant);\r\n  }\r\n\r\n  //Hide snackbar when dismiss button is clicked\r\n  dismissClick() {\r\n    this.visible = false;\r\n    setTimeout(() => {\r\n      this.dismissAlertBanner = true;\r\n    }, 200);\r\n  }\r\n}\r\n","<div\n  [ngClass]=\"cssClass\"\n  [@openClose]\n  *ngIf=\"visible\"\n  role=\"alert\"\n  class=\"alert-container\"\n  [attr.theme]=\"applicationTheme\"\n  [class.shadow]=\"alertVariant === 'callout' && shadow\"\n  [attr.aria-live]=\"(alertType === 'error' || alertType === 'warning') ? 'assertive' : 'polite'\"\n  [attr.aria-describedby]=\"'describedby'\"\n  [attr.aria-labelledby]=\"'labelledby'\"\n  [tabIndex]=\"0\"\n>\n  <span style=\"position: absolute; left: -9999px\" id=\"labelledby\">{{ ('ALERT_BANNER.' + (alertType | uppercase)) | uiTranslate | async }}</span>\n  <span [style.display]=\"'none'\" id=\"describedby\">{{ ariaDescribedby }}</span>\n  <div class=\"primary-alert-container\">\n    <div class=\"alert-text\">\n      @if (hasIcon) {\n        <ui-icon class=\"left-icon\" [name]=\"iconName\" size=\"24\" [applicationTheme]=\"applicationTheme\"></ui-icon>\n      }\n      <span [innerHTML]=\"_message\"></span>\n      <a *ngIf=\"!!linkText\" [target]=\"linkTarget\" [href]=\"linkUrl\">{{ linkText }}</a>\n    </div>\n    <ui-button\n      *ngIf=\"includeDismissButton && applicationTheme === 'classic'\"\n      variant=\"text\"\n      [justIcon]=\"true\"\n      class=\"close\"\n      iconName=\"Close\"\n      (buttonClickEvent)=\"dismissClick()\"\n    ></ui-button>\n    <ui-button\n      *ngIf=\"includeDismissButton && applicationTheme !== 'classic' && alertVariant !== 'callout'\"\n      class=\"right-icon\"\n      [variant]=\"'icon-button'\"\n      [applicationTheme]=\"applicationTheme\"\n      [iconName]=\"'Close'\"\n      [size]=\"'small'\"\n      [justIcon]=\"true\"\n      [tooltip]=\"(closeButtonTooltip || ('COMMON.CLOSE' | uiTranslate | async))!\"\n      (click)=\"dismissClick()\"\n    ></ui-button>\n  </div>\n  <div class=\"secondary-alerts-container\">\n    <div class=\"alert-text\" *ngFor=\"let alert of _secondaryAlerts\">\n      <ui-icon class=\"left-icon\" [name]=\"'Stop-filled'\" [applicationTheme]=\"applicationTheme\"></ui-icon>\n      <span [innerHTML]=\"alert\"></span>\n    </div>\n  </div>\n</div>\n"]}