@testgorilla/tgo-ui 3.10.13 → 3.10.14

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 (59) hide show
  1. package/README.md +103 -103
  2. package/components/confirm-dialog/confirm-dialog.component.d.ts +5 -3
  3. package/components/confirm-dialog/confirm-dialog.model.d.ts +30 -2
  4. package/components/dialog/dialog.component.d.ts +3 -2
  5. package/components/dialog/dialog.model.d.ts +2 -2
  6. package/components/dialog/dialog.service.d.ts +5 -2
  7. package/esm2022/components/ai-feedback/ai-feedback.component.mjs +3 -3
  8. package/esm2022/components/ai-feedback/ai-feedback.model.mjs +1 -1
  9. package/esm2022/components/ai-feedback/ai-feedback.module.mjs +1 -1
  10. package/esm2022/components/alert-banner/alert-banner.component.mjs +1 -1
  11. package/esm2022/components/card/card.component.mjs +3 -3
  12. package/esm2022/components/checklist/checklist.component.mjs +3 -3
  13. package/esm2022/components/checklist/checklist.model.mjs +1 -1
  14. package/esm2022/components/confirm-dialog/confirm-dialog.component.mjs +10 -3
  15. package/esm2022/components/confirm-dialog/confirm-dialog.model.mjs +1 -1
  16. package/esm2022/components/datepicker/datepicker.component.mjs +3 -3
  17. package/esm2022/components/dialog/dialog.component.mjs +5 -4
  18. package/esm2022/components/dialog/dialog.model.mjs +1 -1
  19. package/esm2022/components/dialog/dialog.service.mjs +1 -1
  20. package/esm2022/components/empty-state/empty-state.model.mjs +1 -1
  21. package/esm2022/components/field/field.component.mjs +1 -1
  22. package/esm2022/components/file-upload/file-upload.component.mjs +3 -3
  23. package/esm2022/components/gaussian-chart/gaussian-chart.component.mjs +3 -3
  24. package/esm2022/components/icon/icon.config.mjs +1 -1
  25. package/esm2022/components/icon-label/icon-label.component.mjs +1 -1
  26. package/esm2022/components/multi-input/multi-input.component.mjs +1 -1
  27. package/esm2022/components/progress-bar/progress-bar.component.mjs +1 -1
  28. package/esm2022/components/selectable-card/selectable-card.component.mjs +3 -3
  29. package/esm2022/components/selectable-card/selectable-card.component.module.mjs +1 -1
  30. package/esm2022/components/side-panel/side-panel.animations.mjs +1 -1
  31. package/esm2022/components/side-panel/side-panel.component.mjs +3 -3
  32. package/esm2022/components/side-panel/side-panel.model.mjs +1 -1
  33. package/esm2022/components/side-panel/side-panel.service.mjs +1 -1
  34. package/esm2022/pipes/ui-translate.pipe.mjs +1 -1
  35. package/esm2022/public-api.mjs +4 -4
  36. package/fesm2022/testgorilla-tgo-ui.mjs +28 -20
  37. package/fesm2022/testgorilla-tgo-ui.mjs.map +1 -1
  38. package/package.json +1 -1
  39. package/projects/tgo-canopy-ui/assets/i18n/en.json +821 -821
  40. package/projects/tgo-canopy-ui/assets/icons/Switch-tab.svg +3 -3
  41. package/projects/tgo-canopy-ui/assets/icons/rebrand/Credit-card-filled.svg +10 -10
  42. package/projects/tgo-canopy-ui/assets/icons/rebrand/Credit-card-in-line.svg +10 -10
  43. package/projects/tgo-canopy-ui/assets/icons/rebrand/Credit-filled.svg +3 -3
  44. package/projects/tgo-canopy-ui/assets/icons/rebrand/Credit-in-line.svg +3 -3
  45. package/projects/tgo-canopy-ui/assets/icons/rebrand/Invoice-filled.svg +3 -3
  46. package/projects/tgo-canopy-ui/assets/icons/rebrand/Invoice-in-line.svg +3 -3
  47. package/projects/tgo-canopy-ui/assets/icons/rebrand/Messages-in-line.svg +3 -3
  48. package/projects/tgo-canopy-ui/assets/icons/rebrand/Open-in-new-filled.svg +3 -3
  49. package/projects/tgo-canopy-ui/assets/icons/rebrand/Open-in-new-in-line.svg +3 -3
  50. package/projects/tgo-canopy-ui/assets/icons/rebrand/Open-lock-filled.svg +3 -3
  51. package/projects/tgo-canopy-ui/assets/icons/rebrand/Open-lock-in-line.svg +3 -3
  52. package/projects/tgo-canopy-ui/assets/icons/rebrand/Switch-tab-filled.svg +3 -3
  53. package/projects/tgo-canopy-ui/assets/icons/rebrand/Switch-tab-in-line.svg +3 -3
  54. package/projects/tgo-canopy-ui/assets/icons/rebrand/Thumb-down-filled.svg +3 -3
  55. package/projects/tgo-canopy-ui/assets/icons/rebrand/Thumb-down-in-line.svg +3 -3
  56. package/projects/tgo-canopy-ui/assets/icons/rebrand/Thumb-up-filled.svg +3 -3
  57. package/projects/tgo-canopy-ui/assets/icons/rebrand/Thumb-up-in-line.svg +3 -3
  58. package/projects/tgo-canopy-ui/theme/_input.scss +575 -575
  59. package/public-api.d.ts +3 -3
package/README.md CHANGED
@@ -1,103 +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 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
-
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
+
@@ -1,16 +1,16 @@
1
1
  import { MatDialogRef } from '@angular/material/dialog';
2
2
  import { DomSanitizer, SafeHtml } from '@angular/platform-browser';
3
3
  import { ApplicationTheme } from '../../models/application-theme.model';
4
- import { ConfirmDialogData } from './confirm-dialog.model';
5
- import { ButtonColor } from '../button/button.model';
4
+ import { ButtonColor, ButtonIconPosition } from '../button/button.model';
6
5
  import { IconName } from '../icon/icon.model';
6
+ import { ConfirmDialogData } from './confirm-dialog.model';
7
7
  import * as i0 from "@angular/core";
8
8
  export declare class ConfirmDialogComponent {
9
9
  private readonly defaultAppTheme;
10
10
  dialogRef: MatDialogRef<ConfirmDialogComponent>;
11
11
  private data;
12
12
  protected domSanitizer: DomSanitizer;
13
- confirmMessage: string;
13
+ confirmMessage: string | undefined;
14
14
  confirmButtonText: string | undefined;
15
15
  cancelButtonText: string | undefined;
16
16
  title: string | undefined;
@@ -24,6 +24,7 @@ export declare class ConfirmDialogComponent {
24
24
  primaryButtonIconName: IconName | undefined;
25
25
  primaryButtonDataTestId: string;
26
26
  secondaryButtonDataTestId: string;
27
+ primaryButtonIconPosition: ButtonIconPosition;
27
28
  /**
28
29
  *
29
30
  * Defines the application theme
@@ -33,6 +34,7 @@ export declare class ConfirmDialogComponent {
33
34
  */
34
35
  applicationTheme: ApplicationTheme;
35
36
  constructor(defaultAppTheme: ApplicationTheme, dialogRef: MatDialogRef<ConfirmDialogComponent>, data: ConfirmDialogData, domSanitizer: DomSanitizer);
37
+ onConfirm(): void;
36
38
  static ɵfac: i0.ɵɵFactoryDeclaration<ConfirmDialogComponent, [{ optional: true; }, null, null, null]>;
37
39
  static ɵcmp: i0.ɵɵComponentDeclaration<ConfirmDialogComponent, "ui-confirm-dialog", never, { "applicationTheme": { "alias": "applicationTheme"; "required": false; }; }, {}, never, never, false, never>;
38
40
  }
@@ -1,8 +1,8 @@
1
1
  import { Language } from '../../utils/localization/language.model';
2
- import { ButtonColor } from '../button/button.model';
2
+ import { ButtonColor, ButtonIconPosition } from '../button/button.model';
3
3
  import { IconName } from '../icon/icon.model';
4
4
  export interface ConfirmDialogData {
5
- message: string;
5
+ message?: string;
6
6
  confirmButtonText?: string;
7
7
  cancelButtonText?: string;
8
8
  title?: string;
@@ -12,8 +12,36 @@ export interface ConfirmDialogData {
12
12
  showCloseButton?: boolean;
13
13
  showSecondaryButton?: boolean;
14
14
  primaryButtonType?: ButtonColor;
15
+ primaryButtonIconPosition?: ButtonIconPosition;
15
16
  secondaryButtonType?: ButtonColor;
16
17
  primaryButtonIconName?: IconName;
17
18
  primaryButtonDataTestId?: string;
18
19
  secondaryButtonDataTestId?: string;
20
+ /**
21
+ * Callback function executed when the primary/confirm button is clicked.
22
+ *
23
+ * This callback is executed immediately before the dialog closes, within the same
24
+ * user gesture context. This is crucial for operations that may trigger popup blockers
25
+ * in restrictive browsers, such as:
26
+ * - Opening new tabs/windows (window.open)
27
+ * - Triggering file downloads
28
+ * - Navigating to external URLs
29
+ * - Accessing clipboard operations
30
+ *
31
+ * **Important**: Use this instead of subscribing to `afterClosed()` for popup-sensitive
32
+ * operations, as `afterClosed()` executes outside the user gesture context and will
33
+ * be blocked by popup blockers in most modern browsers.
34
+ *
35
+ * @example
36
+ * ```typescript
37
+ * // ✅ Good - executes within user gesture, won't be blocked
38
+ * onConfirm: () => window.open('https://example.com', '_blank')
39
+ *
40
+ * // ❌ Bad - executes outside user gesture, could be blocked
41
+ * dialogRef.afterClosed().subscribe(result => {
42
+ * if (result) window.open('https://example.com', '_blank');
43
+ * });
44
+ * ```
45
+ */
46
+ onConfirm?: () => void;
19
47
  }
@@ -1,8 +1,8 @@
1
1
  import { AfterViewInit, EventEmitter, OnChanges, OnInit, SimpleChanges } from '@angular/core';
2
2
  import { MatDialogRef } from '@angular/material/dialog';
3
- import { ButtonColor } from '../button/button.model';
4
3
  import { ApplicationTheme } from '../../models/application-theme.model';
5
4
  import { ButtonComponent } from '../button/button.component';
5
+ import { ButtonColor, ButtonIconPosition } from '../button/button.model';
6
6
  import { IconName } from '../icon/icon.model';
7
7
  import * as i0 from "@angular/core";
8
8
  export declare class DialogComponent implements OnInit, OnChanges, AfterViewInit {
@@ -136,6 +136,7 @@ export declare class DialogComponent implements OnInit, OnChanges, AfterViewInit
136
136
  * @memberof DialogComponent
137
137
  */
138
138
  keyboardOpen: boolean;
139
+ primaryButtonIconPosition: import("@angular/core").InputSignal<ButtonIconPosition>;
139
140
  closeEvent: EventEmitter<Event>;
140
141
  secondaryButtonClickEvent: EventEmitter<Event>;
141
142
  primaryButtonClickEvent: EventEmitter<Event>;
@@ -158,5 +159,5 @@ export declare class DialogComponent implements OnInit, OnChanges, AfterViewInit
158
159
  onSecondaryButtonClick(event: Event): void;
159
160
  onPrimaryButtonClick(event: Event): void;
160
161
  static ɵfac: i0.ɵɵFactoryDeclaration<DialogComponent, [{ optional: true; }, null, null]>;
161
- static ɵcmp: i0.ɵɵComponentDeclaration<DialogComponent, "ui-dialog", never, { "title": { "alias": "title"; "required": false; }; "showCloseButton": { "alias": "showCloseButton"; "required": false; }; "canCloseFn": { "alias": "canCloseFn"; "required": false; }; "secondaryButtonLabel": { "alias": "secondaryButtonLabel"; "required": false; }; "footerMessage": { "alias": "footerMessage"; "required": false; }; "primaryButtonLabel": { "alias": "primaryButtonLabel"; "required": false; }; "primaryButtonIconName": { "alias": "primaryButtonIconName"; "required": false; }; "secondaryButtonType": { "alias": "secondaryButtonType"; "required": false; }; "primaryButtonType": { "alias": "primaryButtonType"; "required": false; }; "primaryButtonDataTestId": { "alias": "primaryButtonDataTestId"; "required": false; }; "secondaryButtonDataTestId": { "alias": "secondaryButtonDataTestId"; "required": false; }; "companyColor": { "alias": "companyColor"; "required": false; }; "applicationTheme": { "alias": "applicationTheme"; "required": false; }; "disablePrimaryButton": { "alias": "disablePrimaryButton"; "required": false; }; "disableClose": { "alias": "disableClose"; "required": false; }; "shouldDisableButtons": { "alias": "shouldDisableButtons"; "required": false; }; "ariaLabelledby": { "alias": "ariaLabelledby"; "required": false; }; "ariaDescribedby": { "alias": "ariaDescribedby"; "required": false; }; "keyboardOpen": { "alias": "keyboardOpen"; "required": false; }; }, { "closeEvent": "closeEvent"; "secondaryButtonClickEvent": "secondaryButtonClickEvent"; "primaryButtonClickEvent": "primaryButtonClickEvent"; }, ["customHeader"], ["[dialogHeader]", "*"], false, never>;
162
+ static ɵcmp: i0.ɵɵComponentDeclaration<DialogComponent, "ui-dialog", never, { "title": { "alias": "title"; "required": false; }; "showCloseButton": { "alias": "showCloseButton"; "required": false; }; "canCloseFn": { "alias": "canCloseFn"; "required": false; }; "secondaryButtonLabel": { "alias": "secondaryButtonLabel"; "required": false; }; "footerMessage": { "alias": "footerMessage"; "required": false; }; "primaryButtonLabel": { "alias": "primaryButtonLabel"; "required": false; }; "primaryButtonIconName": { "alias": "primaryButtonIconName"; "required": false; }; "secondaryButtonType": { "alias": "secondaryButtonType"; "required": false; }; "primaryButtonType": { "alias": "primaryButtonType"; "required": false; }; "primaryButtonDataTestId": { "alias": "primaryButtonDataTestId"; "required": false; }; "secondaryButtonDataTestId": { "alias": "secondaryButtonDataTestId"; "required": false; }; "companyColor": { "alias": "companyColor"; "required": false; }; "applicationTheme": { "alias": "applicationTheme"; "required": false; }; "disablePrimaryButton": { "alias": "disablePrimaryButton"; "required": false; }; "disableClose": { "alias": "disableClose"; "required": false; }; "shouldDisableButtons": { "alias": "shouldDisableButtons"; "required": false; }; "ariaLabelledby": { "alias": "ariaLabelledby"; "required": false; }; "ariaDescribedby": { "alias": "ariaDescribedby"; "required": false; }; "keyboardOpen": { "alias": "keyboardOpen"; "required": false; }; "primaryButtonIconPosition": { "alias": "primaryButtonIconPosition"; "required": false; "isSignal": true; }; }, { "closeEvent": "closeEvent"; "secondaryButtonClickEvent": "secondaryButtonClickEvent"; "primaryButtonClickEvent": "primaryButtonClickEvent"; }, ["customHeader"], ["[dialogHeader]", "*"], false, never>;
162
163
  }
@@ -1,11 +1,11 @@
1
1
  import { DialogSize } from "./dialog.service";
2
2
  import { MatDialogConfig } from "@angular/material/dialog";
3
3
  import { ApplicationTheme } from '../../models/application-theme.model';
4
- export interface DialogConfig {
4
+ export interface DialogConfig<T = any> {
5
5
  applicationTheme?: ApplicationTheme;
6
6
  size?: DialogSize;
7
7
  panelClass?: string;
8
- extraData?: any;
8
+ extraData?: T;
9
9
  backdropClass?: string;
10
10
  keyboardOpen?: boolean;
11
11
  config?: MatDialogConfig;
@@ -1,14 +1,17 @@
1
1
  import { ComponentType } from '@angular/cdk/portal';
2
2
  import { MatDialog, MatDialogRef } from '@angular/material/dialog';
3
3
  import { ApplicationTheme } from '../../models/application-theme.model';
4
- import { DialogConfig } from "./dialog.model";
4
+ import type { ConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component';
5
+ import type { ConfirmDialogData } from '../confirm-dialog/confirm-dialog.model';
6
+ import { DialogConfig } from './dialog.model';
5
7
  import * as i0 from "@angular/core";
6
8
  export type DialogSize = 'small' | 'large' | 'x-large';
7
9
  export declare class DialogService {
8
10
  private matDialog;
9
11
  private readonly defaultAppTheme;
10
12
  constructor(matDialog: MatDialog, defaultAppTheme: ApplicationTheme);
11
- open(dialogComponent: ComponentType<any>, dialogConfig?: DialogConfig): MatDialogRef<any>;
13
+ open(dialogComponent: ComponentType<ConfirmDialogComponent>, dialogConfig?: DialogConfig<ConfirmDialogData>): MatDialogRef<ConfirmDialogComponent>;
14
+ open<K, T>(dialogComponent: Exclude<ComponentType<T>, ComponentType<ConfirmDialogComponent>>, dialogConfig?: DialogConfig<K>): MatDialogRef<T>;
12
15
  static ɵfac: i0.ɵɵFactoryDeclaration<DialogService, [null, { optional: true; }]>;
13
16
  static ɵprov: i0.ɵɵInjectableDeclaration<DialogService>;
14
17
  }
@@ -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":"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","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"]}