@flywheel-io/vision 2.7.7 → 2.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,7 +1,6 @@
1
1
  import { DialogRef } from '@angular/cdk/dialog';
2
2
  import { ElementRef, EventEmitter } from '@angular/core';
3
3
  import { IconType } from '../icon/icon.types';
4
- import { DialogWidth } from './dialog.component';
5
4
  import * as i0 from "@angular/core";
6
5
  export declare class FwDialogConfirmComponent {
7
6
  dialogRef: DialogRef;
@@ -10,6 +9,7 @@ export declare class FwDialogConfirmComponent {
10
9
  icon?: IconType;
11
10
  iconColor?: 'primary' | 'secondary' | 'red' | 'orange' | 'green' | 'slate';
12
11
  confirmColor?: 'primary' | 'secondary' | 'danger' | 'slate' | 'warning' | 'success';
12
+ cancelColor?: 'primary' | 'secondary' | 'danger' | 'slate' | 'warning' | 'success';
13
13
  confirmButtonText?: string;
14
14
  confirmButtonIcon?: IconType;
15
15
  cancelButtonText?: string;
@@ -24,7 +24,6 @@ export declare class FwDialogConfirmComponent {
24
24
  };
25
25
  close: EventEmitter<void>;
26
26
  confirm: EventEmitter<void>;
27
- protected readonly DialogWidth: typeof DialogWidth;
28
27
  private isClosing;
29
28
  constructor(dialogRef: DialogRef, elementRef: ElementRef);
30
29
  get classes(): {
@@ -32,7 +31,8 @@ export declare class FwDialogConfirmComponent {
32
31
  };
33
32
  get dialogClasses(): string;
34
33
  handleCloseButton(): void;
34
+ protected handleConfirm(): void;
35
35
  private closeWithAnimation;
36
36
  static ɵfac: i0.ɵɵFactoryDeclaration<FwDialogConfirmComponent, [{ optional: true; }, null]>;
37
- static ɵcmp: i0.ɵɵComponentDeclaration<FwDialogConfirmComponent, "fw-dialog-confirm", never, { "title": { "alias": "title"; "required": false; }; "icon": { "alias": "icon"; "required": false; }; "iconColor": { "alias": "iconColor"; "required": false; }; "confirmColor": { "alias": "confirmColor"; "required": false; }; "confirmButtonText": { "alias": "confirmButtonText"; "required": false; }; "confirmButtonIcon": { "alias": "confirmButtonIcon"; "required": false; }; "cancelButtonText": { "alias": "cancelButtonText"; "required": false; }; "contentIcon": { "alias": "contentIcon"; "required": false; }; "contentTitle": { "alias": "contentTitle"; "required": false; }; "contentText": { "alias": "contentText"; "required": false; }; "showConfirmButtonIcon": { "alias": "showConfirmButtonIcon"; "required": false; }; "showClose": { "alias": "showClose"; "required": false; }; "width": { "alias": "width"; "required": false; }; "externalClasses": { "alias": "class"; "required": false; }; }, { "close": "close"; "confirm": "confirm"; }, never, never, false, never>;
37
+ static ɵcmp: i0.ɵɵComponentDeclaration<FwDialogConfirmComponent, "fw-dialog-confirm", never, { "title": { "alias": "title"; "required": false; }; "icon": { "alias": "icon"; "required": false; }; "iconColor": { "alias": "iconColor"; "required": false; }; "confirmColor": { "alias": "confirmColor"; "required": false; }; "cancelColor": { "alias": "cancelColor"; "required": false; }; "confirmButtonText": { "alias": "confirmButtonText"; "required": false; }; "confirmButtonIcon": { "alias": "confirmButtonIcon"; "required": false; }; "cancelButtonText": { "alias": "cancelButtonText"; "required": false; }; "contentIcon": { "alias": "contentIcon"; "required": false; }; "contentTitle": { "alias": "contentTitle"; "required": false; }; "contentText": { "alias": "contentText"; "required": false; }; "showConfirmButtonIcon": { "alias": "showConfirmButtonIcon"; "required": false; }; "showClose": { "alias": "showClose"; "required": false; }; "width": { "alias": "width"; "required": false; }; "externalClasses": { "alias": "class"; "required": false; }; }, { "close": "close"; "confirm": "confirm"; }, never, never, false, never>;
38
38
  }
@@ -1,24 +1,28 @@
1
- import { AfterViewInit, ChangeDetectorRef, EventEmitter, OnInit } from '@angular/core';
1
+ import { AfterViewInit, ChangeDetectorRef } from '@angular/core';
2
2
  import { FwSnackbarMessage } from '../snackbar-message.model';
3
3
  import { FwSnackbarTimerService } from '../snackbar-timer.service';
4
4
  import * as i0 from "@angular/core";
5
- export declare class FwSnackbarComponent implements AfterViewInit, OnInit {
5
+ export declare class FwSnackbarComponent implements AfterViewInit {
6
6
  private cdr;
7
7
  private timerService;
8
- message: FwSnackbarMessage;
9
- messageDuration: number;
10
- ready: EventEmitter<FwSnackbarComponent>;
11
- dismiss: EventEmitter<string>;
12
- action: EventEmitter<string>;
13
- color: 'primary' | 'success' | 'warning' | 'danger';
8
+ message: import("@angular/core").InputSignal<FwSnackbarMessage>;
9
+ messageDuration: import("@angular/core").InputSignal<number>;
10
+ ready: import("@angular/core").OutputEmitterRef<FwSnackbarComponent>;
11
+ dismiss: import("@angular/core").OutputEmitterRef<string>;
12
+ action: import("@angular/core").OutputEmitterRef<string>;
13
+ private defaultIcons;
14
+ icon: import("@angular/core").Signal<string>;
15
+ showClose: import("@angular/core").Signal<boolean>;
16
+ duration: import("@angular/core").Signal<number>;
17
+ color: import("@angular/core").Signal<"warning" | "success" | "primary" | "secondary" | "slate" | "danger" | "skeleton">;
18
+ isTemplateRef: import("@angular/core").Signal<boolean>;
14
19
  get cssClass(): string;
15
20
  constructor(cdr: ChangeDetectorRef, timerService: FwSnackbarTimerService);
16
21
  ngAfterViewInit(): void;
17
22
  startTimer(): void;
18
23
  stopTimer(): void;
19
- ngOnInit(): void;
20
24
  handleDismiss(): void;
21
25
  handleAction(): void;
22
26
  static ɵfac: i0.ɵɵFactoryDeclaration<FwSnackbarComponent, never>;
23
- static ɵcmp: i0.ɵɵComponentDeclaration<FwSnackbarComponent, "fw-snackbar", never, { "message": { "alias": "message"; "required": false; }; "messageDuration": { "alias": "messageDuration"; "required": false; }; }, { "ready": "ready"; "dismiss": "dismiss"; "action": "action"; }, never, never, false, never>;
27
+ static ɵcmp: i0.ɵɵComponentDeclaration<FwSnackbarComponent, "fw-snackbar", never, { "message": { "alias": "message"; "required": true; "isSignal": true; }; "messageDuration": { "alias": "messageDuration"; "required": false; "isSignal": true; }; }, { "ready": "ready"; "dismiss": "dismiss"; "action": "action"; }, never, never, false, never>;
24
28
  }
@@ -1,12 +1,14 @@
1
+ import { TemplateRef } from '@angular/core';
1
2
  import { FwSnackbarComponent } from './snackbar/snackbar.component';
2
3
  export interface FwSnackbarMessage {
3
4
  id?: string;
4
5
  severity: 'info' | 'success' | 'warning' | 'error';
5
- message: string;
6
+ message: string | TemplateRef<any>;
6
7
  icon?: string;
7
8
  showClose?: boolean;
8
9
  actionText?: string;
9
10
  action?: () => void;
10
11
  duration?: number;
11
12
  ref?: FwSnackbarComponent;
13
+ templateContext?: object;
12
14
  }
@@ -5,7 +5,7 @@ export type DelayLength = 'none' | 'short' | 'long';
5
5
  export type SimplePosition = 'above' | 'below' | 'left' | 'right';
6
6
  export declare class FwTooltipPanelComponent {
7
7
  animation: any;
8
- trigger: import("@angular/core").InputSignalWithTransform<CdkOverlayOrigin, CdkOverlayOrigin | ElementRef<HTMLElement>>;
8
+ trigger: import("@angular/core").InputSignalWithTransform<CdkOverlayOrigin, ElementRef<HTMLElement> | CdkOverlayOrigin>;
9
9
  title: string;
10
10
  isOpen: import("@angular/core").InputSignal<boolean>;
11
11
  position: import("@angular/core").InputSignal<SimplePosition>;
@@ -1,5 +1,4 @@
1
1
  import { Component, EventEmitter, HostBinding, Input, Optional, Output } from '@angular/core';
2
- import { DialogWidth } from './dialog.component';
3
2
  import * as i0 from "@angular/core";
4
3
  import * as i1 from "@angular/cdk/dialog";
5
4
  import * as i2 from "@angular/common";
@@ -15,6 +14,7 @@ export class FwDialogConfirmComponent {
15
14
  this.title = 'Confirm';
16
15
  this.iconColor = 'primary';
17
16
  this.confirmColor = 'primary';
17
+ this.cancelColor = 'slate';
18
18
  this.confirmButtonText = 'Confirm';
19
19
  this.confirmButtonIcon = 'done-check';
20
20
  this.cancelButtonText = 'Cancel';
@@ -25,7 +25,6 @@ export class FwDialogConfirmComponent {
25
25
  // eslint-disable-next-line @angular-eslint/no-output-native
26
26
  this.close = new EventEmitter();
27
27
  this.confirm = new EventEmitter();
28
- this.DialogWidth = DialogWidth;
29
28
  this.isClosing = false;
30
29
  }
31
30
  get classes() {
@@ -57,6 +56,10 @@ export class FwDialogConfirmComponent {
57
56
  handleCloseButton() {
58
57
  this.closeWithAnimation();
59
58
  }
59
+ handleConfirm() {
60
+ this.dialogRef.close(true);
61
+ this.confirm.emit();
62
+ }
60
63
  closeWithAnimation() {
61
64
  if (this.isClosing) {
62
65
  return;
@@ -68,11 +71,11 @@ export class FwDialogConfirmComponent {
68
71
  }, 300);
69
72
  }
70
73
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwDialogConfirmComponent, deps: [{ token: i1.DialogRef, optional: true }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
71
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FwDialogConfirmComponent, selector: "fw-dialog-confirm", inputs: { title: "title", icon: "icon", iconColor: "iconColor", confirmColor: "confirmColor", confirmButtonText: "confirmButtonText", confirmButtonIcon: "confirmButtonIcon", cancelButtonText: "cancelButtonText", contentIcon: "contentIcon", contentTitle: "contentTitle", contentText: "contentText", showConfirmButtonIcon: "showConfirmButtonIcon", showClose: "showClose", width: "width", externalClasses: ["class", "externalClasses"] }, outputs: { close: "close", confirm: "confirm" }, host: { properties: { "class": "this.classes" } }, ngImport: i0, template: "<fw-dialog\n [width]=\"width\"\n [title]=\"title\"\n [icon]=\"icon\"\n [iconColor]=\"iconColor\"\n [showClose]=\"showClose\"\n [ngClass]=\"dialogClasses\">\n <fw-dialog-content>\n <div class=\"dialog-content-confirm\">\n <fw-icon class=\"content-icon\" [ngClass]=\"confirmColor\" *ngIf=\"contentIcon\">\n {{ contentIcon }}\n </fw-icon>\n <p class=\"vision-p2 content-title\" *ngIf=\"contentTitle\">\n {{ contentTitle }}\n </p>\n <p class=\"vision-p2 content-text\" *ngIf=\"contentText\">\n {{ contentText }}\n </p>\n </div>\n </fw-dialog-content>\n <fw-dialog-actions>\n <fw-button\n variant=\"outline\"\n *ngIf=\"cancelButtonText\"\n color=\"slate\"\n (click)=\"handleCloseButton()\">\n {{ cancelButtonText }}\n </fw-button>\n <fw-button\n variant=\"solid\"\n *ngIf=\"confirmButtonText\"\n [color]=\"confirmColor\"\n [leftIcon]=\"showConfirmButtonIcon ? confirmButtonIcon : null\"\n (click)=\"confirm.emit()\">\n {{ confirmButtonText }}\n </fw-button>\n </fw-dialog-actions>\n</fw-dialog>\n", styles: ["@keyframes slide-in-from-bottom{0%{opacity:0;transform:translateY(100vh)}to{opacity:1;transform:translateY(0)}}@keyframes slide-out-to-bottom{0%{opacity:1;transform:translateY(0)}99%{opacity:0;transform:translateY(100vh)}to{opacity:0;transform:translateY(100vh)}}:host{box-sizing:border-box;animation:slide-in-from-bottom .3s ease-out}:host.dialog-closing{animation:slide-out-to-bottom .3s ease-in forwards}:host .fw-dialog-confirm{position:relative}.dialog-content-confirm{display:flex;flex-direction:column;padding:50px;align-items:center;justify-content:center}.dialog-content-confirm .content-title{margin-bottom:5px;font-weight:500}.dialog-content-confirm .content-text{margin:0;color:var(--typography-muted)}.dialog-content-confirm .content-icon{font-size:50px}.dialog-content-confirm .content-icon.primary{color:var(--primary-base)}.dialog-content-confirm .content-icon.secondary{color:var(--secondary-base)}.dialog-content-confirm .content-icon.slate{color:var(--slate-base)}.dialog-content-confirm .content-icon.success{color:var(--green-base)}.dialog-content-confirm .content-icon.warning{color:var(--orange-base)}.dialog-content-confirm .content-icon.danger{color:var(--red-base)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.FwButtonComponent, selector: "fw-button", inputs: ["color", "size", "variant", "type", "disabled", "fullWidth", "leftIcon", "rightIcon"] }, { kind: "component", type: i4.FwIconComponent, selector: "fw-icon", inputs: ["size", "color"] }, { kind: "component", type: i5.FwDialogActionsComponent, selector: "fw-dialog-actions" }, { kind: "component", type: i6.FwDialogComponent, selector: "fw-dialog", inputs: ["width", "title", "icon", "iconColor", "showClose", "class"], outputs: ["close"] }, { kind: "component", type: i7.FwDialogContentComponent, selector: "fw-dialog-content", inputs: ["padded"] }] }); }
74
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: FwDialogConfirmComponent, selector: "fw-dialog-confirm", inputs: { title: "title", icon: "icon", iconColor: "iconColor", confirmColor: "confirmColor", cancelColor: "cancelColor", confirmButtonText: "confirmButtonText", confirmButtonIcon: "confirmButtonIcon", cancelButtonText: "cancelButtonText", contentIcon: "contentIcon", contentTitle: "contentTitle", contentText: "contentText", showConfirmButtonIcon: "showConfirmButtonIcon", showClose: "showClose", width: "width", externalClasses: ["class", "externalClasses"] }, outputs: { close: "close", confirm: "confirm" }, host: { properties: { "class": "this.classes" } }, ngImport: i0, template: "<fw-dialog\n [width]=\"width\"\n [title]=\"title\"\n [icon]=\"icon\"\n [iconColor]=\"iconColor\"\n [showClose]=\"showClose\"\n [ngClass]=\"dialogClasses\">\n <fw-dialog-content>\n <div class=\"dialog-content-confirm\">\n @if (contentIcon) {\n <fw-icon class=\"content-icon\" [ngClass]=\"confirmColor\">\n {{ contentIcon }}\n </fw-icon>\n }\n\n @if (contentTitle) {\n <p class=\"vision-p2 content-title\">\n {{ contentTitle }}\n </p>\n }\n\n @if (contentText) {\n <p class=\"vision-p2 content-text\">\n {{ contentText }}\n </p>\n }\n </div>\n </fw-dialog-content>\n <fw-dialog-actions>\n @if (cancelButtonText) {\n <fw-button\n variant=\"outline\"\n [color]=\"cancelColor\"\n (click)=\"handleCloseButton()\">\n {{ cancelButtonText }}\n </fw-button>\n }\n\n @if (confirmButtonText) {\n <fw-button\n variant=\"solid\"\n [color]=\"confirmColor\"\n [leftIcon]=\"showConfirmButtonIcon ? confirmButtonIcon : null\"\n (click)=\"handleConfirm()\">\n {{ confirmButtonText }}\n </fw-button>\n }\n </fw-dialog-actions>\n</fw-dialog>\n", styles: ["@keyframes slide-in-from-bottom{0%{opacity:0;transform:translateY(100vh)}to{opacity:1;transform:translateY(0)}}@keyframes slide-out-to-bottom{0%{opacity:1;transform:translateY(0)}99%{opacity:0;transform:translateY(100vh)}to{opacity:0;transform:translateY(100vh)}}:host{box-sizing:border-box;animation:slide-in-from-bottom .3s ease-out}:host.dialog-closing{animation:slide-out-to-bottom .3s ease-in forwards}:host .fw-dialog-confirm{position:relative}.dialog-content-confirm{display:flex;flex-direction:column;padding:50px;align-items:center;justify-content:center}.dialog-content-confirm .content-title{margin-bottom:5px;font-weight:500}.dialog-content-confirm .content-text{margin:0;color:var(--typography-muted)}.dialog-content-confirm .content-icon{font-size:50px}.dialog-content-confirm .content-icon.primary{color:var(--primary-base)}.dialog-content-confirm .content-icon.secondary{color:var(--secondary-base)}.dialog-content-confirm .content-icon.slate{color:var(--slate-base)}.dialog-content-confirm .content-icon.success{color:var(--green-base)}.dialog-content-confirm .content-icon.warning{color:var(--orange-base)}.dialog-content-confirm .content-icon.danger{color:var(--red-base)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i3.FwButtonComponent, selector: "fw-button", inputs: ["color", "size", "variant", "type", "disabled", "fullWidth", "leftIcon", "rightIcon"] }, { kind: "component", type: i4.FwIconComponent, selector: "fw-icon", inputs: ["size", "color"] }, { kind: "component", type: i5.FwDialogActionsComponent, selector: "fw-dialog-actions" }, { kind: "component", type: i6.FwDialogComponent, selector: "fw-dialog", inputs: ["width", "title", "icon", "iconColor", "showClose", "class"], outputs: ["close"] }, { kind: "component", type: i7.FwDialogContentComponent, selector: "fw-dialog-content", inputs: ["padded"] }] }); }
72
75
  }
73
76
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwDialogConfirmComponent, decorators: [{
74
77
  type: Component,
75
- args: [{ selector: 'fw-dialog-confirm', template: "<fw-dialog\n [width]=\"width\"\n [title]=\"title\"\n [icon]=\"icon\"\n [iconColor]=\"iconColor\"\n [showClose]=\"showClose\"\n [ngClass]=\"dialogClasses\">\n <fw-dialog-content>\n <div class=\"dialog-content-confirm\">\n <fw-icon class=\"content-icon\" [ngClass]=\"confirmColor\" *ngIf=\"contentIcon\">\n {{ contentIcon }}\n </fw-icon>\n <p class=\"vision-p2 content-title\" *ngIf=\"contentTitle\">\n {{ contentTitle }}\n </p>\n <p class=\"vision-p2 content-text\" *ngIf=\"contentText\">\n {{ contentText }}\n </p>\n </div>\n </fw-dialog-content>\n <fw-dialog-actions>\n <fw-button\n variant=\"outline\"\n *ngIf=\"cancelButtonText\"\n color=\"slate\"\n (click)=\"handleCloseButton()\">\n {{ cancelButtonText }}\n </fw-button>\n <fw-button\n variant=\"solid\"\n *ngIf=\"confirmButtonText\"\n [color]=\"confirmColor\"\n [leftIcon]=\"showConfirmButtonIcon ? confirmButtonIcon : null\"\n (click)=\"confirm.emit()\">\n {{ confirmButtonText }}\n </fw-button>\n </fw-dialog-actions>\n</fw-dialog>\n", styles: ["@keyframes slide-in-from-bottom{0%{opacity:0;transform:translateY(100vh)}to{opacity:1;transform:translateY(0)}}@keyframes slide-out-to-bottom{0%{opacity:1;transform:translateY(0)}99%{opacity:0;transform:translateY(100vh)}to{opacity:0;transform:translateY(100vh)}}:host{box-sizing:border-box;animation:slide-in-from-bottom .3s ease-out}:host.dialog-closing{animation:slide-out-to-bottom .3s ease-in forwards}:host .fw-dialog-confirm{position:relative}.dialog-content-confirm{display:flex;flex-direction:column;padding:50px;align-items:center;justify-content:center}.dialog-content-confirm .content-title{margin-bottom:5px;font-weight:500}.dialog-content-confirm .content-text{margin:0;color:var(--typography-muted)}.dialog-content-confirm .content-icon{font-size:50px}.dialog-content-confirm .content-icon.primary{color:var(--primary-base)}.dialog-content-confirm .content-icon.secondary{color:var(--secondary-base)}.dialog-content-confirm .content-icon.slate{color:var(--slate-base)}.dialog-content-confirm .content-icon.success{color:var(--green-base)}.dialog-content-confirm .content-icon.warning{color:var(--orange-base)}.dialog-content-confirm .content-icon.danger{color:var(--red-base)}\n"] }]
78
+ args: [{ selector: 'fw-dialog-confirm', template: "<fw-dialog\n [width]=\"width\"\n [title]=\"title\"\n [icon]=\"icon\"\n [iconColor]=\"iconColor\"\n [showClose]=\"showClose\"\n [ngClass]=\"dialogClasses\">\n <fw-dialog-content>\n <div class=\"dialog-content-confirm\">\n @if (contentIcon) {\n <fw-icon class=\"content-icon\" [ngClass]=\"confirmColor\">\n {{ contentIcon }}\n </fw-icon>\n }\n\n @if (contentTitle) {\n <p class=\"vision-p2 content-title\">\n {{ contentTitle }}\n </p>\n }\n\n @if (contentText) {\n <p class=\"vision-p2 content-text\">\n {{ contentText }}\n </p>\n }\n </div>\n </fw-dialog-content>\n <fw-dialog-actions>\n @if (cancelButtonText) {\n <fw-button\n variant=\"outline\"\n [color]=\"cancelColor\"\n (click)=\"handleCloseButton()\">\n {{ cancelButtonText }}\n </fw-button>\n }\n\n @if (confirmButtonText) {\n <fw-button\n variant=\"solid\"\n [color]=\"confirmColor\"\n [leftIcon]=\"showConfirmButtonIcon ? confirmButtonIcon : null\"\n (click)=\"handleConfirm()\">\n {{ confirmButtonText }}\n </fw-button>\n }\n </fw-dialog-actions>\n</fw-dialog>\n", styles: ["@keyframes slide-in-from-bottom{0%{opacity:0;transform:translateY(100vh)}to{opacity:1;transform:translateY(0)}}@keyframes slide-out-to-bottom{0%{opacity:1;transform:translateY(0)}99%{opacity:0;transform:translateY(100vh)}to{opacity:0;transform:translateY(100vh)}}:host{box-sizing:border-box;animation:slide-in-from-bottom .3s ease-out}:host.dialog-closing{animation:slide-out-to-bottom .3s ease-in forwards}:host .fw-dialog-confirm{position:relative}.dialog-content-confirm{display:flex;flex-direction:column;padding:50px;align-items:center;justify-content:center}.dialog-content-confirm .content-title{margin-bottom:5px;font-weight:500}.dialog-content-confirm .content-text{margin:0;color:var(--typography-muted)}.dialog-content-confirm .content-icon{font-size:50px}.dialog-content-confirm .content-icon.primary{color:var(--primary-base)}.dialog-content-confirm .content-icon.secondary{color:var(--secondary-base)}.dialog-content-confirm .content-icon.slate{color:var(--slate-base)}.dialog-content-confirm .content-icon.success{color:var(--green-base)}.dialog-content-confirm .content-icon.warning{color:var(--orange-base)}.dialog-content-confirm .content-icon.danger{color:var(--red-base)}\n"] }]
76
79
  }], ctorParameters: () => [{ type: i1.DialogRef, decorators: [{
77
80
  type: Optional
78
81
  }] }, { type: i0.ElementRef }], propDecorators: { title: [{
@@ -83,6 +86,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
83
86
  type: Input
84
87
  }], confirmColor: [{
85
88
  type: Input
89
+ }], cancelColor: [{
90
+ type: Input
86
91
  }], confirmButtonText: [{
87
92
  type: Input
88
93
  }], confirmButtonIcon: [{
@@ -112,4 +117,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
112
117
  type: HostBinding,
113
118
  args: ['class']
114
119
  }] } });
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-confirm.component.js","sourceRoot":"","sources":["../../../../../src/components/dialog/dialog-confirm.component.ts","../../../../../src/components/dialog/dialog-confirm.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DialogRef } from '@angular/cdk/dialog';\nimport { Component, ElementRef, EventEmitter, HostBinding, Input, Optional, Output } from '@angular/core';\n\nimport { IconType } from '../icon/icon.types';\nimport { DialogWidth } from './dialog.component';\n\n@Component({\n  selector: 'fw-dialog-confirm',\n  templateUrl: './dialog-confirm.component.html',\n  styleUrls: ['./dialog-confirm.component.scss'],\n})\nexport class FwDialogConfirmComponent {\n  @Input() title?: string = 'Confirm';\n  @Input() icon?: IconType;\n  @Input() iconColor?: 'primary' | 'secondary' | 'red' | 'orange' | 'green' | 'slate' = 'primary';\n  @Input() confirmColor?: 'primary' | 'secondary' | 'danger' | 'slate' | 'warning' | 'success' = 'primary';\n  @Input() confirmButtonText?: string = 'Confirm';\n  @Input() confirmButtonIcon?: IconType = 'done-check';\n  @Input() cancelButtonText?: string = 'Cancel';\n  @Input() contentIcon?: string;\n  @Input() contentTitle?: string = 'Are you sure?';\n  @Input() contentText?: string;\n  @Input() showConfirmButtonIcon = true;\n  @Input() showClose = false;\n  @Input() width: 'extra-small' | 'small' | 'medium' | 'large' | 'extra-large' | 'responsive' = 'extra-small';\n  // eslint-disable-next-line @angular-eslint/no-input-rename\n  @Input('class') externalClasses?: string | string[] | { [key: string]: boolean };\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() close: EventEmitter<void> = new EventEmitter<void>();\n  @Output() confirm: EventEmitter<void> = new EventEmitter<void>();\n  protected readonly DialogWidth = DialogWidth;\n\n  private isClosing = false;\n\n  constructor(@Optional() public dialogRef: DialogRef, private elementRef: ElementRef) {\n  }\n\n  @HostBinding('class') get classes(): { [key: string]: boolean } {\n    const classes: { [key: string]: boolean } = {};\n\n    if (this.externalClasses) {\n      if (typeof this.externalClasses === 'string') {\n        this.externalClasses.split(' ').forEach((cls: string) => {\n          if (cls.trim()) {\n            classes[cls.trim()] = true;\n          }\n        });\n      } else if (Array.isArray(this.externalClasses)) {\n        this.externalClasses.forEach((cls: string) => {\n          if (cls.trim()) {\n            classes[cls.trim()] = true;\n          }\n        });\n      } else {\n        Object.assign(classes, this.externalClasses);\n      }\n    }\n\n    return classes;\n  }\n\n  get dialogClasses(): string {\n    return this.isClosing ? 'dialog-closing' : '';\n  }\n\n  handleCloseButton(): void {\n    this.closeWithAnimation();\n  }\n\n  private closeWithAnimation(): void {\n    if (this.isClosing) {\n      return;\n    }\n\n    this.isClosing = true;\n\n    setTimeout(() => {\n      this.dialogRef.close();\n      this.close.emit();\n    }, 300);\n  }\n}\n","<fw-dialog\n  [width]=\"width\"\n  [title]=\"title\"\n  [icon]=\"icon\"\n  [iconColor]=\"iconColor\"\n  [showClose]=\"showClose\"\n  [ngClass]=\"dialogClasses\">\n  <fw-dialog-content>\n    <div class=\"dialog-content-confirm\">\n      <fw-icon class=\"content-icon\" [ngClass]=\"confirmColor\" *ngIf=\"contentIcon\">\n        {{ contentIcon }}\n      </fw-icon>\n      <p class=\"vision-p2 content-title\" *ngIf=\"contentTitle\">\n        {{ contentTitle }}\n      </p>\n      <p class=\"vision-p2 content-text\" *ngIf=\"contentText\">\n        {{ contentText }}\n      </p>\n    </div>\n  </fw-dialog-content>\n  <fw-dialog-actions>\n    <fw-button\n      variant=\"outline\"\n      *ngIf=\"cancelButtonText\"\n      color=\"slate\"\n      (click)=\"handleCloseButton()\">\n      {{ cancelButtonText }}\n    </fw-button>\n    <fw-button\n      variant=\"solid\"\n      *ngIf=\"confirmButtonText\"\n      [color]=\"confirmColor\"\n      [leftIcon]=\"showConfirmButtonIcon ? confirmButtonIcon : null\"\n      (click)=\"confirm.emit()\">\n      {{ confirmButtonText }}\n    </fw-button>\n  </fw-dialog-actions>\n</fw-dialog>\n"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-confirm.component.js","sourceRoot":"","sources":["../../../../../src/components/dialog/dialog-confirm.component.ts","../../../../../src/components/dialog/dialog-confirm.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DialogRef } from '@angular/cdk/dialog';\nimport { Component, ElementRef, EventEmitter, HostBinding, Input, Optional, Output } from '@angular/core';\n\nimport { IconType } from '../icon/icon.types';\n\n@Component({\n  selector: 'fw-dialog-confirm',\n  templateUrl: './dialog-confirm.component.html',\n  styleUrls: ['./dialog-confirm.component.scss'],\n})\nexport class FwDialogConfirmComponent {\n  @Input() title?: string = 'Confirm';\n  @Input() icon?: IconType;\n  @Input() iconColor?: 'primary' | 'secondary' | 'red' | 'orange' | 'green' | 'slate' = 'primary';\n  @Input() confirmColor?: 'primary' | 'secondary' | 'danger' | 'slate' | 'warning' | 'success' = 'primary';\n  @Input() cancelColor?: 'primary' | 'secondary' | 'danger' | 'slate' | 'warning' | 'success' = 'slate';\n  @Input() confirmButtonText?: string = 'Confirm';\n  @Input() confirmButtonIcon?: IconType = 'done-check';\n  @Input() cancelButtonText?: string = 'Cancel';\n  @Input() contentIcon?: string;\n  @Input() contentTitle?: string = 'Are you sure?';\n  @Input() contentText?: string;\n  @Input() showConfirmButtonIcon = true;\n  @Input() showClose = false;\n  @Input() width: 'extra-small' | 'small' | 'medium' | 'large' | 'extra-large' | 'responsive' = 'extra-small';\n  // eslint-disable-next-line @angular-eslint/no-input-rename\n  @Input('class') externalClasses?: string | string[] | { [key: string]: boolean };\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() close: EventEmitter<void> = new EventEmitter<void>();\n  @Output() confirm: EventEmitter<void> = new EventEmitter<void>();\n\n  private isClosing = false;\n\n  constructor(@Optional() public dialogRef: DialogRef, private elementRef: ElementRef) {\n  }\n\n  @HostBinding('class') get classes(): { [key: string]: boolean } {\n    const classes: { [key: string]: boolean } = {};\n\n    if (this.externalClasses) {\n      if (typeof this.externalClasses === 'string') {\n        this.externalClasses.split(' ').forEach((cls: string) => {\n          if (cls.trim()) {\n            classes[cls.trim()] = true;\n          }\n        });\n      } else if (Array.isArray(this.externalClasses)) {\n        this.externalClasses.forEach((cls: string) => {\n          if (cls.trim()) {\n            classes[cls.trim()] = true;\n          }\n        });\n      } else {\n        Object.assign(classes, this.externalClasses);\n      }\n    }\n\n    return classes;\n  }\n\n  get dialogClasses(): string {\n    return this.isClosing ? 'dialog-closing' : '';\n  }\n\n  handleCloseButton(): void {\n    this.closeWithAnimation();\n  }\n\n  protected handleConfirm(): void {\n    this.dialogRef.close(true);\n    this.confirm.emit();\n  }\n\n  private closeWithAnimation(): void {\n    if (this.isClosing) {\n      return;\n    }\n\n    this.isClosing = true;\n\n    setTimeout(() => {\n      this.dialogRef.close();\n      this.close.emit();\n    }, 300);\n  }\n}\n","<fw-dialog\n  [width]=\"width\"\n  [title]=\"title\"\n  [icon]=\"icon\"\n  [iconColor]=\"iconColor\"\n  [showClose]=\"showClose\"\n  [ngClass]=\"dialogClasses\">\n  <fw-dialog-content>\n    <div class=\"dialog-content-confirm\">\n      @if (contentIcon) {\n        <fw-icon class=\"content-icon\" [ngClass]=\"confirmColor\">\n          {{ contentIcon }}\n        </fw-icon>\n      }\n\n      @if (contentTitle) {\n        <p class=\"vision-p2 content-title\">\n          {{ contentTitle }}\n        </p>\n      }\n\n      @if (contentText) {\n        <p class=\"vision-p2 content-text\">\n          {{ contentText }}\n        </p>\n      }\n    </div>\n  </fw-dialog-content>\n  <fw-dialog-actions>\n    @if (cancelButtonText) {\n      <fw-button\n        variant=\"outline\"\n        [color]=\"cancelColor\"\n        (click)=\"handleCloseButton()\">\n        {{ cancelButtonText }}\n      </fw-button>\n    }\n\n    @if (confirmButtonText) {\n      <fw-button\n        variant=\"solid\"\n        [color]=\"confirmColor\"\n        [leftIcon]=\"showConfirmButtonIcon ? confirmButtonIcon : null\"\n        (click)=\"handleConfirm()\">\n        {{ confirmButtonText }}\n      </fw-button>\n    }\n  </fw-dialog-actions>\n</fw-dialog>\n"]}
@@ -1,5 +1,5 @@
1
1
  /* eslint-disable @rx-angular/no-explicit-change-detection-apis */
2
- import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation, } from '@angular/core';
2
+ import { ChangeDetectionStrategy, Component, computed, HostBinding, input, output, TemplateRef, ViewEncapsulation, } from '@angular/core';
3
3
  import { FwSnackbarTimerService } from '../snackbar-timer.service';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "../snackbar-timer.service";
@@ -10,8 +10,9 @@ import * as i5 from "../../icon/icon.component";
10
10
  export class FwSnackbarComponent {
11
11
  get cssClass() {
12
12
  const cssClass = 'fw-snackbar';
13
- if (this.message?.severity) {
14
- return cssClass + ' ' + this.color;
13
+ const severity = this.message()?.severity;
14
+ if (severity) {
15
+ return cssClass + ' ' + this.color();
15
16
  }
16
17
  else {
17
18
  return cssClass;
@@ -20,21 +21,47 @@ export class FwSnackbarComponent {
20
21
  constructor(cdr, timerService) {
21
22
  this.cdr = cdr;
22
23
  this.timerService = timerService;
23
- this.messageDuration = 9000;
24
- this.ready = new EventEmitter();
25
- this.dismiss = new EventEmitter();
26
- this.action = new EventEmitter();
27
- this.color = 'primary';
24
+ this.message = input.required();
25
+ this.messageDuration = input(9000);
26
+ this.ready = output();
27
+ this.dismiss = output();
28
+ this.action = output();
29
+ this.defaultIcons = {
30
+ success: 'done-check-tracked',
31
+ warning: 'warning-circle',
32
+ error: 'warning',
33
+ info: 'information-circle',
34
+ };
35
+ this.icon = computed(() => this.message().icon || this.defaultIcons[this.message().severity]);
36
+ this.showClose = computed(() => {
37
+ const msg = this.message();
38
+ return msg.showClose !== undefined ? msg.showClose : msg.severity === 'error';
39
+ });
40
+ this.duration = computed(() => {
41
+ const msg = this.message();
42
+ if (msg.duration) {
43
+ return msg.duration;
44
+ }
45
+ return msg.severity === 'error' ? 29000 : this.messageDuration();
46
+ });
47
+ this.color = computed(() => {
48
+ const severity = this.message().severity;
49
+ const colors = {
50
+ success: 'success',
51
+ warning: 'warning',
52
+ error: 'danger',
53
+ info: 'primary',
54
+ };
55
+ return colors[severity] || 'primary';
56
+ });
57
+ this.isTemplateRef = computed(() => this.message().message instanceof TemplateRef);
28
58
  }
29
59
  ngAfterViewInit() {
30
60
  this.ready.emit(this);
31
61
  this.cdr.markForCheck();
32
62
  }
33
63
  startTimer() {
34
- if (this.message && this.message.duration) {
35
- this.messageDuration = this.message.duration;
36
- }
37
- this.timerService.start(this.messageDuration).then(() => {
64
+ this.timerService.start(this.duration()).then(() => {
38
65
  this.handleDismiss();
39
66
  this.cdr.markForCheck();
40
67
  });
@@ -43,69 +70,26 @@ export class FwSnackbarComponent {
43
70
  this.timerService.stop();
44
71
  this.cdr.markForCheck();
45
72
  }
46
- ngOnInit() {
47
- switch (this.message.severity) {
48
- case 'success':
49
- if (!this.message.icon) {
50
- this.message.icon = 'done-check-tracked';
51
- }
52
- this.color = 'success';
53
- break;
54
- case 'warning':
55
- if (!this.message.icon) {
56
- this.message.icon = 'warning-circle';
57
- }
58
- this.color = 'warning';
59
- break;
60
- case 'error':
61
- if (!this.message.icon) {
62
- this.message.icon = 'warning';
63
- }
64
- if (this.message.showClose === undefined) {
65
- this.message.showClose = true;
66
- }
67
- if (!this.message.duration) {
68
- this.message.duration = 29000;
69
- }
70
- this.color = 'danger';
71
- break;
72
- case 'info':
73
- if (!this.message.icon) {
74
- this.message.icon = 'information-circle';
75
- }
76
- this.color = 'primary';
77
- break;
78
- }
79
- }
80
73
  handleDismiss() {
81
- this.dismiss.emit(this.message.id);
74
+ this.dismiss.emit(this.message().id);
82
75
  this.cdr.markForCheck();
83
76
  }
84
77
  handleAction() {
85
- this.action.emit(this.message.id);
86
- if (this.message.action) {
87
- this.message.action();
78
+ const msg = this.message();
79
+ this.action.emit(msg.id);
80
+ if (msg.action) {
81
+ msg.action();
88
82
  }
89
83
  this.cdr.markForCheck();
90
84
  }
91
85
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwSnackbarComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.FwSnackbarTimerService }], target: i0.ɵɵFactoryTarget.Component }); }
92
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FwSnackbarComponent, selector: "fw-snackbar", inputs: { message: "message", messageDuration: "messageDuration" }, outputs: { ready: "ready", dismiss: "dismiss", action: "action" }, host: { properties: { "class": "this.cssClass" } }, providers: [FwSnackbarTimerService], ngImport: i0, template: "<ng-container *ngIf=\"message\">\n <fw-icon *ngIf=\"message.icon\">{{ message.icon }}</fw-icon>\n <h4 class=\"vision-h4\" *ngIf=\"message.message\">{{ message.message }}</h4>\n <fw-button\n *ngIf=\"message.actionText\" variant=\"ghost\"\n [color]=\"color\" size=\"small\"\n (click)=\"handleAction()\">{{ message.actionText }}\n </fw-button>\n <fw-icon-button\n *ngIf=\"message.showClose\"\n icon=\"close\" size=\"small\" [color]=\"message.severity\"\n (click)=\"handleDismiss()\">\n </fw-icon-button>\n <div *ngIf=\"!message.actionText && !message.showClose\"></div>\n</ng-container>\n", styles: [".vision-shadow-extra-large{box-shadow:0 8px 25px #0000001a}.vision-shadow-large,fw-snackbar{box-shadow:0 5px 15px #0000001a}.vision-shadow-medium{box-shadow:0 2px 5px #0000001a}.vision-shadow-small{box-shadow:0 1px 2px #0000000d}.vision-shadow-inner{box-shadow:0 2px 4px #00000014 inset}fw-snackbar{display:flex;align-items:flex-start;box-sizing:border-box;max-width:320px;min-width:200px;min-height:30px;padding:8px 8px 8px 16px;gap:8px;transform-origin:center;background-color:var(--card-header);color:var(--typography-base);white-space:pre-wrap;border-radius:4px;border:1px solid var(--separations-border);margin:8px}fw-snackbar>fw-icon{width:24px;height:24px;font-size:24px;white-space:nowrap;margin:3px 0}fw-snackbar h4{margin:6px 0 0;flex:1}fw-snackbar.primary fw-icon{color:var(--primary-base)}fw-snackbar.danger fw-icon{color:var(--red-base)}fw-snackbar.success fw-icon{color:var(--green-base)}fw-snackbar.warning fw-icon{color:var(--orange-base)}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.FwButtonComponent, selector: "fw-button", inputs: ["color", "size", "variant", "type", "disabled", "fullWidth", "leftIcon", "rightIcon"] }, { kind: "component", type: i4.FwIconButtonComponent, selector: "fw-icon-button", inputs: ["color", "icon", "size", "disabled", "selected"] }, { kind: "component", type: i5.FwIconComponent, selector: "fw-icon", inputs: ["size", "color"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
86
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: FwSnackbarComponent, selector: "fw-snackbar", inputs: { message: { classPropertyName: "message", publicName: "message", isSignal: true, isRequired: true, transformFunction: null }, messageDuration: { classPropertyName: "messageDuration", publicName: "messageDuration", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { ready: "ready", dismiss: "dismiss", action: "action" }, host: { properties: { "class": "this.cssClass" } }, providers: [FwSnackbarTimerService], ngImport: i0, template: "@if (message(); as msg) {\n @if (icon()) {\n <fw-icon>{{ icon() }}</fw-icon>\n }\n @if (isTemplateRef()) {\n <ng-container *ngTemplateOutlet=\"$any(msg.message); context: msg.templateContext\"></ng-container>\n } @else {\n @if (msg.message) {\n <h4 class=\"vision-h4\">{{ msg.message }}</h4>\n }\n }\n @if (msg.actionText) {\n <fw-button\n size=\"small\"\n variant=\"ghost\"\n [color]=\"color()\"\n (click)=\"handleAction()\"\n >\n {{ msg.actionText }}\n </fw-button>\n }\n @if (showClose()) {\n <fw-icon-button\n icon=\"close\"\n size=\"small\"\n [color]=\"msg.severity\"\n (click)=\"handleDismiss()\"\n ></fw-icon-button>\n }\n @if (!msg.actionText && !showClose()) {\n <div></div>\n }\n}\n", styles: [".vision-shadow-extra-large{box-shadow:0 8px 25px #0000001a}.vision-shadow-large,fw-snackbar{box-shadow:0 5px 15px #0000001a}.vision-shadow-medium{box-shadow:0 2px 5px #0000001a}.vision-shadow-small{box-shadow:0 1px 2px #0000000d}.vision-shadow-inner{box-shadow:0 2px 4px #00000014 inset}fw-snackbar{display:flex;align-items:flex-start;box-sizing:border-box;max-width:320px;min-width:200px;min-height:30px;padding:8px 8px 8px 16px;gap:8px;transform-origin:center;background-color:var(--card-header);color:var(--typography-base);white-space:pre-wrap;border-radius:4px;border:1px solid var(--separations-border);margin:8px}fw-snackbar>fw-icon{width:24px;height:24px;font-size:24px;white-space:nowrap;margin:3px 0}fw-snackbar h4{margin:6px 0 0;flex:1}fw-snackbar.primary fw-icon{color:var(--primary-base)}fw-snackbar.danger fw-icon{color:var(--red-base)}fw-snackbar.success fw-icon{color:var(--green-base)}fw-snackbar.warning fw-icon{color:var(--orange-base)}\n"], dependencies: [{ kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.FwButtonComponent, selector: "fw-button", inputs: ["color", "size", "variant", "type", "disabled", "fullWidth", "leftIcon", "rightIcon"] }, { kind: "component", type: i4.FwIconButtonComponent, selector: "fw-icon-button", inputs: ["color", "icon", "size", "disabled", "selected"] }, { kind: "component", type: i5.FwIconComponent, selector: "fw-icon", inputs: ["size", "color"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
93
87
  }
94
88
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwSnackbarComponent, decorators: [{
95
89
  type: Component,
96
- args: [{ selector: 'fw-snackbar', providers: [FwSnackbarTimerService], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"message\">\n <fw-icon *ngIf=\"message.icon\">{{ message.icon }}</fw-icon>\n <h4 class=\"vision-h4\" *ngIf=\"message.message\">{{ message.message }}</h4>\n <fw-button\n *ngIf=\"message.actionText\" variant=\"ghost\"\n [color]=\"color\" size=\"small\"\n (click)=\"handleAction()\">{{ message.actionText }}\n </fw-button>\n <fw-icon-button\n *ngIf=\"message.showClose\"\n icon=\"close\" size=\"small\" [color]=\"message.severity\"\n (click)=\"handleDismiss()\">\n </fw-icon-button>\n <div *ngIf=\"!message.actionText && !message.showClose\"></div>\n</ng-container>\n", styles: [".vision-shadow-extra-large{box-shadow:0 8px 25px #0000001a}.vision-shadow-large,fw-snackbar{box-shadow:0 5px 15px #0000001a}.vision-shadow-medium{box-shadow:0 2px 5px #0000001a}.vision-shadow-small{box-shadow:0 1px 2px #0000000d}.vision-shadow-inner{box-shadow:0 2px 4px #00000014 inset}fw-snackbar{display:flex;align-items:flex-start;box-sizing:border-box;max-width:320px;min-width:200px;min-height:30px;padding:8px 8px 8px 16px;gap:8px;transform-origin:center;background-color:var(--card-header);color:var(--typography-base);white-space:pre-wrap;border-radius:4px;border:1px solid var(--separations-border);margin:8px}fw-snackbar>fw-icon{width:24px;height:24px;font-size:24px;white-space:nowrap;margin:3px 0}fw-snackbar h4{margin:6px 0 0;flex:1}fw-snackbar.primary fw-icon{color:var(--primary-base)}fw-snackbar.danger fw-icon{color:var(--red-base)}fw-snackbar.success fw-icon{color:var(--green-base)}fw-snackbar.warning fw-icon{color:var(--orange-base)}\n"] }]
97
- }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.FwSnackbarTimerService }], propDecorators: { message: [{
98
- type: Input
99
- }], messageDuration: [{
100
- type: Input
101
- }], ready: [{
102
- type: Output
103
- }], dismiss: [{
104
- type: Output
105
- }], action: [{
106
- type: Output
107
- }], cssClass: [{
90
+ args: [{ selector: 'fw-snackbar', providers: [FwSnackbarTimerService], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (message(); as msg) {\n @if (icon()) {\n <fw-icon>{{ icon() }}</fw-icon>\n }\n @if (isTemplateRef()) {\n <ng-container *ngTemplateOutlet=\"$any(msg.message); context: msg.templateContext\"></ng-container>\n } @else {\n @if (msg.message) {\n <h4 class=\"vision-h4\">{{ msg.message }}</h4>\n }\n }\n @if (msg.actionText) {\n <fw-button\n size=\"small\"\n variant=\"ghost\"\n [color]=\"color()\"\n (click)=\"handleAction()\"\n >\n {{ msg.actionText }}\n </fw-button>\n }\n @if (showClose()) {\n <fw-icon-button\n icon=\"close\"\n size=\"small\"\n [color]=\"msg.severity\"\n (click)=\"handleDismiss()\"\n ></fw-icon-button>\n }\n @if (!msg.actionText && !showClose()) {\n <div></div>\n }\n}\n", styles: [".vision-shadow-extra-large{box-shadow:0 8px 25px #0000001a}.vision-shadow-large,fw-snackbar{box-shadow:0 5px 15px #0000001a}.vision-shadow-medium{box-shadow:0 2px 5px #0000001a}.vision-shadow-small{box-shadow:0 1px 2px #0000000d}.vision-shadow-inner{box-shadow:0 2px 4px #00000014 inset}fw-snackbar{display:flex;align-items:flex-start;box-sizing:border-box;max-width:320px;min-width:200px;min-height:30px;padding:8px 8px 8px 16px;gap:8px;transform-origin:center;background-color:var(--card-header);color:var(--typography-base);white-space:pre-wrap;border-radius:4px;border:1px solid var(--separations-border);margin:8px}fw-snackbar>fw-icon{width:24px;height:24px;font-size:24px;white-space:nowrap;margin:3px 0}fw-snackbar h4{margin:6px 0 0;flex:1}fw-snackbar.primary fw-icon{color:var(--primary-base)}fw-snackbar.danger fw-icon{color:var(--red-base)}fw-snackbar.success fw-icon{color:var(--green-base)}fw-snackbar.warning fw-icon{color:var(--orange-base)}\n"] }]
91
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.FwSnackbarTimerService }], propDecorators: { cssClass: [{
108
92
  type: HostBinding,
109
93
  args: ['class']
110
94
  }] } });
111
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snackbar.component.js","sourceRoot":"","sources":["../../../../../../src/components/snackbar/snackbar/snackbar.component.ts","../../../../../../src/components/snackbar/snackbar/snackbar.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @rx-angular/no-explicit-change-detection-apis */\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnInit,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\n\nimport { FwSnackbarMessage } from '../snackbar-message.model';\nimport { FwSnackbarTimerService } from '../snackbar-timer.service';\n\n@Component({\n  selector: 'fw-snackbar',\n  styleUrls: ['./snackbar.component.scss'],\n  templateUrl: './snackbar.component.html',\n  providers: [FwSnackbarTimerService],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\n\nexport class FwSnackbarComponent implements AfterViewInit, OnInit {\n  @Input() message: FwSnackbarMessage;\n  @Input() messageDuration: number = 9000;\n  @Output() ready = new EventEmitter<FwSnackbarComponent>();\n  @Output() dismiss = new EventEmitter<string>();\n  @Output() action = new EventEmitter<string>();\n  color: 'primary' | 'success' | 'warning' | 'danger' = 'primary';\n\n  @HostBinding('class') get cssClass(): string {\n    const cssClass = 'fw-snackbar';\n    if (this.message?.severity) {\n      return cssClass + ' ' + this.color;\n    } else {\n      return cssClass;\n    }\n  }\n\n  constructor(private cdr: ChangeDetectorRef, private timerService: FwSnackbarTimerService) {\n  }\n\n  ngAfterViewInit(): void {\n    this.ready.emit(this);\n    this.cdr.markForCheck();\n  }\n\n  startTimer(): void {\n    if (this.message && this.message.duration) {\n      this.messageDuration = this.message.duration;\n    }\n    this.timerService.start(this.messageDuration).then(() => {\n      this.handleDismiss();\n      this.cdr.markForCheck();\n    });\n  }\n\n  stopTimer(): void {\n    this.timerService.stop();\n    this.cdr.markForCheck();\n  }\n\n  ngOnInit(): void {\n    switch (this.message.severity) {\n      case 'success':\n        if (!this.message.icon) {\n          this.message.icon = 'done-check-tracked';\n        }\n        this.color = 'success';\n        break;\n      case 'warning':\n        if (!this.message.icon) {\n          this.message.icon = 'warning-circle';\n        }\n        this.color = 'warning';\n        break;\n      case 'error':\n        if (!this.message.icon) {\n          this.message.icon = 'warning';\n        }\n        if (this.message.showClose === undefined) {\n          this.message.showClose = true;\n        }\n        if (!this.message.duration) {\n          this.message.duration = 29000;\n        }\n        this.color = 'danger';\n        break;\n      case 'info':\n        if (!this.message.icon) {\n          this.message.icon = 'information-circle';\n        }\n        this.color = 'primary';\n        break;\n    }\n  }\n\n  handleDismiss(): void {\n    this.dismiss.emit(this.message.id);\n    this.cdr.markForCheck();\n  }\n\n  handleAction(): void {\n    this.action.emit(this.message.id);\n    if (this.message.action) {\n      this.message.action();\n    }\n    this.cdr.markForCheck();\n  }\n\n}\n","<ng-container *ngIf=\"message\">\n  <fw-icon *ngIf=\"message.icon\">{{ message.icon }}</fw-icon>\n  <h4 class=\"vision-h4\" *ngIf=\"message.message\">{{ message.message }}</h4>\n  <fw-button\n    *ngIf=\"message.actionText\" variant=\"ghost\"\n    [color]=\"color\" size=\"small\"\n    (click)=\"handleAction()\">{{ message.actionText }}\n  </fw-button>\n  <fw-icon-button\n    *ngIf=\"message.showClose\"\n    icon=\"close\" size=\"small\" [color]=\"message.severity\"\n    (click)=\"handleDismiss()\">\n  </fw-icon-button>\n  <div *ngIf=\"!message.actionText && !message.showClose\"></div>\n</ng-container>\n"]}
95
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snackbar.component.js","sourceRoot":"","sources":["../../../../../../src/components/snackbar/snackbar/snackbar.component.ts","../../../../../../src/components/snackbar/snackbar/snackbar.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @rx-angular/no-explicit-change-detection-apis */\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  computed,\n  HostBinding,\n  input,\n  output,\n  TemplateRef,\n  ViewEncapsulation,\n} from '@angular/core';\n\nimport { FwButtonComponent } from '../../button/button.component';\nimport { IconType } from '../../icon/icon.types';\nimport { FwSnackbarMessage } from '../snackbar-message.model';\nimport { FwSnackbarTimerService } from '../snackbar-timer.service';\n\n@Component({\n  selector: 'fw-snackbar',\n  styleUrls: ['./snackbar.component.scss'],\n  templateUrl: './snackbar.component.html',\n  providers: [FwSnackbarTimerService],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\n\nexport class FwSnackbarComponent implements AfterViewInit {\n  message = input.required<FwSnackbarMessage>();\n  messageDuration = input(9000);\n  ready = output<FwSnackbarComponent>();\n  dismiss = output<string>();\n  action = output<string>();\n\n  private defaultIcons: Record<FwSnackbarMessage['severity'], IconType> = {\n    success: 'done-check-tracked',\n    warning: 'warning-circle',\n    error: 'warning',\n    info: 'information-circle',\n  };\n\n  icon = computed(() => this.message().icon || this.defaultIcons[this.message().severity]);\n\n  showClose = computed(() => {\n    const msg = this.message();\n    return msg.showClose !== undefined ? msg.showClose : msg.severity === 'error';\n  });\n\n  duration = computed(() => {\n    const msg = this.message();\n    if (msg.duration) {\n      return msg.duration;\n    }\n    return msg.severity === 'error' ? 29000 : this.messageDuration();\n  });\n\n  color = computed<FwButtonComponent['color']>(() => {\n    const severity = this.message().severity;\n    const colors: Record<FwSnackbarMessage['severity'], FwButtonComponent['color']> = {\n      success: 'success',\n      warning: 'warning',\n      error: 'danger',\n      info: 'primary',\n    }\n    return colors[severity] || 'primary';\n  });\n\n  isTemplateRef = computed(() => this.message().message instanceof TemplateRef);\n\n  @HostBinding('class') get cssClass(): string {\n    const cssClass = 'fw-snackbar';\n    const severity = this.message()?.severity;\n    if (severity) {\n      return cssClass + ' ' + this.color();\n    } else {\n      return cssClass;\n    }\n  }\n\n  constructor(private cdr: ChangeDetectorRef, private timerService: FwSnackbarTimerService) {\n  }\n\n  ngAfterViewInit(): void {\n    this.ready.emit(this);\n    this.cdr.markForCheck();\n  }\n\n  startTimer(): void {\n    this.timerService.start(this.duration()).then(() => {\n      this.handleDismiss();\n      this.cdr.markForCheck();\n    });\n  }\n\n  stopTimer(): void {\n    this.timerService.stop();\n    this.cdr.markForCheck();\n  }\n\n  handleDismiss(): void {\n    this.dismiss.emit(this.message().id);\n    this.cdr.markForCheck();\n  }\n\n  handleAction(): void {\n    const msg = this.message();\n    this.action.emit(msg.id);\n    if (msg.action) {\n      msg.action();\n    }\n    this.cdr.markForCheck();\n  }\n\n}\n","@if (message(); as msg) {\n  @if (icon()) {\n    <fw-icon>{{ icon() }}</fw-icon>\n  }\n  @if (isTemplateRef()) {\n    <ng-container *ngTemplateOutlet=\"$any(msg.message); context: msg.templateContext\"></ng-container>\n  } @else {\n    @if (msg.message) {\n      <h4 class=\"vision-h4\">{{ msg.message }}</h4>\n    }\n  }\n  @if (msg.actionText) {\n    <fw-button\n      size=\"small\"\n      variant=\"ghost\"\n      [color]=\"color()\"\n      (click)=\"handleAction()\"\n    >\n      {{ msg.actionText }}\n    </fw-button>\n  }\n  @if (showClose()) {\n    <fw-icon-button\n      icon=\"close\"\n      size=\"small\"\n      [color]=\"msg.severity\"\n      (click)=\"handleDismiss()\"\n    ></fw-icon-button>\n  }\n  @if (!msg.actionText && !showClose()) {\n    <div></div>\n  }\n}\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25hY2tiYXItbWVzc2FnZS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3NuYWNrYmFyL3NuYWNrYmFyLW1lc3NhZ2UubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZ3U25hY2tiYXJDb21wb25lbnQgfSBmcm9tICcuL3NuYWNrYmFyL3NuYWNrYmFyLmNvbXBvbmVudCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRndTbmFja2Jhck1lc3NhZ2Uge1xuICBpZD86IHN0cmluZztcbiAgc2V2ZXJpdHk6ICdpbmZvJyB8ICdzdWNjZXNzJyB8ICd3YXJuaW5nJyB8ICdlcnJvcic7XG4gIG1lc3NhZ2U6IHN0cmluZztcbiAgaWNvbj86IHN0cmluZztcbiAgc2hvd0Nsb3NlPzogYm9vbGVhbjtcbiAgYWN0aW9uVGV4dD86IHN0cmluZyxcbiAgYWN0aW9uPzogKCkgPT4gdm9pZDtcbiAgZHVyYXRpb24/OiBudW1iZXI7XG4gIHJlZj86IEZ3U25hY2tiYXJDb21wb25lbnQ7XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25hY2tiYXItbWVzc2FnZS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3NuYWNrYmFyL3NuYWNrYmFyLW1lc3NhZ2UubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEZ3U25hY2tiYXJDb21wb25lbnQgfSBmcm9tICcuL3NuYWNrYmFyL3NuYWNrYmFyLmNvbXBvbmVudCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRndTbmFja2Jhck1lc3NhZ2Uge1xuICBpZD86IHN0cmluZztcbiAgc2V2ZXJpdHk6ICdpbmZvJyB8ICdzdWNjZXNzJyB8ICd3YXJuaW5nJyB8ICdlcnJvcic7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG4gIG1lc3NhZ2U6IHN0cmluZyB8IFRlbXBsYXRlUmVmPGFueT47XG4gIGljb24/OiBzdHJpbmc7XG4gIHNob3dDbG9zZT86IGJvb2xlYW47XG4gIGFjdGlvblRleHQ/OiBzdHJpbmcsXG4gIGFjdGlvbj86ICgpID0+IHZvaWQ7XG4gIGR1cmF0aW9uPzogbnVtYmVyO1xuICByZWY/OiBGd1NuYWNrYmFyQ29tcG9uZW50O1xuICB0ZW1wbGF0ZUNvbnRleHQ/OiBvYmplY3Q7XG59XG4iXX0=