@testgorilla/tgo-ui 3.12.2 → 3.12.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/components/donut-chart/donut-chart.component.d.ts +2 -2
- package/components/icon/icon-svg-content.d.ts +16 -0
- package/components/icon/icon.component.d.ts +1 -1
- package/components/segmented-bar/segmented-bar.component.d.ts +1 -0
- package/components/snackbar/snackbar.component.d.ts +1 -0
- package/esm2022/components/icon/icon-svg-content.mjs +489 -0
- package/esm2022/components/icon/icon.component.mjs +22 -6
- package/esm2022/components/segmented-bar/segmented-bar.component.mjs +8 -3
- package/esm2022/components/snackbar/snackbar.component.mjs +8 -7
- package/fesm2022/testgorilla-tgo-ui.mjs +522 -12
- package/fesm2022/testgorilla-tgo-ui.mjs.map +1 -1
- package/package.json +5 -1
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import { Component, HostBinding, Inject, Input, Optional, ViewEncapsulation } from '@angular/core';
|
|
1
|
+
import { Component, HostBinding, Inject, Input, Optional, ViewEncapsulation, } from '@angular/core';
|
|
2
|
+
import { getIconSvgContent } from './icon-svg-content';
|
|
2
3
|
import { tgoIcons, tgoRebrandIcons } from './icon.config';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
import * as i1 from "@angular/material/icon";
|
|
@@ -107,17 +108,32 @@ export class IconComponent {
|
|
|
107
108
|
this._name = this.name;
|
|
108
109
|
filename = this.name;
|
|
109
110
|
}
|
|
110
|
-
const
|
|
111
|
+
const isRebrand = this.applicationTheme !== 'classic';
|
|
111
112
|
if (filename && !this.iconsService.isIconLoaded(filename)) {
|
|
112
|
-
|
|
113
|
-
|
|
113
|
+
const svgContent = getIconSvgContent(filename, isRebrand);
|
|
114
|
+
if (svgContent) {
|
|
115
|
+
// Icon is available inline - use it directly
|
|
116
|
+
this.matIconRegistry.addSvgIconLiteral(filename, this.domSanitzer.bypassSecurityTrustHtml(svgContent));
|
|
117
|
+
this.iconsService.addIcon(filename);
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
// Icon not found inline - fallback to HTTP request
|
|
121
|
+
// This happens for large icons (>10KB) that are excluded from the bundle
|
|
122
|
+
const path = this.applicationTheme === 'classic' ? '/icons/' : '/icons/rebrand/';
|
|
123
|
+
this.matIconRegistry.addSvgIcon(filename, this.domSanitzer.bypassSecurityTrustResourceUrl(`${path}${filename}.svg`));
|
|
124
|
+
this.iconsService.addIcon(filename);
|
|
125
|
+
}
|
|
114
126
|
}
|
|
115
127
|
}
|
|
116
128
|
get cssStyle() {
|
|
117
129
|
return { '--icon-color': this.color };
|
|
118
130
|
}
|
|
119
131
|
get filledIconName() {
|
|
120
|
-
return this.name?.includes('filled')
|
|
132
|
+
return this.name?.includes('filled')
|
|
133
|
+
? this.name
|
|
134
|
+
: this.name.includes('in-line')
|
|
135
|
+
? this.name.replace('in-line', 'filled')
|
|
136
|
+
: `${this.name}-filled`;
|
|
121
137
|
}
|
|
122
138
|
get inlineIconName() {
|
|
123
139
|
return this.name?.includes('in-line') ? this.name : `${this.name}-in-line`;
|
|
@@ -159,4 +175,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
159
175
|
}], useFullIconName: [{
|
|
160
176
|
type: Input
|
|
161
177
|
}] } });
|
|
162
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/icon/icon.component.ts","../../../../../projects/tgo-canopy-ui/components/icon/icon.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  HostBinding,\n  Inject,\n  Input,\n  OnInit,\n  Optional,\n  SimpleChanges,\n  ViewEncapsulation\n} from '@angular/core';\nimport { MatIconRegistry } from '@angular/material/icon';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { tgoIcons, tgoRebrandIcons } from './icon.config';\nimport { IconColor, IconName, IconSize } from './icon.model';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { IconsService } from '../../services/icons.service';\n\n@Component({\n  selector: 'ui-icon',\n  templateUrl: './icon.component.html',\n  styleUrls: ['./icon.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class IconComponent implements OnInit {\n  /**\n   * Icon size\n   *\n   * @type {IconSize}\n   * @memberof IconComponent\n   */\n  @HostBinding('style.--icon-size')\n  @Input() size: IconSize = '16';\n\n  /**\n   * Icon css class\n   *\n   * @memberof IconComponent\n   */\n  @Input() cssClass = '';\n\n  /**\n   * Icon name\n   *\n   * @type {IconName}\n   * @memberof IconComponent\n   */\n  @Input() name: IconName;\n\n  /**\n   * Icon color\n   *\n   * @type {IconColor}\n   * @memberof IconComponent\n   */\n  @Input() color?: IconColor = 'black';\n\n  /**\n   * Icon filled\n   *\n   * @type {boolean}\n   * @memberof IconComponent\n   */\n  @Input() filled = false;\n\n  @Input() toggleIconStyle = false;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof IconComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n\n  @Input() useFullIconName = true;\n\n  customCssClass: string;\n  filename: IconName | undefined;\n  _name: string;\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private matIconRegistry: MatIconRegistry,\n    private domSanitzer: DomSanitizer,\n    private iconsService: IconsService\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  ngOnInit(): void {\n    this.customCssClass = this.setCssClass();\n    this.addIcon();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['size'] || changes['cssClass'] || changes['color'] ) {\n      this.customCssClass = this.setCssClass();\n    }\n    if (changes['name'] || changes['filled'] || changes['applicationTheme']) {\n      this.addIcon();\n    }\n  }\n\n  //set css class for size\n  setCssClass(): string {\n    return `${this.cssClass} size-${this.size} ${this.color}`;\n  }\n\n  //Add icon to matIcon registry\n  addIcon() {\n    let filename: IconName | undefined;\n    if (!this.useFullIconName) {\n      if (this.filled || this.name?.includes('filled')) {\n        this._name = this.name.replace(/-in-line/, '') as IconName;\n        filename =\n          this.applicationTheme === 'classic'\n            ? tgoIcons.find(icon => icon === this.filledIconName)\n            : tgoRebrandIcons.find(icon => icon === this.filledIconName);\n      } else {\n        filename =\n          this.applicationTheme === 'classic'\n            ? (this.name?.replace(/-filled|-in-line/, '') as IconName)\n            : (this.inlineIconFileName as IconName);\n      }\n\n      if (!filename) {\n        filename = tgoIcons.find(icon => icon === this._name);\n      }\n\n      this._name = filename as IconName;\n    } else {\n      if (this.applicationTheme !== 'classic') {\n        const hasInline = this.name?.includes('-in-line');\n        const hasFilled = this.name?.includes('filled');\n\n        if (!hasInline && !hasFilled) {\n          this.name = `${this.name}-in-line` as IconName;\n        } else if (!hasInline && hasFilled && this.toggleIconStyle) {\n          this.name = this.name.replace(/-filled/, '-in-line') as IconName;\n        } else if (hasInline && !hasFilled && this.toggleIconStyle && this.filled) {\n          this.name = this.name.replace(/-in-line/, '-filled') as IconName;\n        }\n      }\n\n      this._name = this.name;\n      filename = this.name as IconName;\n    }\n\n    const path = this.applicationTheme === 'classic' ? '/icons/' : '/icons/rebrand/';\n\n    if (filename && !this.iconsService.isIconLoaded(filename)) {\n      this.matIconRegistry.addSvgIcon(\n        filename,\n        this.domSanitzer.bypassSecurityTrustResourceUrl(`${path}${filename}.svg`)\n      );\n      this.iconsService.addIcon(filename);\n    }\n  }\n\n  get cssStyle(): Record<string, string | undefined> {\n    return { '--icon-color': this.color }\n  }\n\n  get filledIconName() {\n    return this.name?.includes('filled') ? this.name : this.name.includes('in-line') ? this.name.replace('in-line', 'filled') : `${this.name}-filled`;\n  }\n\n  get inlineIconName() {\n    return this.name?.includes('in-line') ? this.name : `${this.name}-in-line`;\n  }\n\n  get inlineIconFileName() {\n    return this.name?.includes('filled') ? this.name.replace('filled', 'in-line') : this.inlineIconName;\n  }\n\n  get isIconLoaded(): boolean {\n    return this.iconsService.isIconLoaded(this._name);\n  }\n}\n","@if (isIconLoaded) {\n  <mat-icon [svgIcon]=\"_name\" [attr.class]=\"customCssClass\" [ngStyle]=\"cssStyle\"></mat-icon>\n} @else {\n  <div class=\"empty-icon-placeholder\"></div>\n}\n"]}
|
|
178
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/icon/icon.component.ts","../../../../../projects/tgo-canopy-ui/components/icon/icon.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  HostBinding,\n  Inject,\n  Input,\n  OnInit,\n  Optional,\n  SimpleChanges,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { MatIconRegistry } from '@angular/material/icon';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { IconsService } from '../../services/icons.service';\nimport { getIconSvgContent } from './icon-svg-content';\nimport { tgoIcons, tgoRebrandIcons } from './icon.config';\nimport { IconColor, IconName, IconSize } from './icon.model';\n\n@Component({\n  selector: 'ui-icon',\n  templateUrl: './icon.component.html',\n  styleUrls: ['./icon.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class IconComponent implements OnInit {\n  /**\n   * Icon size\n   *\n   * @type {IconSize}\n   * @memberof IconComponent\n   */\n  @HostBinding('style.--icon-size')\n  @Input()\n  size: IconSize = '16';\n\n  /**\n   * Icon css class\n   *\n   * @memberof IconComponent\n   */\n  @Input() cssClass = '';\n\n  /**\n   * Icon name\n   *\n   * @type {IconName}\n   * @memberof IconComponent\n   */\n  @Input() name: IconName;\n\n  /**\n   * Icon color\n   *\n   * @type {IconColor}\n   * @memberof IconComponent\n   */\n  @Input() color?: IconColor = 'black';\n\n  /**\n   * Icon filled\n   *\n   * @type {boolean}\n   * @memberof IconComponent\n   */\n  @Input() filled = false;\n\n  @Input() toggleIconStyle = false;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof IconComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  @Input() useFullIconName = true;\n\n  customCssClass: string;\n  filename: IconName | undefined;\n  _name: string;\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private matIconRegistry: MatIconRegistry,\n    private domSanitzer: DomSanitizer,\n    private iconsService: IconsService\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  ngOnInit(): void {\n    this.customCssClass = this.setCssClass();\n    this.addIcon();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['size'] || changes['cssClass'] || changes['color']) {\n      this.customCssClass = this.setCssClass();\n    }\n    if (changes['name'] || changes['filled'] || changes['applicationTheme']) {\n      this.addIcon();\n    }\n  }\n\n  //set css class for size\n  setCssClass(): string {\n    return `${this.cssClass} size-${this.size} ${this.color}`;\n  }\n\n  //Add icon to matIcon registry\n  addIcon() {\n    let filename: IconName | undefined;\n    if (!this.useFullIconName) {\n      if (this.filled || this.name?.includes('filled')) {\n        this._name = this.name.replace(/-in-line/, '') as IconName;\n        filename =\n          this.applicationTheme === 'classic'\n            ? tgoIcons.find(icon => icon === this.filledIconName)\n            : tgoRebrandIcons.find(icon => icon === this.filledIconName);\n      } else {\n        filename =\n          this.applicationTheme === 'classic'\n            ? (this.name?.replace(/-filled|-in-line/, '') as IconName)\n            : (this.inlineIconFileName as IconName);\n      }\n\n      if (!filename) {\n        filename = tgoIcons.find(icon => icon === this._name);\n      }\n\n      this._name = filename as IconName;\n    } else {\n      if (this.applicationTheme !== 'classic') {\n        const hasInline = this.name?.includes('-in-line');\n        const hasFilled = this.name?.includes('filled');\n\n        if (!hasInline && !hasFilled) {\n          this.name = `${this.name}-in-line` as IconName;\n        } else if (!hasInline && hasFilled && this.toggleIconStyle) {\n          this.name = this.name.replace(/-filled/, '-in-line') as IconName;\n        } else if (hasInline && !hasFilled && this.toggleIconStyle && this.filled) {\n          this.name = this.name.replace(/-in-line/, '-filled') as IconName;\n        }\n      }\n\n      this._name = this.name;\n      filename = this.name as IconName;\n    }\n\n    const isRebrand = this.applicationTheme !== 'classic';\n\n    if (filename && !this.iconsService.isIconLoaded(filename)) {\n      const svgContent = getIconSvgContent(filename, isRebrand);\n\n      if (svgContent) {\n        // Icon is available inline - use it directly\n        this.matIconRegistry.addSvgIconLiteral(filename, this.domSanitzer.bypassSecurityTrustHtml(svgContent));\n        this.iconsService.addIcon(filename);\n      } else {\n        // Icon not found inline - fallback to HTTP request\n        // This happens for large icons (>10KB) that are excluded from the bundle\n        const path = this.applicationTheme === 'classic' ? '/icons/' : '/icons/rebrand/';\n        this.matIconRegistry.addSvgIcon(\n          filename,\n          this.domSanitzer.bypassSecurityTrustResourceUrl(`${path}${filename}.svg`)\n        );\n        this.iconsService.addIcon(filename);\n      }\n    }\n  }\n\n  get cssStyle(): Record<string, string | undefined> {\n    return { '--icon-color': this.color };\n  }\n\n  get filledIconName() {\n    return this.name?.includes('filled')\n      ? this.name\n      : this.name.includes('in-line')\n        ? this.name.replace('in-line', 'filled')\n        : `${this.name}-filled`;\n  }\n\n  get inlineIconName() {\n    return this.name?.includes('in-line') ? this.name : `${this.name}-in-line`;\n  }\n\n  get inlineIconFileName() {\n    return this.name?.includes('filled') ? this.name.replace('filled', 'in-line') : this.inlineIconName;\n  }\n\n  get isIconLoaded(): boolean {\n    return this.iconsService.isIconLoaded(this._name);\n  }\n}\n","@if (isIconLoaded) {\n  <mat-icon [svgIcon]=\"_name\" [attr.class]=\"customCssClass\" [ngStyle]=\"cssStyle\"></mat-icon>\n} @else {\n  <div class=\"empty-icon-placeholder\"></div>\n}\n"]}
|
|
@@ -76,12 +76,17 @@ export class SegmentedBarComponent {
|
|
|
76
76
|
return { ...segment, percentage: percentageLabel };
|
|
77
77
|
});
|
|
78
78
|
}
|
|
79
|
+
get accessibleValueText() {
|
|
80
|
+
return this.segmentList
|
|
81
|
+
.map((segment, index) => `${segment.tooltip || `Value ${index}`}: ${segment.value}`)
|
|
82
|
+
.join(', ');
|
|
83
|
+
}
|
|
79
84
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SegmentedBarComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
80
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: SegmentedBarComponent, selector: "ui-segmented-bar", inputs: { width: "width", size: "size", segments: "segments", applicationTheme: "applicationTheme", ariaLabel: "ariaLabel", ariaRequired: "ariaRequired", tooltipStats: "tooltipStats" }, ngImport: i0, template: "<div\n class=\"segmented-bar-container\"\n [attr.theme]=\"applicationTheme\"\n [ngClass]=\"'segment-size-' + size\"\n [style.width]=\"width\"\n [uiTooltipTemplate]=\"segmentedStats\"\n [showTooltip]=\"tooltipStats\"\n>\n <ng-container *ngFor=\"let segment of segmentList\">\n <div\n class=\"segmented-bar\"\n *ngIf=\"segment.value\"\n [ngClass]=\"segment.color\"\n [ngStyle]=\"{ flex: segment.value }\"\n [matTooltip]=\"!tooltipStats ? segment.tooltip ?? '' : ''\"\n [matTooltipClass]=\"applicationTheme\"\n [attr.aria-
|
|
85
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: SegmentedBarComponent, selector: "ui-segmented-bar", inputs: { width: "width", size: "size", segments: "segments", applicationTheme: "applicationTheme", ariaLabel: "ariaLabel", ariaRequired: "ariaRequired", tooltipStats: "tooltipStats" }, ngImport: i0, template: "<div\n class=\"segmented-bar-container\"\n [attr.theme]=\"applicationTheme\"\n [ngClass]=\"'segment-size-' + size\"\n [style.width]=\"width\"\n [uiTooltipTemplate]=\"segmentedStats\"\n [showTooltip]=\"tooltipStats\"\n [attr.aria-label]=\"accessibleValueText\"\n role=\"graphics-object\"\n [tabIndex]=\"0\"\n>\n <ng-container *ngFor=\"let segment of segmentList\">\n <div\n class=\"segmented-bar\"\n *ngIf=\"segment.value\"\n [ngClass]=\"segment.color\"\n [ngStyle]=\"{ flex: segment.value }\"\n [matTooltip]=\"!tooltipStats ? segment.tooltip ?? '' : ''\"\n [matTooltipClass]=\"applicationTheme\"\n [attr.aria-hidden]=\"true\"\n [attr.aria-required]=\"ariaRequired\"\n >\n <ui-icon *ngIf=\"segment.icon\" [applicationTheme]=\"applicationTheme\" [name]=\"segment.icon\"></ui-icon>\n <span>{{ segment.value }}</span>\n </div>\n </ng-container>\n</div>\n<ng-template #segmentedStats>\n <div class=\"stats-container\">\n <div class=\"name-column\">\n @for (segment of segmentList; track segment.value) {\n <div class=\"segment\">\n <div [class]=\"'point ' + segment.color\"></div>\n <span [class]=\"'label ' + segment.color\">{{ segment.tooltip }}</span>\n </div>\n }\n </div>\n\n <div class=\"value-column\">\n @for (segment of segmentList; track segment.value) {\n <div class=\"segment\">\n <span>{{ segment.value }}</span>\n </div>\n }\n </div>\n\n <div class=\"percentage-column\">\n @for (segment of segmentList; track segment.value) {\n <div class=\"segment\">\n <span>{{ segment.percentage }}</span>\n </div>\n }\n </div>\n\n </div>\n</ng-template>\n\n<ng-template #segmentedStats>\n <div class=\"stats-container\">\n <div class=\"name-column\">\n @for (segment of segmentList; track segment.value) {\n <div class=\"segment\">\n <div [class]=\"'point ' + segment.color\"></div>\n <span [class]=\"'label ' + segment.color\">{{ segment.tooltip }}</span>\n </div>\n }\n </div>\n\n <div class=\"value-column\">\n @for (segment of segmentList; track segment.value) {\n <div class=\"segment\">\n <span>{{ segment.value }}</span>\n </div>\n }\n </div>\n\n <div class=\"percentage-column\">\n @for (segment of segmentList; track segment.value) {\n <div class=\"segment\">\n <span>{{ segment.percentage }}</span>\n </div>\n }\n </div>\n\n </div>\n</ng-template>\n\n", styles: ["@import\"https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600;1,700&display=swap\";.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}.segmented-bar-container{width:100%;display:flex;flex-direction:row}.segmented-bar-container.segment-size-small{height:16px}.segmented-bar-container.segment-size-large{height:30px}.segmented-bar-container .segmented-bar{color:#000;font-weight:700;display:flex;justify-content:center;align-items:center;background:#46a997}.segmented-bar-container .segmented-bar ui-icon{margin-right:4px}.segmented-bar-container .segmented-bar.teal{background:#46a997}.segmented-bar-container .segmented-bar.rhubarb{background:#cb7b7a}.segmented-bar-container .segmented-bar.light-teal{background:#cbd6cb}.segmented-bar-container .segmented-bar.grey{background:#ededed}.segmented-bar-container[theme=dark].segment-size-small,.segmented-bar-container[theme=light].segment-size-small{font-size:12px}.segmented-bar-container[theme=dark].segment-size-large,.segmented-bar-container[theme=light].segment-size-large{font-size:14px}.segmented-bar-container[theme=dark] .segmented-bar,.segmented-bar-container[theme=light] .segmented-bar{padding:0 4px;color:#242424;background:#80d63e}.segmented-bar-container[theme=dark] .segmented-bar.teal,.segmented-bar-container[theme=light] .segmented-bar.teal{background:#80d63e}.segmented-bar-container[theme=dark] .segmented-bar.rhubarb,.segmented-bar-container[theme=light] .segmented-bar.rhubarb{background:#ffac9a}.segmented-bar-container[theme=dark] .segmented-bar.light-teal,.segmented-bar-container[theme=light] .segmented-bar.light-teal{background:#ffe1b3}.segmented-bar-container[theme=dark] .segmented-bar.grey,.segmented-bar-container[theme=light] .segmented-bar.grey{background:#e9e9e9}::ng-deep .mat-mdc-tooltip{background-color:#a9c2c9;font-family:Open Sans,serif;font-weight:400;font-size:12px;border-radius:4px;overflow:visible;max-width:248px;padding:6px 2px;--mdc-plain-tooltip-container-color: none;--mdc-plain-tooltip-supporting-text-color: $tgo-black}.stats-container{display:flex;flex-direction:row;max-width:248px}.stats-container .segment{display:flex;flex-direction:row;align-items:center}.stats-container .segment .point{margin-right:4px;width:8px;height:8px;border-radius:50%}.stats-container .segment .point.teal{background:#80d63e}.stats-container .segment .point.rhubarb{background:#ffac9a}.stats-container .segment .point.light-teal{background:#ffe1b3}.stats-container .segment .point.grey{background:#e9e9e9}.stats-container .segment .label{margin-right:8px}.stats-container .segment .label.teal{color:#80d63e}.stats-container .segment .label.rhubarb{color:#ffac9a}.stats-container .segment .label.light-teal{color:#ffe1b3}.stats-container .segment .label.grey{color:#e9e9e9}.stats-container .name-column span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.stats-container .value-column{margin-right:8px;color:#fff;min-width:28px}.stats-container .percentage-column{min-width:28px;color:#919191}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: i3.IconComponent, selector: "ui-icon", inputs: ["size", "cssClass", "name", "color", "filled", "toggleIconStyle", "applicationTheme", "useFullIconName"] }, { kind: "directive", type: i4.TooltipTemplateDirective, selector: "[uiTooltipTemplate]", inputs: ["tooltipPosition", "showTooltip", "uiTooltipTemplate"] }] }); }
|
|
81
86
|
}
|
|
82
87
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SegmentedBarComponent, decorators: [{
|
|
83
88
|
type: Component,
|
|
84
|
-
args: [{ selector: 'ui-segmented-bar', template: "<div\n class=\"segmented-bar-container\"\n [attr.theme]=\"applicationTheme\"\n [ngClass]=\"'segment-size-' + size\"\n [style.width]=\"width\"\n [uiTooltipTemplate]=\"segmentedStats\"\n [showTooltip]=\"tooltipStats\"\n>\n <ng-container *ngFor=\"let segment of segmentList\">\n <div\n class=\"segmented-bar\"\n *ngIf=\"segment.value\"\n [ngClass]=\"segment.color\"\n [ngStyle]=\"{ flex: segment.value }\"\n [matTooltip]=\"!tooltipStats ? segment.tooltip ?? '' : ''\"\n [matTooltipClass]=\"applicationTheme\"\n [attr.aria-
|
|
89
|
+
args: [{ selector: 'ui-segmented-bar', template: "<div\n class=\"segmented-bar-container\"\n [attr.theme]=\"applicationTheme\"\n [ngClass]=\"'segment-size-' + size\"\n [style.width]=\"width\"\n [uiTooltipTemplate]=\"segmentedStats\"\n [showTooltip]=\"tooltipStats\"\n [attr.aria-label]=\"accessibleValueText\"\n role=\"graphics-object\"\n [tabIndex]=\"0\"\n>\n <ng-container *ngFor=\"let segment of segmentList\">\n <div\n class=\"segmented-bar\"\n *ngIf=\"segment.value\"\n [ngClass]=\"segment.color\"\n [ngStyle]=\"{ flex: segment.value }\"\n [matTooltip]=\"!tooltipStats ? segment.tooltip ?? '' : ''\"\n [matTooltipClass]=\"applicationTheme\"\n [attr.aria-hidden]=\"true\"\n [attr.aria-required]=\"ariaRequired\"\n >\n <ui-icon *ngIf=\"segment.icon\" [applicationTheme]=\"applicationTheme\" [name]=\"segment.icon\"></ui-icon>\n <span>{{ segment.value }}</span>\n </div>\n </ng-container>\n</div>\n<ng-template #segmentedStats>\n <div class=\"stats-container\">\n <div class=\"name-column\">\n @for (segment of segmentList; track segment.value) {\n <div class=\"segment\">\n <div [class]=\"'point ' + segment.color\"></div>\n <span [class]=\"'label ' + segment.color\">{{ segment.tooltip }}</span>\n </div>\n }\n </div>\n\n <div class=\"value-column\">\n @for (segment of segmentList; track segment.value) {\n <div class=\"segment\">\n <span>{{ segment.value }}</span>\n </div>\n }\n </div>\n\n <div class=\"percentage-column\">\n @for (segment of segmentList; track segment.value) {\n <div class=\"segment\">\n <span>{{ segment.percentage }}</span>\n </div>\n }\n </div>\n\n </div>\n</ng-template>\n\n<ng-template #segmentedStats>\n <div class=\"stats-container\">\n <div class=\"name-column\">\n @for (segment of segmentList; track segment.value) {\n <div class=\"segment\">\n <div [class]=\"'point ' + segment.color\"></div>\n <span [class]=\"'label ' + segment.color\">{{ segment.tooltip }}</span>\n </div>\n }\n </div>\n\n <div class=\"value-column\">\n @for (segment of segmentList; track segment.value) {\n <div class=\"segment\">\n <span>{{ segment.value }}</span>\n </div>\n }\n </div>\n\n <div class=\"percentage-column\">\n @for (segment of segmentList; track segment.value) {\n <div class=\"segment\">\n <span>{{ segment.percentage }}</span>\n </div>\n }\n </div>\n\n </div>\n</ng-template>\n\n", styles: ["@import\"https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600;1,700&display=swap\";.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}.segmented-bar-container{width:100%;display:flex;flex-direction:row}.segmented-bar-container.segment-size-small{height:16px}.segmented-bar-container.segment-size-large{height:30px}.segmented-bar-container .segmented-bar{color:#000;font-weight:700;display:flex;justify-content:center;align-items:center;background:#46a997}.segmented-bar-container .segmented-bar ui-icon{margin-right:4px}.segmented-bar-container .segmented-bar.teal{background:#46a997}.segmented-bar-container .segmented-bar.rhubarb{background:#cb7b7a}.segmented-bar-container .segmented-bar.light-teal{background:#cbd6cb}.segmented-bar-container .segmented-bar.grey{background:#ededed}.segmented-bar-container[theme=dark].segment-size-small,.segmented-bar-container[theme=light].segment-size-small{font-size:12px}.segmented-bar-container[theme=dark].segment-size-large,.segmented-bar-container[theme=light].segment-size-large{font-size:14px}.segmented-bar-container[theme=dark] .segmented-bar,.segmented-bar-container[theme=light] .segmented-bar{padding:0 4px;color:#242424;background:#80d63e}.segmented-bar-container[theme=dark] .segmented-bar.teal,.segmented-bar-container[theme=light] .segmented-bar.teal{background:#80d63e}.segmented-bar-container[theme=dark] .segmented-bar.rhubarb,.segmented-bar-container[theme=light] .segmented-bar.rhubarb{background:#ffac9a}.segmented-bar-container[theme=dark] .segmented-bar.light-teal,.segmented-bar-container[theme=light] .segmented-bar.light-teal{background:#ffe1b3}.segmented-bar-container[theme=dark] .segmented-bar.grey,.segmented-bar-container[theme=light] .segmented-bar.grey{background:#e9e9e9}::ng-deep .mat-mdc-tooltip{background-color:#a9c2c9;font-family:Open Sans,serif;font-weight:400;font-size:12px;border-radius:4px;overflow:visible;max-width:248px;padding:6px 2px;--mdc-plain-tooltip-container-color: none;--mdc-plain-tooltip-supporting-text-color: $tgo-black}.stats-container{display:flex;flex-direction:row;max-width:248px}.stats-container .segment{display:flex;flex-direction:row;align-items:center}.stats-container .segment .point{margin-right:4px;width:8px;height:8px;border-radius:50%}.stats-container .segment .point.teal{background:#80d63e}.stats-container .segment .point.rhubarb{background:#ffac9a}.stats-container .segment .point.light-teal{background:#ffe1b3}.stats-container .segment .point.grey{background:#e9e9e9}.stats-container .segment .label{margin-right:8px}.stats-container .segment .label.teal{color:#80d63e}.stats-container .segment .label.rhubarb{color:#ffac9a}.stats-container .segment .label.light-teal{color:#ffe1b3}.stats-container .segment .label.grey{color:#e9e9e9}.stats-container .name-column span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.stats-container .value-column{margin-right:8px;color:#fff;min-width:28px}.stats-container .percentage-column{min-width:28px;color:#919191}\n"] }]
|
|
85
90
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
86
91
|
type: Optional
|
|
87
92
|
}, {
|
|
@@ -103,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
103
108
|
}], tooltipStats: [{
|
|
104
109
|
type: Input
|
|
105
110
|
}] } });
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"segmented-bar.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/segmented-bar/segmented-bar.component.ts","../../../../../projects/tgo-canopy-ui/components/segmented-bar/segmented-bar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;;;;;;AASnE,MAAM,OAAO,qBAAqB;IAmBhC;;;;;OAKG;IACH,IAA+B,QAAQ,CAAC,QAAwB;QAC/D,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,CAAC;IACxD,CAAC;IAqCD,YAC6E,eAAiC;QAAjC,oBAAe,GAAf,eAAe,CAAkB;QAhE9G;;;;;;WAMG;QACM,UAAK,GAAG,MAAM,CAAC;QAExB;;;;;;WAMG;QACM,SAAI,GAAwB,OAAO,CAAC;QAY7C;;;;;;WAMG;QACM,qBAAgB,GAAqB,OAAO,CAAC;QAUtD;;;;;WAKG;QACM,iBAAY,GAAG,KAAK,CAAC;QAE9B;;;;;WAKG;QACM,iBAAY,GAAG,KAAK,CAAC;QAE9B,gBAAW,GAAiC,EAAE,CAAC;QAK7C,IAAI,eAAe,EAAE,CAAC;YACpB,IAAI,CAAC,gBAAgB,GAAG,eAAe,CAAC;QAC1C,CAAC;IACH,CAAC;IAED,oBAAoB,CAAC,QAAwB;QAC3C,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,OAAO,EAAE,EAAE,CAAC,GAAG,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QACxE,OAAO,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;YAC5B,IAAI,UAAU,GAAG,CAAC,OAAO,CAAC,KAAK,GAAG,KAAK,CAAC,GAAG,GAAG,CAAC;YAC/C,IAAI,eAAe,GAAG,EAAE,CAAC;YAEzB,IAAI,UAAU,KAAK,CAAC,EAAE,CAAC;gBACrB,eAAe,GAAG,IAAI,CAAC;YACzB,CAAC;iBAAM,IAAI,UAAU,GAAG,CAAC,IAAI,UAAU,GAAG,CAAC,EAAE,CAAC;gBAC5C,eAAe,GAAG,KAAK,CAAC;YAC1B,CAAC;iBAAM,CAAC;gBACN,eAAe,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC;YAChD,CAAC;YAED,OAAO,EAAE,GAAG,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,CAAC;QACrD,CAAC,CAAC,CAAC;IACL,CAAC;+GAxFU,qBAAqB,kBAiEV,oCAAoC;mGAjE/C,qBAAqB,kPCTlC,k8EAoFA;;4FD3Ea,qBAAqB;kBALjC,SAAS;+BACE,kBAAkB;;0BAqEzB,QAAQ;;0BAAI,MAAM;2BAAC,oCAAoC;yCAzDjD,KAAK;sBAAb,KAAK;gBASG,IAAI;sBAAZ,KAAK;gBAQyB,QAAQ;sBAAtC,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAWhB,gBAAgB;sBAAxB,KAAK;gBAQG,SAAS;sBAAjB,KAAK;gBAQG,YAAY;sBAApB,KAAK;gBAQG,YAAY;sBAApB,KAAK","sourcesContent":["import { Component, Inject, Input, Optional } from '@angular/core';\nimport { SegmentedBar, SegmentedBarVariant, SegmentedBarWithPercentage } from './segmented-bar.model';\nimport { ApplicationTheme } from \"../../models/application-theme.model\";\n\n@Component({\n  selector: 'ui-segmented-bar',\n  templateUrl: './segmented-bar.component.html',\n  styleUrls: ['./segmented-bar.component.scss'],\n})\nexport class SegmentedBarComponent {\n  /**\n   * The width of the segmented bar. Defaults to '100%'.\n   * You can use '100%' or '100px' for this field. 100 is just an example\n   * @default '100%'\n   * @type {string}\n   * @memberof SegmentedBarComponent\n   */\n  @Input() width = '100%';\n\n  /**\n   * The size variant of the segmented bar. Can be 'small' or 'large'.\n   * Defaults to 'large'.\n   * @default 'large'\n   * @type {SegmentedBarVariant}\n   * @memberof SegmentedBarComponent\n   */\n  @Input() size: SegmentedBarVariant = 'large';\n\n  /**\n   * The segments to be displayed in the segmented bar.\n   * @required true\n   * @type {SegmentedBar}\n   * @memberof SegmentedBarComponent\n   */\n  @Input({ required: true }) set segments(segments: SegmentedBar[]) {\n   this.segmentList = this.calculatePercentages(segments);\n  }\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof SegmentedBarComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * A string representing the ARIA label for accessibility.\n   * This label is used to provide an accessible name for the input element.\n   * @type {string}\n   * @memberof SegmentedBarComponent\n   */\n  @Input() ariaLabel: string;\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 {boolean}\n   * @memberof SegmentedBarComponent\n   */\n  @Input() ariaRequired = false;\n\n  /**\n   * Groups the tooltips into one template\n   *\n   * @type {boolean}\n   * @memberof SegmentedBarComponent\n   */\n  @Input() tooltipStats = false;\n\n  segmentList: SegmentedBarWithPercentage[] = [];\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  calculatePercentages(segments: SegmentedBar[]): SegmentedBarWithPercentage[] {\n    const total = segments.reduce((sum, segment) => sum + segment.value, 0);\n    return segments.map(segment => {\n      let percentage = (segment.value / total) * 100;\n      let percentageLabel = '';\n\n      if (percentage === 0) {\n        percentageLabel = '0%';\n      } else if (percentage > 0 && percentage < 1) {\n        percentageLabel = '>1%';\n      } else {\n        percentageLabel = `${Math.ceil(percentage)}%`;\n      }\n\n      return { ...segment, percentage: percentageLabel };\n    });\n  }\n}\n","<div\n  class=\"segmented-bar-container\"\n  [attr.theme]=\"applicationTheme\"\n  [ngClass]=\"'segment-size-' + size\"\n  [style.width]=\"width\"\n  [uiTooltipTemplate]=\"segmentedStats\"\n  [showTooltip]=\"tooltipStats\"\n>\n  <ng-container *ngFor=\"let segment of segmentList\">\n    <div\n      class=\"segmented-bar\"\n      *ngIf=\"segment.value\"\n      [ngClass]=\"segment.color\"\n      [ngStyle]=\"{ flex: segment.value }\"\n      [matTooltip]=\"!tooltipStats ? segment.tooltip ?? '' : ''\"\n      [matTooltipClass]=\"applicationTheme\"\n      [attr.aria-label]=\"ariaLabel\"\n      [attr.aria-required]=\"ariaRequired\"\n    >\n      <ui-icon *ngIf=\"segment.icon\"  [applicationTheme]=\"applicationTheme\" [name]=\"segment.icon\"></ui-icon>\n      <span>{{ segment.value }}</span>\n    </div>\n  </ng-container>\n</div>\n<ng-template #segmentedStats>\n  <div class=\"stats-container\">\n    <div class=\"name-column\">\n      @for (segment of segmentList; track segment.value) {\n        <div class=\"segment\">\n          <div [class]=\"'point ' + segment.color\"></div>\n          <span [class]=\"'label ' + segment.color\">{{ segment.tooltip }}</span>\n        </div>\n      }\n    </div>\n\n    <div class=\"value-column\">\n      @for (segment of segmentList; track segment.value) {\n        <div class=\"segment\">\n          <span>{{ segment.value }}</span>\n        </div>\n      }\n    </div>\n\n    <div class=\"percentage-column\">\n      @for (segment of segmentList; track segment.value) {\n        <div class=\"segment\">\n          <span>{{ segment.percentage }}</span>\n        </div>\n      }\n    </div>\n\n  </div>\n</ng-template>\n\n<ng-template #segmentedStats>\n  <div class=\"stats-container\">\n    <div class=\"name-column\">\n      @for (segment of segmentList; track segment.value) {\n        <div class=\"segment\">\n          <div [class]=\"'point ' + segment.color\"></div>\n          <span [class]=\"'label ' + segment.color\">{{ segment.tooltip }}</span>\n        </div>\n      }\n    </div>\n\n    <div class=\"value-column\">\n      @for (segment of segmentList; track segment.value) {\n        <div class=\"segment\">\n          <span>{{ segment.value }}</span>\n        </div>\n      }\n    </div>\n\n    <div class=\"percentage-column\">\n      @for (segment of segmentList; track segment.value) {\n        <div class=\"segment\">\n          <span>{{ segment.percentage }}</span>\n        </div>\n      }\n    </div>\n\n  </div>\n</ng-template>\n\n"]}
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"segmented-bar.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/segmented-bar/segmented-bar.component.ts","../../../../../projects/tgo-canopy-ui/components/segmented-bar/segmented-bar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;;;;;;AASnE,MAAM,OAAO,qBAAqB;IAmBhC;;;;;OAKG;IACH,IAA+B,QAAQ,CAAC,QAAwB;QAC/D,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,CAAC;IACxD,CAAC;IAqCD,YAC6E,eAAiC;QAAjC,oBAAe,GAAf,eAAe,CAAkB;QAhE9G;;;;;;WAMG;QACM,UAAK,GAAG,MAAM,CAAC;QAExB;;;;;;WAMG;QACM,SAAI,GAAwB,OAAO,CAAC;QAY7C;;;;;;WAMG;QACM,qBAAgB,GAAqB,OAAO,CAAC;QAUtD;;;;;WAKG;QACM,iBAAY,GAAG,KAAK,CAAC;QAE9B;;;;;WAKG;QACM,iBAAY,GAAG,KAAK,CAAC;QAE9B,gBAAW,GAAiC,EAAE,CAAC;QAK7C,IAAI,eAAe,EAAE,CAAC;YACpB,IAAI,CAAC,gBAAgB,GAAG,eAAe,CAAC;QAC1C,CAAC;IACH,CAAC;IAED,oBAAoB,CAAC,QAAwB;QAC3C,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,OAAO,EAAE,EAAE,CAAC,GAAG,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QACxE,OAAO,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;YAC5B,IAAI,UAAU,GAAG,CAAC,OAAO,CAAC,KAAK,GAAG,KAAK,CAAC,GAAG,GAAG,CAAC;YAC/C,IAAI,eAAe,GAAG,EAAE,CAAC;YAEzB,IAAI,UAAU,KAAK,CAAC,EAAE,CAAC;gBACrB,eAAe,GAAG,IAAI,CAAC;YACzB,CAAC;iBAAM,IAAI,UAAU,GAAG,CAAC,IAAI,UAAU,GAAG,CAAC,EAAE,CAAC;gBAC5C,eAAe,GAAG,KAAK,CAAC;YAC1B,CAAC;iBAAM,CAAC;gBACN,eAAe,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC;YAChD,CAAC;YAED,OAAO,EAAE,GAAG,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,CAAC;QACrD,CAAC,CAAC,CAAC;IACL,CAAC;IAED,IAAI,mBAAmB;QACrB,OAAO,IAAI,CAAC,WAAW;aACpB,GAAG,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE,CAAC,GAAG,OAAO,CAAC,OAAO,IAAI,SAAS,KAAK,EAAE,KAAK,OAAO,CAAC,KAAK,EAAE,CAAC;aACnF,IAAI,CAAC,IAAI,CAAC,CAAC;IAChB,CAAC;+GA9FU,qBAAqB,kBAiEV,oCAAoC;mGAjE/C,qBAAqB,kPCTlC,2hFAuFA;;4FD9Ea,qBAAqB;kBALjC,SAAS;+BACE,kBAAkB;;0BAqEzB,QAAQ;;0BAAI,MAAM;2BAAC,oCAAoC;yCAzDjD,KAAK;sBAAb,KAAK;gBASG,IAAI;sBAAZ,KAAK;gBAQyB,QAAQ;sBAAtC,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAWhB,gBAAgB;sBAAxB,KAAK;gBAQG,SAAS;sBAAjB,KAAK;gBAQG,YAAY;sBAApB,KAAK;gBAQG,YAAY;sBAApB,KAAK","sourcesContent":["import { Component, Inject, Input, Optional } from '@angular/core';\nimport { SegmentedBar, SegmentedBarVariant, SegmentedBarWithPercentage } from './segmented-bar.model';\nimport { ApplicationTheme } from \"../../models/application-theme.model\";\n\n@Component({\n  selector: 'ui-segmented-bar',\n  templateUrl: './segmented-bar.component.html',\n  styleUrls: ['./segmented-bar.component.scss'],\n})\nexport class SegmentedBarComponent {\n  /**\n   * The width of the segmented bar. Defaults to '100%'.\n   * You can use '100%' or '100px' for this field. 100 is just an example\n   * @default '100%'\n   * @type {string}\n   * @memberof SegmentedBarComponent\n   */\n  @Input() width = '100%';\n\n  /**\n   * The size variant of the segmented bar. Can be 'small' or 'large'.\n   * Defaults to 'large'.\n   * @default 'large'\n   * @type {SegmentedBarVariant}\n   * @memberof SegmentedBarComponent\n   */\n  @Input() size: SegmentedBarVariant = 'large';\n\n  /**\n   * The segments to be displayed in the segmented bar.\n   * @required true\n   * @type {SegmentedBar}\n   * @memberof SegmentedBarComponent\n   */\n  @Input({ required: true }) set segments(segments: SegmentedBar[]) {\n   this.segmentList = this.calculatePercentages(segments);\n  }\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof SegmentedBarComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * A string representing the ARIA label for accessibility.\n   * This label is used to provide an accessible name for the input element.\n   * @type {string}\n   * @memberof SegmentedBarComponent\n   */\n  @Input() ariaLabel: string;\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 {boolean}\n   * @memberof SegmentedBarComponent\n   */\n  @Input() ariaRequired = false;\n\n  /**\n   * Groups the tooltips into one template\n   *\n   * @type {boolean}\n   * @memberof SegmentedBarComponent\n   */\n  @Input() tooltipStats = false;\n\n  segmentList: SegmentedBarWithPercentage[] = [];\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  calculatePercentages(segments: SegmentedBar[]): SegmentedBarWithPercentage[] {\n    const total = segments.reduce((sum, segment) => sum + segment.value, 0);\n    return segments.map(segment => {\n      let percentage = (segment.value / total) * 100;\n      let percentageLabel = '';\n\n      if (percentage === 0) {\n        percentageLabel = '0%';\n      } else if (percentage > 0 && percentage < 1) {\n        percentageLabel = '>1%';\n      } else {\n        percentageLabel = `${Math.ceil(percentage)}%`;\n      }\n\n      return { ...segment, percentage: percentageLabel };\n    });\n  }\n\n  get accessibleValueText(): string {\n    return this.segmentList\n      .map((segment, index) => `${segment.tooltip || `Value ${index}`}: ${segment.value}`)\n      .join(', ');\n  }\n}\n","<div\n  class=\"segmented-bar-container\"\n  [attr.theme]=\"applicationTheme\"\n  [ngClass]=\"'segment-size-' + size\"\n  [style.width]=\"width\"\n  [uiTooltipTemplate]=\"segmentedStats\"\n  [showTooltip]=\"tooltipStats\"\n  [attr.aria-label]=\"accessibleValueText\"\n  role=\"graphics-object\"\n  [tabIndex]=\"0\"\n>\n  <ng-container *ngFor=\"let segment of segmentList\">\n    <div\n      class=\"segmented-bar\"\n      *ngIf=\"segment.value\"\n      [ngClass]=\"segment.color\"\n      [ngStyle]=\"{ flex: segment.value }\"\n      [matTooltip]=\"!tooltipStats ? segment.tooltip ?? '' : ''\"\n      [matTooltipClass]=\"applicationTheme\"\n      [attr.aria-hidden]=\"true\"\n      [attr.aria-required]=\"ariaRequired\"\n    >\n      <ui-icon *ngIf=\"segment.icon\"  [applicationTheme]=\"applicationTheme\" [name]=\"segment.icon\"></ui-icon>\n      <span>{{ segment.value }}</span>\n    </div>\n  </ng-container>\n</div>\n<ng-template #segmentedStats>\n  <div class=\"stats-container\">\n    <div class=\"name-column\">\n      @for (segment of segmentList; track segment.value) {\n        <div class=\"segment\">\n          <div [class]=\"'point ' + segment.color\"></div>\n          <span [class]=\"'label ' + segment.color\">{{ segment.tooltip }}</span>\n        </div>\n      }\n    </div>\n\n    <div class=\"value-column\">\n      @for (segment of segmentList; track segment.value) {\n        <div class=\"segment\">\n          <span>{{ segment.value }}</span>\n        </div>\n      }\n    </div>\n\n    <div class=\"percentage-column\">\n      @for (segment of segmentList; track segment.value) {\n        <div class=\"segment\">\n          <span>{{ segment.percentage }}</span>\n        </div>\n      }\n    </div>\n\n  </div>\n</ng-template>\n\n<ng-template #segmentedStats>\n  <div class=\"stats-container\">\n    <div class=\"name-column\">\n      @for (segment of segmentList; track segment.value) {\n        <div class=\"segment\">\n          <div [class]=\"'point ' + segment.color\"></div>\n          <span [class]=\"'label ' + segment.color\">{{ segment.tooltip }}</span>\n        </div>\n      }\n    </div>\n\n    <div class=\"value-column\">\n      @for (segment of segmentList; track segment.value) {\n        <div class=\"segment\">\n          <span>{{ segment.value }}</span>\n        </div>\n      }\n    </div>\n\n    <div class=\"percentage-column\">\n      @for (segment of segmentList; track segment.value) {\n        <div class=\"segment\">\n          <span>{{ segment.percentage }}</span>\n        </div>\n      }\n    </div>\n\n  </div>\n</ng-template>\n\n"]}
|
|
@@ -134,9 +134,7 @@ export class SnackbarComponent {
|
|
|
134
134
|
this.timerStartedAt = 0;
|
|
135
135
|
clearTimeout(this.timer);
|
|
136
136
|
this.timer = undefined;
|
|
137
|
-
|
|
138
|
-
this.snackbarRef.dismiss();
|
|
139
|
-
}
|
|
137
|
+
this.dismissSnackbar();
|
|
140
138
|
}
|
|
141
139
|
//Pause timer when mouse enter
|
|
142
140
|
onMouseEnter() {
|
|
@@ -155,9 +153,7 @@ export class SnackbarComponent {
|
|
|
155
153
|
//Hide snackbar when dismiss button is clicked
|
|
156
154
|
dismissClick() {
|
|
157
155
|
this.visible = false;
|
|
158
|
-
|
|
159
|
-
this.snackbarRef.dismiss();
|
|
160
|
-
}
|
|
156
|
+
this.dismissSnackbar();
|
|
161
157
|
}
|
|
162
158
|
onLinkClick(event) {
|
|
163
159
|
event?.preventDefault();
|
|
@@ -168,6 +164,11 @@ export class SnackbarComponent {
|
|
|
168
164
|
window.open(this.data.link?.url, '_blank');
|
|
169
165
|
}
|
|
170
166
|
}
|
|
167
|
+
dismissSnackbar() {
|
|
168
|
+
if (Object.keys(this.snackbarRef).length > 0) {
|
|
169
|
+
this.snackbarRef.dismiss();
|
|
170
|
+
}
|
|
171
|
+
}
|
|
171
172
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SnackbarComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }, { token: MAT_SNACK_BAR_DATA }, { token: i1.MatSnackBarRef }, { token: i2.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
172
173
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SnackbarComponent, selector: "ui-snackbar", inputs: { snackbarType: "snackbarType", message: "message", html: "html", seconds: "seconds", includeDismissButton: "includeDismissButton", fixed: "fixed", linkText: "linkText", linkUrl: "linkUrl", linkTarget: "linkTarget", variant: "variant", applicationTheme: "applicationTheme", closeButtonTooltip: "closeButtonTooltip", ariaDescribedby: "ariaDescribedby" }, ngImport: i0, template: "<ng-container>\n <div\n [ngClass]=\"snackbarType + ' ' + position\"\n [@openClose]\n *ngIf=\"visible\"\n class=\"snackbar-container\"\n [attr.theme]=\"applicationTheme\"\n [class.mobile]=\"variant === 'mobile'\"\n [class.desktop]=\"variant === 'desktop'\"\n (mouseenter)=\"onMouseEnter()\"\n (mouseleave)=\"onMouseLeave()\"\n data-testid=\"snackbar-wrapper\"\n [attr.data-test-snackbar-type]=\"snackbarType\"\n [attr.aria-describedby]=\"'describedby'\"\n role=\"alert\"\n [attr.aria-labelledby]=\"'labelledby'\"\n >\n <span style=\"position: absolute; left: -9999px\" id=\"labelledby\">{{ ('ALERT_BANNER.' + (snackbarType | uppercase)) | uiTranslate | async }}</span>\n <span style=\"position: absolute; left: -9999px\">{{ message }}\n <a *ngIf=\"!!linkText\" [target]=\"linkTarget\" [href]=\"linkUrl\" (click)=\"onLinkClick($event)\">{{ linkText }}</a>\n </span>\n <span [style.display]=\"'none'\" id=\"describedby\">{{ ariaDescribedby }}</span>\n <div\n aria-hidden=\"true\"\n class=\"snackbar-text\"\n [matTooltip]=\"message.length > maxCharacters ? message : ''\"\n data-testid=\"snackbar-content\"\n >\n <ui-icon *ngIf=\"applicationTheme === 'classic'\" [name]=\"iconName\" size=\"24\"></ui-icon>\n {{ message.length > maxCharacters ? (message | slice: 0:maxCharacters) + '..' : message }}\n <div *ngIf=\"safeHtml\" [innerHTML]=\"safeHtml\"></div>\n <a *ngIf=\"!!linkText\" [target]=\"linkTarget\" [href]=\"linkUrl\" (click)=\"onLinkClick($event)\">{{ linkText }}</a>\n </div>\n <ui-button\n *ngIf=\"includeDismissButton && applicationTheme === 'classic'\"\n variant=\"text\"\n [label]=\"(translationContext + 'DISMISS' | uiTranslate | async)!\"\n [applicationTheme]=\"applicationTheme !== 'classic' ? 'light' : 'classic'\"\n (buttonClickEvent)=\"dismissClick()\"\n data-testid=\"snackbar-dismiss-button\"\n ></ui-button>\n <ui-button\n *ngIf=\"includeDismissButton && applicationTheme !== 'classic'\"\n [variant]=\"'icon-button'\"\n [applicationTheme]=\"'light'\"\n [iconName]=\"'Close-in-line'\"\n [size]=\"'small'\"\n [tooltip]=\"(closeButtonTooltip || ('COMMON.CLOSE' | uiTranslate | async))!\"\n (click)=\"dismissClick()\"\n data-testid=\"snackbar-dismiss-button\"\n ></ui-button>\n </div>\n</ng-container>\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}:host{display:flex;width:100%;justify-content:center}:host .snackbar-container{max-width:600px}:host .alert-container,:host .snackbar-container{margin:0 auto;display:flex;padding:0 14px;border-radius:4px;align-items:center;justify-content:space-between;opacity:1;min-height:48px}:host .alert-container.fixed,:host .snackbar-container.fixed{position:fixed}:host .alert-container.static,:host .snackbar-container.static{position:relative}:host .alert-container ui-icon,:host .snackbar-container ui-icon{margin-right:14px}:host .alert-container ui-button,:host .snackbar-container ui-button{margin-left:14px}:host .alert-container ::ng-deep button.mat-mdc-unelevated-button.big,:host .snackbar-container ::ng-deep button.mat-mdc-unelevated-button.big{padding:0;min-width:auto}:host .alert-container .alert-text,:host .alert-container .snackbar-text,:host .snackbar-container .alert-text,:host .snackbar-container .snackbar-text{display:flex;align-items:center;color:#000}:host .alert-container .alert-text a,:host .alert-container .snackbar-text a,:host .snackbar-container .alert-text a,:host .snackbar-container .snackbar-text a{color:#000;text-decoration:underline;font-weight:700}:host .alert-container .alert-text a:hover,:host .alert-container .alert-text a:visited,:host .alert-container .alert-text a:focus,:host .alert-container .snackbar-text a:hover,:host .alert-container .snackbar-text a:visited,:host .alert-container .snackbar-text a:focus,:host .snackbar-container .alert-text a:hover,:host .snackbar-container .alert-text a:visited,:host .snackbar-container .alert-text a:focus,:host .snackbar-container .snackbar-text a:hover,:host .snackbar-container .snackbar-text a:visited,:host .snackbar-container .snackbar-text a:focus{text-decoration:none}:host .alert-container.success,:host .snackbar-container.success{background-color:#cbd6cb}:host .alert-container.info,:host .snackbar-container.info{background-color:#c8d7de}:host .alert-container.warning,:host .snackbar-container.warning{background-color:#f0d6bb}:host .alert-container.error,:host .snackbar-container.error{background-color:#e3c3c6}:host .alert-container[theme=dark].success,:host .alert-container[theme=light].success,:host .snackbar-container[theme=dark].success,:host .snackbar-container[theme=light].success{background-color:#aae47a}:host .alert-container[theme=dark].info,:host .alert-container[theme=light].info,:host .snackbar-container[theme=dark].info,:host .snackbar-container[theme=light].info{background-color:#d9e8ff}:host .alert-container[theme=dark].warning,:host .alert-container[theme=light].warning,:host .snackbar-container[theme=dark].warning,:host .snackbar-container[theme=light].warning{background-color:#ffe1b3}:host .alert-container[theme=dark].error,:host .alert-container[theme=light].error,:host .snackbar-container[theme=dark].error,:host .snackbar-container[theme=light].error{background-color:#ffac9a}::ng-deep .display-none{display:none!important}@media (max-width: 600px){:host .alert-container,:host .snackbar-container{padding:8px 14px}}:host .snackbar-container{bottom:0;z-index:98}:host .snackbar-container[theme=dark] ui-icon,:host .snackbar-container[theme=light] ui-icon{margin-right:10px;cursor:pointer}:host .snackbar-container[theme=dark] .snackbar-text,:host .snackbar-container[theme=light] .snackbar-text{padding-left:10px;margin-right:8px}:host .snackbar-container[theme=dark] .snackbar-text a,:host .snackbar-container[theme=light] .snackbar-text a{margin-left:4px}:host .snackbar-container[theme=dark].desktop,:host .snackbar-container[theme=light].desktop{border-radius:24px;box-shadow:0 4px 16px #2424240a;width:fit-content;max-width:600px;min-height:48px;line-height:1.4;font-size:14px;padding:16px 24px}:host .snackbar-container[theme=dark].mobile,:host .snackbar-container[theme=light].mobile{width:100%;min-width:100%;word-break:break-word}:host .mat-mdc-snack-bar-container{margin:16px 8px}::ng-deep .mdc-snackbar__surface{height:0}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.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: "component", type: i5.IconComponent, selector: "ui-icon", inputs: ["size", "cssClass", "name", "color", "filled", "toggleIconStyle", "applicationTheme", "useFullIconName"] }, { kind: "directive", type: i6.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i3.SlicePipe, name: "slice" }, { kind: "pipe", type: i7.UiTranslatePipe, name: "uiTranslate" }], animations: [
|
|
173
174
|
trigger('openClose', [
|
|
@@ -231,4 +232,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
231
232
|
}], ariaDescribedby: [{
|
|
232
233
|
type: Input
|
|
233
234
|
}] } });
|
|
234
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snackbar.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/snackbar/snackbar.component.ts","../../../../../projects/tgo-canopy-ui/components/snackbar/snackbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, style, transition, trigger } from '@angular/animations';\nimport { Component, Inject, Input, OnInit, Optional } from '@angular/core';\nimport { MAT_SNACK_BAR_DATA, MatSnackBarRef } from '@angular/material/snack-bar';\nimport { IconName } from '../../components/icon/icon.model';\nimport { SnackbarLink, SnackbarType, SnackbarVariant } from '../../components/snackbar/snackbar.model';\nimport { alertBarsUtil } from '../../utils/alert-bars.utils';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { LinkTargetType } from '../alert-banner/alert-banner.model';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\n@Component({\n  selector: 'ui-snackbar',\n  templateUrl: './snackbar.component.html',\n  styleUrls: ['./snackbar.component.scss'],\n  animations: [\n    trigger('openClose', [\n      transition(':enter', [\n        style({ bottom: '-55px', opacity: 0 }),\n        animate('0.2s ease-out', style({ opacity: 1, bottom: '10px' })),\n      ]),\n      transition(':leave', [\n        style({ bottom: '10px', opacity: 1 }),\n        animate('0.2s ease-in', style({ bottom: '-55px', opacity: 0 })),\n      ]),\n    ]),\n  ],\n})\nexport class SnackbarComponent implements OnInit {\n  /**\n   * Background color of the button while in active state\n   *\n   * @type {SnackbarType}\n   * @memberof SnackbarComponent\n   */\n  @Input() snackbarType: SnackbarType = 'success';\n\n  /**\n   * Snackbar message\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() message = '';\n\n  /**\n   * Snackbar message from html\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() set html(value: string) {\n    if (value) {\n      this.safeHtml = this.domSanitizer.bypassSecurityTrustHtml(value);\n    }\n  }\n\n  /**\n   * Set the time that the snackbar will be visible\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() seconds = 5;\n\n  /**\n   * Include dismmiss button\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() includeDismissButton = true;\n\n  /**\n   * Static or fixed position\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() fixed = true;\n\n  /**\n   * Link text that will appended at the end of message\n   *\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   * @memberof AlertBannerComponent\n   */\n  @Input() linkTarget?: LinkTargetType = '_blank';\n\n  /**\n   * The variant to be used\n   *\n   * @type {SnackbarVariant}\n   * @memberof SnackbarComponent\n   */\n  @Input() variant: SnackbarVariant = 'desktop';\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof SnackbarComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Close button tooltip\n   *\n   * @type {string}\n   * @memberof SnackbarComponent\n   */\n  @Input() closeButtonTooltip = '';\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 SnackbarComponent\n   */\n  @Input() ariaDescribedby = '';\n\n  iconName: IconName;\n  showSnackbar = true;\n  milisenconds: number;\n  visible = false;\n  timer?: number;\n  timerStartedAt = 0;\n  timerPausedAt = 0;\n  position: string;\n  safeHtml: SafeHtml;\n\n  translationContext = 'SNACKBAR.';\n  protected readonly maxCharacters = 70;\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    @Inject(MAT_SNACK_BAR_DATA)\n    private data: {\n      snackbarType: SnackbarType;\n      message: string;\n      link?: SnackbarLink;\n      applicationTheme?: ApplicationTheme;\n      html?: string;\n      seconds?: number;\n    },\n    private snackbarRef: MatSnackBarRef<SnackbarComponent>,\n    private domSanitizer: DomSanitizer\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n\n    this.snackbarType = data.snackbarType ?? 'success';\n    this.message = data.message ?? '';\n    this.safeHtml = data.html ? this.domSanitizer.bypassSecurityTrustHtml(data.html) : '';\n    this.linkText = data.link?.text ?? '';\n    this.linkUrl = data.link?.url ?? '';\n    this.seconds = data.seconds ?? 5;\n  }\n\n  ngOnInit(): void {\n    this.milisenconds = this.seconds * 1000;\n    this.iconName = alertBarsUtil.setIcon(this.snackbarType);\n    this.show();\n    this.position = alertBarsUtil.setPosition(this.fixed);\n  }\n\n  //Show snackbar\n  show() {\n    this.timerStartedAt = Date.now();\n    this.visible = true;\n    this.timer = window.setTimeout(() => this.hide(), this.milisenconds);\n  }\n\n  //Hide snackbar\n  hide() {\n    this.visible = false;\n    this.timerPausedAt = 0;\n    this.timerStartedAt = 0;\n    clearTimeout(this.timer);\n    this.timer = undefined;\n    if (Object.keys(this.snackbarRef).length > 0) {\n      this.snackbarRef.dismiss();\n    }\n  }\n\n  //Pause timer when mouse enter\n  onMouseEnter() {\n    this.visible = true;\n    this.timerPausedAt = Date.now();\n    clearTimeout(this.timer);\n  }\n\n  //Continue timer when mouse leave\n  onMouseLeave() {\n    const diff = this.timerPausedAt - this.timerStartedAt;\n    if (diff <= 0) {\n      return this.hide();\n    }\n    this.timer = window.setTimeout(() => this.hide(), this.milisenconds - diff);\n  }\n\n  //Hide snackbar when dismiss button is clicked\n  dismissClick() {\n    this.visible = false;\n    if (Object.keys(this.snackbarRef).length > 0) {\n      this.snackbarRef.dismiss();\n    }\n  }\n\n  onLinkClick(event: Event): void {\n    event?.preventDefault();\n\n    if (this.data.link?.action) {\n      this.data.link?.action();\n    } else if (this.data.link?.url) {\n      window.open(this.data.link?.url, '_blank');\n    }\n  }\n}\n","<ng-container>\n  <div\n    [ngClass]=\"snackbarType + ' ' + position\"\n    [@openClose]\n    *ngIf=\"visible\"\n    class=\"snackbar-container\"\n    [attr.theme]=\"applicationTheme\"\n    [class.mobile]=\"variant === 'mobile'\"\n    [class.desktop]=\"variant === 'desktop'\"\n    (mouseenter)=\"onMouseEnter()\"\n    (mouseleave)=\"onMouseLeave()\"\n    data-testid=\"snackbar-wrapper\"\n    [attr.data-test-snackbar-type]=\"snackbarType\"\n    [attr.aria-describedby]=\"'describedby'\"\n    role=\"alert\"\n    [attr.aria-labelledby]=\"'labelledby'\"\n  >\n    <span style=\"position: absolute; left: -9999px\" id=\"labelledby\">{{ ('ALERT_BANNER.' + (snackbarType | uppercase)) | uiTranslate | async }}</span>\n    <span style=\"position: absolute; left: -9999px\">{{ message }}\n      <a *ngIf=\"!!linkText\" [target]=\"linkTarget\" [href]=\"linkUrl\" (click)=\"onLinkClick($event)\">{{ linkText }}</a>\n    </span>\n    <span [style.display]=\"'none'\" id=\"describedby\">{{ ariaDescribedby }}</span>\n    <div\n      aria-hidden=\"true\"\n      class=\"snackbar-text\"\n      [matTooltip]=\"message.length > maxCharacters ? message : ''\"\n      data-testid=\"snackbar-content\"\n    >\n      <ui-icon *ngIf=\"applicationTheme === 'classic'\" [name]=\"iconName\" size=\"24\"></ui-icon>\n      {{ message.length > maxCharacters ? (message | slice: 0:maxCharacters) + '..' : message }}\n      <div *ngIf=\"safeHtml\" [innerHTML]=\"safeHtml\"></div>\n      <a *ngIf=\"!!linkText\" [target]=\"linkTarget\" [href]=\"linkUrl\" (click)=\"onLinkClick($event)\">{{ linkText }}</a>\n    </div>\n    <ui-button\n      *ngIf=\"includeDismissButton && applicationTheme === 'classic'\"\n      variant=\"text\"\n      [label]=\"(translationContext + 'DISMISS' | uiTranslate | async)!\"\n      [applicationTheme]=\"applicationTheme !== 'classic' ? 'light' : 'classic'\"\n      (buttonClickEvent)=\"dismissClick()\"\n      data-testid=\"snackbar-dismiss-button\"\n    ></ui-button>\n    <ui-button\n      *ngIf=\"includeDismissButton && applicationTheme !== 'classic'\"\n      [variant]=\"'icon-button'\"\n      [applicationTheme]=\"'light'\"\n      [iconName]=\"'Close-in-line'\"\n      [size]=\"'small'\"\n      [tooltip]=\"(closeButtonTooltip || ('COMMON.CLOSE' | uiTranslate | async))!\"\n      (click)=\"dismissClick()\"\n      data-testid=\"snackbar-dismiss-button\"\n    ></ui-button>\n  </div>\n</ng-container>\n"]}
|
|
235
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snackbar.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/snackbar/snackbar.component.ts","../../../../../projects/tgo-canopy-ui/components/snackbar/snackbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, style, transition, trigger } from '@angular/animations';\nimport { Component, Inject, Input, OnInit, Optional } from '@angular/core';\nimport { MAT_SNACK_BAR_DATA, MatSnackBarRef } from '@angular/material/snack-bar';\nimport { IconName } from '../../components/icon/icon.model';\nimport { SnackbarLink, SnackbarType, SnackbarVariant } from '../../components/snackbar/snackbar.model';\nimport { alertBarsUtil } from '../../utils/alert-bars.utils';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { LinkTargetType } from '../alert-banner/alert-banner.model';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\n@Component({\n  selector: 'ui-snackbar',\n  templateUrl: './snackbar.component.html',\n  styleUrls: ['./snackbar.component.scss'],\n  animations: [\n    trigger('openClose', [\n      transition(':enter', [\n        style({ bottom: '-55px', opacity: 0 }),\n        animate('0.2s ease-out', style({ opacity: 1, bottom: '10px' })),\n      ]),\n      transition(':leave', [\n        style({ bottom: '10px', opacity: 1 }),\n        animate('0.2s ease-in', style({ bottom: '-55px', opacity: 0 })),\n      ]),\n    ]),\n  ],\n})\nexport class SnackbarComponent implements OnInit {\n  /**\n   * Background color of the button while in active state\n   *\n   * @type {SnackbarType}\n   * @memberof SnackbarComponent\n   */\n  @Input() snackbarType: SnackbarType = 'success';\n\n  /**\n   * Snackbar message\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() message = '';\n\n  /**\n   * Snackbar message from html\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() set html(value: string) {\n    if (value) {\n      this.safeHtml = this.domSanitizer.bypassSecurityTrustHtml(value);\n    }\n  }\n\n  /**\n   * Set the time that the snackbar will be visible\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() seconds = 5;\n\n  /**\n   * Include dismmiss button\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() includeDismissButton = true;\n\n  /**\n   * Static or fixed position\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() fixed = true;\n\n  /**\n   * Link text that will appended at the end of message\n   *\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   * @memberof AlertBannerComponent\n   */\n  @Input() linkTarget?: LinkTargetType = '_blank';\n\n  /**\n   * The variant to be used\n   *\n   * @type {SnackbarVariant}\n   * @memberof SnackbarComponent\n   */\n  @Input() variant: SnackbarVariant = 'desktop';\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof SnackbarComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Close button tooltip\n   *\n   * @type {string}\n   * @memberof SnackbarComponent\n   */\n  @Input() closeButtonTooltip = '';\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 SnackbarComponent\n   */\n  @Input() ariaDescribedby = '';\n\n  iconName: IconName;\n  showSnackbar = true;\n  milisenconds: number;\n  visible = false;\n  timer?: number;\n  timerStartedAt = 0;\n  timerPausedAt = 0;\n  position: string;\n  safeHtml: SafeHtml;\n\n  translationContext = 'SNACKBAR.';\n  protected readonly maxCharacters = 70;\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    @Inject(MAT_SNACK_BAR_DATA)\n    private data: {\n      snackbarType: SnackbarType;\n      message: string;\n      link?: SnackbarLink;\n      applicationTheme?: ApplicationTheme;\n      html?: string;\n      seconds?: number;\n    },\n    private snackbarRef: MatSnackBarRef<SnackbarComponent>,\n    private domSanitizer: DomSanitizer\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n\n    this.snackbarType = data.snackbarType ?? 'success';\n    this.message = data.message ?? '';\n    this.safeHtml = data.html ? this.domSanitizer.bypassSecurityTrustHtml(data.html) : '';\n    this.linkText = data.link?.text ?? '';\n    this.linkUrl = data.link?.url ?? '';\n    this.seconds = data.seconds ?? 5;\n  }\n\n  ngOnInit(): void {\n    this.milisenconds = this.seconds * 1000;\n    this.iconName = alertBarsUtil.setIcon(this.snackbarType);\n    this.show();\n    this.position = alertBarsUtil.setPosition(this.fixed);\n  }\n\n  //Show snackbar\n  show() {\n    this.timerStartedAt = Date.now();\n    this.visible = true;\n    this.timer = window.setTimeout(() => this.hide(), this.milisenconds);\n  }\n\n  //Hide snackbar\n  hide() {\n    this.visible = false;\n    this.timerPausedAt = 0;\n    this.timerStartedAt = 0;\n    clearTimeout(this.timer);\n    this.timer = undefined;\n    this.dismissSnackbar();\n  }\n\n  //Pause timer when mouse enter\n  onMouseEnter() {\n    this.visible = true;\n    this.timerPausedAt = Date.now();\n    clearTimeout(this.timer);\n  }\n\n  //Continue timer when mouse leave\n  onMouseLeave() {\n    const diff = this.timerPausedAt - this.timerStartedAt;\n    if (diff <= 0) {\n      return this.hide();\n    }\n    this.timer = window.setTimeout(() => this.hide(), this.milisenconds - diff);\n  }\n\n  //Hide snackbar when dismiss button is clicked\n  dismissClick() {\n    this.visible = false;\n    this.dismissSnackbar();\n  }\n\n  onLinkClick(event: Event): void {\n    event?.preventDefault();\n\n    if (this.data.link?.action) {\n      this.data.link?.action();\n    } else if (this.data.link?.url) {\n      window.open(this.data.link?.url, '_blank');\n    }\n  }\n\n  private dismissSnackbar(): void {\n    if (Object.keys(this.snackbarRef).length > 0) {\n      this.snackbarRef.dismiss();\n    }\n  }\n}\n","<ng-container>\n  <div\n    [ngClass]=\"snackbarType + ' ' + position\"\n    [@openClose]\n    *ngIf=\"visible\"\n    class=\"snackbar-container\"\n    [attr.theme]=\"applicationTheme\"\n    [class.mobile]=\"variant === 'mobile'\"\n    [class.desktop]=\"variant === 'desktop'\"\n    (mouseenter)=\"onMouseEnter()\"\n    (mouseleave)=\"onMouseLeave()\"\n    data-testid=\"snackbar-wrapper\"\n    [attr.data-test-snackbar-type]=\"snackbarType\"\n    [attr.aria-describedby]=\"'describedby'\"\n    role=\"alert\"\n    [attr.aria-labelledby]=\"'labelledby'\"\n  >\n    <span style=\"position: absolute; left: -9999px\" id=\"labelledby\">{{ ('ALERT_BANNER.' + (snackbarType | uppercase)) | uiTranslate | async }}</span>\n    <span style=\"position: absolute; left: -9999px\">{{ message }}\n      <a *ngIf=\"!!linkText\" [target]=\"linkTarget\" [href]=\"linkUrl\" (click)=\"onLinkClick($event)\">{{ linkText }}</a>\n    </span>\n    <span [style.display]=\"'none'\" id=\"describedby\">{{ ariaDescribedby }}</span>\n    <div\n      aria-hidden=\"true\"\n      class=\"snackbar-text\"\n      [matTooltip]=\"message.length > maxCharacters ? message : ''\"\n      data-testid=\"snackbar-content\"\n    >\n      <ui-icon *ngIf=\"applicationTheme === 'classic'\" [name]=\"iconName\" size=\"24\"></ui-icon>\n      {{ message.length > maxCharacters ? (message | slice: 0:maxCharacters) + '..' : message }}\n      <div *ngIf=\"safeHtml\" [innerHTML]=\"safeHtml\"></div>\n      <a *ngIf=\"!!linkText\" [target]=\"linkTarget\" [href]=\"linkUrl\" (click)=\"onLinkClick($event)\">{{ linkText }}</a>\n    </div>\n    <ui-button\n      *ngIf=\"includeDismissButton && applicationTheme === 'classic'\"\n      variant=\"text\"\n      [label]=\"(translationContext + 'DISMISS' | uiTranslate | async)!\"\n      [applicationTheme]=\"applicationTheme !== 'classic' ? 'light' : 'classic'\"\n      (buttonClickEvent)=\"dismissClick()\"\n      data-testid=\"snackbar-dismiss-button\"\n    ></ui-button>\n    <ui-button\n      *ngIf=\"includeDismissButton && applicationTheme !== 'classic'\"\n      [variant]=\"'icon-button'\"\n      [applicationTheme]=\"'light'\"\n      [iconName]=\"'Close-in-line'\"\n      [size]=\"'small'\"\n      [tooltip]=\"(closeButtonTooltip || ('COMMON.CLOSE' | uiTranslate | async))!\"\n      (click)=\"dismissClick()\"\n      data-testid=\"snackbar-dismiss-button\"\n    ></ui-button>\n  </div>\n</ng-container>\n"]}
|