@testgorilla/tgo-ui 2.26.19 → 2.26.20

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.
@@ -3,7 +3,7 @@ import { ApplicationTheme } from '../../models/application-theme.model';
3
3
  import { FilterButtonOption } from './filter-button.model';
4
4
  import { IconName } from '../icon/icon.model';
5
5
  import { ButtonIconPosition } from '../button/button.model';
6
- import { FocusKeyManager } from "@angular/cdk/a11y";
6
+ import { FocusKeyManager } from '@angular/cdk/a11y';
7
7
  import * as i0 from "@angular/core";
8
8
  export declare class FilterButtonComponent implements OnChanges {
9
9
  private readonly defaultAppTheme;
@@ -98,7 +98,16 @@ export declare class FilterButtonComponent implements OnChanges {
98
98
  displayedLabel: import("@angular/core").WritableSignal<string>;
99
99
  tooltip: import("@angular/core").WritableSignal<string>;
100
100
  search: import("@angular/core").WritableSignal<string>;
101
- displayedOptions: import("@angular/core").Signal<FilterButtonOption[]>;
101
+ showTooltip: {
102
+ [key: string]: boolean;
103
+ };
104
+ displayedOptions: import("@angular/core").Signal<{
105
+ sectionTitle: string;
106
+ value: string;
107
+ label: string;
108
+ labelNumber?: number | undefined;
109
+ icon?: IconName | undefined;
110
+ }[]>;
102
111
  readonly MIN_OPTIONS_LENGTH_FOR_SEARCH = 8;
103
112
  protected keyManager: FocusKeyManager<HTMLElement>;
104
113
  protected translationContext: string;
@@ -107,11 +116,11 @@ export declare class FilterButtonComponent implements OnChanges {
107
116
  clearValue(): void;
108
117
  outsideClick(): void;
109
118
  toggle(): void;
110
- overlayAttach(): void;
111
119
  isSelected(value?: string): boolean;
112
120
  optionChanged(selected: boolean, option: FilterButtonOption): void;
113
- private updateLabel;
114
121
  keyDownHandler(ev: any): void;
122
+ onLabelEllipsisChange(isEllipsis: boolean, value: string): void;
123
+ private updateLabel;
115
124
  static ɵfac: i0.ɵɵFactoryDeclaration<FilterButtonComponent, [{ optional: true; }, null]>;
116
125
  static ɵcmp: i0.ɵɵComponentDeclaration<FilterButtonComponent, "ui-filter-button", never, { "label": { "alias": "label"; "required": false; }; "message": { "alias": "message"; "required": false; }; "value": { "alias": "value"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "options": { "alias": "options"; "required": false; }; "allowClear": { "alias": "allowClear"; "required": false; }; "singleSelection": { "alias": "singleSelection"; "required": false; }; "iconName": { "alias": "iconName"; "required": false; }; "iconPosition": { "alias": "iconPosition"; "required": false; }; "applicationTheme": { "alias": "applicationTheme"; "required": false; }; }, { "changed": "changed"; }, never, never, false, never>;
117
126
  }
@@ -6,11 +6,13 @@ import * as i4 from "@angular/material/tooltip";
6
6
  import * as i5 from "@angular/cdk/overlay";
7
7
  import * as i6 from "../../pipes/ui-translate.pipe";
8
8
  import * as i7 from "../button/button.component.module";
9
- import * as i8 from "../checkbox/checkbox.component.module";
10
- import * as i9 from "../field/field.component.module";
11
- import * as i10 from "../radio-button/radio-button.component.module";
9
+ import * as i8 from "../icon/icon.component.module";
10
+ import * as i9 from "../checkbox/checkbox.component.module";
11
+ import * as i10 from "../field/field.component.module";
12
+ import * as i11 from "../../directives/ellipse-text.directive";
13
+ import * as i12 from "../radio-button/radio-button.component.module";
12
14
  export declare class FilterButtonComponentModule {
13
15
  static ɵfac: i0.ɵɵFactoryDeclaration<FilterButtonComponentModule, never>;
14
- static ɵmod: i0.ɵɵNgModuleDeclaration<FilterButtonComponentModule, [typeof i1.FilterButtonComponent], [typeof i2.CommonModule, typeof i3.FormsModule, typeof i4.MatTooltipModule, typeof i5.OverlayModule, typeof i6.UiTranslatePipe, typeof i7.ButtonComponentModule, typeof i8.CheckboxComponentModule, typeof i9.FieldComponentModule, typeof i10.RadioButtonComponentModule], [typeof i1.FilterButtonComponent]>;
16
+ static ɵmod: i0.ɵɵNgModuleDeclaration<FilterButtonComponentModule, [typeof i1.FilterButtonComponent], [typeof i2.CommonModule, typeof i3.FormsModule, typeof i4.MatTooltipModule, typeof i5.OverlayModule, typeof i6.UiTranslatePipe, typeof i7.ButtonComponentModule, typeof i8.IconComponentModule, typeof i9.CheckboxComponentModule, typeof i10.FieldComponentModule, typeof i11.EllipseTextDirective, typeof i12.RadioButtonComponentModule], [typeof i1.FilterButtonComponent]>;
15
17
  static ɵinj: i0.ɵɵInjectorDeclaration<FilterButtonComponentModule>;
16
18
  }
@@ -1,6 +1,8 @@
1
+ import { IconName } from "../icon/icon.model";
1
2
  export interface FilterButtonOption {
2
3
  value: string;
3
4
  label: string;
4
5
  labelNumber?: number;
6
+ icon?: IconName;
5
7
  sectionTitle?: string;
6
8
  }
@@ -211,6 +211,7 @@ export class ButtonComponent {
211
211
  changes['iconPosition'] ||
212
212
  changes['disabled'] ||
213
213
  changes['companyColor'] ||
214
+ changes['variant'] ||
214
215
  changes['applicationTheme']) {
215
216
  this.classCss = this.setCssClass();
216
217
  this.styleCss = this.setCssStyle();
@@ -445,4 +446,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
445
446
  type: HostBinding,
446
447
  args: ['style.--color']
447
448
  }] } });
448
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/button/button.component.ts","../../../../../projects/tgo-canopy-ui/components/button/button.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/use-lifecycle-interface */\nimport {\n  AfterViewInit,\n  booleanAttribute,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { IconName } from '../icon/icon.model';\nimport {\n  ButtonBadgeConfig,\n  ButtonColor,\n  ButtonIconPosition,\n  ButtonSize,\n  ButtonState,\n  ButtonType,\n  IconButtonSize,\n  LinkUrlTarget\n} from './button.model';\nimport { adjustLightness } from '../../utils/color-contrast';\nimport { MatButton } from '@angular/material/button';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { TooltipPosition } from '@angular/material/tooltip';\nimport { FocusOrigin } from \"@angular/cdk/a11y\";\n\n@Component({\n  selector: 'ui-button',\n  templateUrl: './button.component.html',\n  styleUrls: ['./button.component.scss']\n})\nexport class ButtonComponent implements OnInit, AfterViewInit {\n  @HostBinding('style.pointer-events')\n  get enabled(): string {\n    return this.disabled ? 'none' : 'all';\n  }\n\n  @ViewChild('tooltipElement') tooltipElement: ElementRef<HTMLElement>;\n\n  /**\n   * Define button height\n   *\n   * @type {ButtonSize}\n   * @memberof ButtonComponent\n   */\n  @Input() size: ButtonSize = 'big';\n  /**\n   * Background color of the button while in active state\n   *\n   * @type {ButtonColor}\n   * @memberof ButtonComponent\n   */\n  @HostBinding('attr.btn-variant')\n  @Input()\n  variant: ButtonColor = 'primary';\n\n  /**\n   * Text content to appear on the button\n   *\n   * @memberof ButtonComponent\n   */\n  @Input() label = '';\n\n  /**\n   * Positioning of the icon (when existant)\n   *\n   * @type {ButtonIconPosition}\n   * @memberof ButtonComponent\n   */\n  @Input() iconPosition?: ButtonIconPosition = 'right';\n\n  /**\n   * Define if button has only icon without text\n   *\n   * @memberof ButtonComponent\n   */\n  @Input() justIcon = false;\n\n  /**\n   * Name of ui-icon\n   *\n   * @type {IconName}\n   * @memberof ButtonComponent\n   */\n  @Input() iconName: IconName = '';\n\n  /**\n   * Indicator if the button should be disabled\n   *\n   * @memberof ButtonComponent\n   */\n  @Input() disabled = false;\n\n  /**\n   * Indicator if the loading icon should be shown\n   *\n   * @memberof ButtonComponent\n   */\n  @Input() loading = false;\n\n  /**\n   * Indicator of the button width\n   *\n   * @memberof ButtonComponent\n   */\n  @Input() fullWidth = false;\n\n  /**\n   * Url of button if it is a link\n   *\n   * @memberof ButtonComponent\n   */\n  @Input() url?: string;\n\n  /**\n   * Url's target of button if it is a link\n   *\n   * @type {@type {LinkUrlTarget}}\n   * @memberof ButtonComponent\n   */\n  @Input() urlTarget?: LinkUrlTarget;\n\n  /**\n   * Button value\n   *\n   * @memberof ButtonComponent\n   */\n  @Input() value?: string;\n\n  /**\n   * @property tooltip\n   * @description The tooltip that is displayed on hover. Required for icon-button type\n   * @type {string}\n   * @memberof ButtonComponent\n   */\n  @Input() tooltip = '';\n\n  /**\n   * @property isPremium\n   * @description The icon that is displayed for Premium button\n   * @type {boolean}\n   * @memberof ButtonComponent\n   */\n  @Input() isPremium = false;\n\n  /**\n   * The type of the button.\n   *\n   * @type {ButtonType}\n   * @memberof ButtonComponent\n   * @default 'button'\n   */\n  @Input() type: ButtonType = 'button';\n\n  /**\n   * Color of the button.\n   * Defaults to Test Gorilla primary color.\n   *\n   * @type {string}\n   * @memberof ButtonComponent\n   */\n  @Input() companyColor: string | null = '';\n\n  /**\n   * Config for the button badge variation\n   * @type {ButtonBadgeConfig}\n   * @property badgeType Type of badge on the button\n   * @property badgeLabel Label text for the badge\n   * @property badgeNotificationAmount The amount for notification in the badge\n   */\n  @Input() buttonBadgeConfig: ButtonBadgeConfig | undefined;\n\n  /**\n   *\n   * Defines the application theme where buttons is used\n   *\n   * @type {ApplicationTheme}\n   * @memberof ButtonComponent\n   */\n  @HostBinding('attr.theme')\n  @Input()\n  applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   *\n   * Disabled button scale on click\n   *\n   * @type {boolean}\n   * @memberof ButtonComponent\n   */\n  @Input() disabledScaleOnClick = false;\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 ButtonComponent\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 ButtonComponent\n   */\n  @Input() ariaRequired = false;\n\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 ButtonComponent\n   */\n  @Input() ariaLabelledby = '';\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 ButtonComponent\n   */\n  @Input() ariaDescribedby = '';\n\n  /**\n   * Prevents default button click behavior\n   * @type {boolean}\n   * @memberof ButtonComponent\n   */\n  @Input({ transform: booleanAttribute }) preventDefault = false;\n\n  /**\n   * Ghost variant with white background\n   * @type {boolean}\n   * @memberof ButtonComponent\n   */\n  @Input({ transform: booleanAttribute }) hasBackground = false;\n\n  /**\n   * Sets tooltip position\n   *\n   * @type {TooltipPosition}\n   * @memberof ButtonComponent\n   */\n  @Input() tooltipPosition: TooltipPosition = 'below';\n\n  @Input() role: string = 'button';\n\n  @Output() buttonClickEvent: EventEmitter<Event> = new EventEmitter<Event>();\n\n  @Output() buttonHoverEvent: EventEmitter<Event> = new EventEmitter<Event>();\n\n  @ViewChild('buttonElement', { static: false }) buttonElement: MatButton;\n\n\n  get isDisabled(): boolean {\n    return this.disabled;\n  }\n\n  @HostBinding('style.--color')\n  get compColor() {\n    return this.getCompanyColor;\n  }\n\n  classCss: string;\n  styleCss: any;\n  isButtonLink: boolean;\n  isLabel: boolean;\n  buttonState: ButtonState;\n  hover = false;\n  iconButtonSize: IconButtonSize = '40';\n  allowButtonTypeForPremium: ButtonColor[] = ['secondary', 'primary', 'ghost', 'outlined', 'destructive'];\n  isFilledIcon: boolean;\n  coloredIcons = ['Google-in-line', 'Google', 'Google-filled'];\n  labelEllipsis = false;\n  icon: IconName = '';\n\n  get typeIncluded(): boolean {\n    return this.allowButtonTypeForPremium.includes(this.variant);\n  }\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  ngOnInit(): void {\n    this.classCss = this.setCssClass();\n    this.styleCss = this.setCssStyle();\n    this.isButtonLink = this.showButtonLink();\n    this.isLabel = this.showLabel();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['disabled']) {\n      this.buttonState = 'default';\n    }\n    if (!this.applicationTheme) {\n      this.applicationTheme = 'light';\n    }\n    if (changes['type']) {\n      this.isButtonLink = this.showButtonLink();\n    }\n    if (changes['loading']) {\n      this.isLabel = this.showLabel();\n    }\n    if (changes['iconName']) {\n      this.icon = changes['iconName'].currentValue;\n    }\n    if (\n      changes['type'] ||\n      changes['fullWidth'] ||\n      changes['iconName'] ||\n      changes['justIcon'] ||\n      changes['iconPosition'] ||\n      changes['disabled'] ||\n      changes['companyColor'] ||\n      changes['applicationTheme']\n    ) {\n      this.classCss = this.setCssClass();\n      this.styleCss = this.setCssStyle();\n    }\n    if (changes['variant']?.currentValue === 'icon-button' || (changes['variant']?.currentValue === 'menuTrigger' && this.applicationTheme !== 'classic')) {\n      this.iconButtonSize = this.setIconButtonSize();\n    }\n\n    this.isFilledIcon = this.applicationTheme !== 'classic' && (this.variant === 'primary' || this.variant === 'secondary');\n  }\n\n  ngAfterViewInit(): void {\n    this.tooltipElement.nativeElement.onclick = ev => {\n      ev.preventDefault();\n      ev.stopPropagation();\n    };\n    if (this.variant === 'icon-button' && !this.tooltip) {\n      console.warn('ui-button ButtonComponent\\n    [tooltip] is required for [type] icon-button!');\n    } else if (this.variant === 'destructive' && !this.icon && !this.loading && this.applicationTheme !== 'classic') {\n      console.warn('ui-button ButtonComponent\\n  [icon] is required for [type] destructive');\n    }\n  }\n\n  buttonClick(event: Event): void {\n    if (this.preventDefault) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n    this.buttonClickEvent.emit(event);\n  }\n\n  buttonHover(event: Event): void {\n    if (event.type === 'mouseenter') {\n      this.hover = true;\n      this.buttonHoverEvent.emit(event);\n      this.buttonState = 'hover';\n      if (this.shouldChangeFilledStatus && this.icon) {\n        this.icon = this.getIconName(this.iconName, '-filled');\n      }\n    } else {\n      this.hover = false;\n      if (this.shouldChangeFilledStatus && this.icon) {\n        this.icon = this.iconName;\n      }\n      this.buttonState = 'default';\n    }\n\n    this.styleCss = this.setCssStyle();\n  }\n\n  //Show or hide label\n  showLabel(): boolean {\n    return !this.loading;\n  }\n\n  //Set css class according inputs\n  setCssClass(): string {\n    const width = this.fullWidth ? 'full-width' : '';\n    const hasIcon = this.iconName === null ? '' : 'icon';\n    const justIcon = this.justIcon || this.variant === 'icon-button' ? 'only-icon' : '';\n    const iconPosition = this.iconPosition === undefined ? '' : this.iconPosition;\n    const disabled = this.disabled && this.variant === 'primary' ? 'primary-disabled' : '';\n    const variant = this.variant === 'ghost' && this.applicationTheme === 'classic' ? 'outlined' : this.variant;\n    const companyColor = this.companyColor ? 'has-company-color' : '';\n    return `${this.size} ${iconPosition} ${variant} ${width} ${hasIcon} ${justIcon} ${disabled} ${companyColor} ${this.applicationTheme}-theme`;\n  }\n\n  setCssStyle(): any {\n    this.buttonState = this.disabled ? 'disabled' : this.buttonState;\n    const styleObj: any = {};\n\n    if ((this.variant === 'primary' || this.variant === 'text') && this.applicationTheme !== 'classic' && (this.buttonState === 'hover' || this.buttonState === 'pressed')) {\n      styleObj[this.variant === 'primary' ? 'background-color' : 'color'] = adjustLightness(this.getCompanyColor, this.buttonState);\n      if (this.variant === 'text') {\n        styleObj['--active-color'] = this.companyColor ? adjustLightness(this.getCompanyColor, this.buttonState) : '#666666';\n      }\n    } else if ((this.variant === 'primary' || this.variant === 'text') && this.applicationTheme === 'classic' && this.buttonState !== 'default') {\n      styleObj[this.variant === 'primary' ? 'background-color' : 'color'] = adjustLightness(this.getCompanyColor, this.buttonState, 'classic');\n    } else if (this.getCompanyColor && (this.variant === 'link' || this.variant === 'tertiary' || this.variant === 'icon-button')) {\n      styleObj['color'] = this.getCompanyColor;\n    } else if (this.hasBackground) {\n      styleObj['--ghost-background'] = '#ffffff';\n    }\n    return styleObj;\n  }\n\n  //Show or hide spinner\n  get showSpinner(): boolean {\n    const isNotTab = this.variant !== 'tab';\n    const isNotLink = this.variant !== 'link';\n    const isLoading = this.loading === true;\n    return isLoading && isNotTab && isNotLink;\n  }\n\n  //Show button with <button> or <a> tag\n  showButtonLink(): boolean {\n    return this.variant !== 'link';\n  }\n\n  setIconButtonSize(): IconButtonSize {\n    return this.size === 'big' ? '40' : this.size === 'small' ? '24' : '32';\n  }\n\n  onPressed(ev: Event): void {\n    if (ev.type === 'mousedown') {\n      this.buttonState = 'pressed';\n    } else {\n      this.buttonState = this.hover ? 'hover' : 'default';\n    }\n\n    this.styleCss = this.setCssStyle();\n  }\n\n  focus(origin?: FocusOrigin): void {\n    this.buttonElement.focus(origin)\n  }\n\n  get getCompanyColor(): string {\n    return this.companyColor || (this.variant === 'text' ? this.applicationTheme === 'dark' ? '#ffffff' : '#242424' : (this.applicationTheme === 'classic' ? '#46A997' : '#D410AA'));\n  }\n\n  get shouldChangeFilledStatus(): boolean {\n    return this.applicationTheme !== 'classic' && this.variant !== 'primary' && this.variant !== 'secondary' && !this.coloredIcons.includes(this.icon);\n  }\n\n  onKeydown(event: KeyboardEvent): void {\n    if (event.key === ' ') {\n      event.preventDefault();\n      const target = event.target as HTMLElement;\n      target.click();\n    }\n\n    if (event.key === 'Enter' || event.key === ' ') {\n      this.buttonState = 'pressed';\n      this.styleCss = this.setCssStyle();\n    }\n  }\n\n  onKeyup(event: KeyboardEvent): void {\n    if (event.key === 'Enter' || event.key === ' ') {\n      this.buttonState = this.hover ? 'hover' : 'default';\n      this.styleCss = this.setCssStyle();\n    }\n  }\n\n  onLabelEllipsisChange(state: boolean): void {\n    this.labelEllipsis = state;\n  }\n\n  getIconName(iconName: string, defaultValue: string): IconName {\n    if (iconName.includes('filled')) {\n      return iconName.replace(/filled/, 'in-line') as IconName\n    } else if (iconName.includes('in-line')) {\n      return iconName.replace(/in-line/, 'filled') as IconName\n    } else {\n      return iconName + defaultValue as IconName;\n    }\n  }\n}\n","<div #tooltipElement class=\"tooltip\"\n     [matTooltip]=\"tooltip ? tooltip : labelEllipsis ? label : ''\"\n     [matTooltipClass]=\"applicationTheme\"\n></div>\n<div\n  class=\"button-wrapper\"\n  [ngClass]=\"{ 'full-width': fullWidth, 'rounded-icon': applicationTheme !== 'classic' && icon && !label, link: !isButtonLink }\"\n>\n  <div class=\"button-container\"\n       [ngClass]=\"{ 'disabled': disabled, 'button-scale': buttonState === 'pressed' && applicationTheme !== 'classic' && !disabledScaleOnClick }\"\n  >\n     <span *ngIf=\"isPremium && typeIncluded\" class=\"right-top\">\n     <img [attr.src]=\"'/images/premium.svg'\" [alt]=\"'premium-icon'\">\n   </span>\n    <ui-badge\n      id=\"badge\"\n      *ngIf=\"buttonBadgeConfig?.badgeType\"\n      [rebrandColor]=\"buttonBadgeConfig?.rebrandColor ?? 'brand'\"\n      [variant]=\"buttonBadgeConfig!.badgeType!\"\n      [label]=\"buttonBadgeConfig?.badgeLabel ?? ''\"\n      [notificationsAmount]=\"buttonBadgeConfig?.badgeNotificationAmount ?? 0\"\n      class=\"right-top\"\n      [ngClass]=\"{ 'badge-primary': buttonBadgeConfig?.badgeType === 'primary', 'badge-notification': buttonBadgeConfig?.badgeType === 'notification' }\"\n    ></ui-badge>\n    <button\n      [style]=\"'--icon-button-size:' + iconButtonSize + 'px'\"\n      [ngClass]=\"classCss\"\n      [ngStyle]=\"styleCss\"\n      [disabled]=\"disabled\"\n      (click)=\"buttonClick($event)\"\n      (mouseleave)=\"buttonHover($event)\"\n      (mouseenter)=\"buttonHover($event)\"\n      (mousedown)=\"onPressed($event)\"\n      (mouseup)=\"onPressed($event)\"\n      (keydown)=\"onKeydown($event)\"\n      (keyup)=\"onKeyup($event)\"\n      *ngIf=\"isButtonLink\"\n      [attr.aria-required]=\"ariaRequired\"\n      [attr.aria-label]=\"ariaLabel\"\n      [attr.aria-labelledby]=\"'labelledby'\"\n      [attr.aria-describedby]=\"'describedby'\"\n      [attr.aria-disabled]=\"disabled\"\n      [type]=\"type\"\n      [disableRipple]=\"applicationTheme !== 'classic'\"\n      [matTooltip]=\"tooltip ? tooltip : labelEllipsis ? label : ''\"\n      [matTooltipClass]=\"applicationTheme\"\n      [matTooltipPosition]=\"tooltipPosition\"\n      #buttonElement\n      [attr.role]=\"role\"\n      mat-flat-button>\n      <span id=\"describedby\" [style.display]=\"'none'\">\n        {{ (isPremium ? (label + ' ' + ('BUTTON.PREMIUM_FEATURE' | uiTranslate | async)) : ariaDescribedby) }}\n      </span>\n      <span id=\"labelledby\" [style.display]=\"'none'\">\n        {{ ariaLabelledby }}\n      </span>\n      <ng-container *ngIf=\"showSpinner; else icons\">\n        <span class=\"spinner-wrapper\">\n          <mat-spinner class=\"position-spinner\" aria-label=\"loading\" mode=\"indeterminate\" diameter=\"24\"></mat-spinner>\n        </span>\n      </ng-container>\n      <ng-template #icons>\n      <span class=\"icon-only-wrapper\" *ngIf=\"justIcon && !!icon\">\n        <span\n          class=\"icon only\"\n          role=\"label\"\n        >\n          <ui-icon\n            [color]=\"'inherit'\"\n            [applicationTheme]=\"applicationTheme\"\n            [name]=\"icon\"\n            [filled]=\"isFilledIcon\"\n            [useFullIconName]=\"this.variant === 'primary' || this.variant === 'secondary'\"\n            [size]=\"size === 'small' ? '16' : '24'\"\n          ></ui-icon>\n        </span>\n      </span>\n\n        <span class=\"icon-label-wrapper\" [ngClass]=\"{'center-text': iconName === ''}\" *ngIf=\"!justIcon\">\n        <span\n          class=\"icon\"\n          *ngIf=\"iconPosition === 'left' && !!iconName\"\n          aria-hidden=\"true\"\n        >\n          <ui-icon\n            [color]=\"'inherit'\"\n            [applicationTheme]=\"applicationTheme\"\n            [name]=\"icon\"\n            [filled]=\"isFilledIcon\"\n            [useFullIconName]=\"this.variant === 'primary' || this.variant === 'secondary'\"\n            [size]=\"size === 'small' ? '16' : '24'\"\n          ></ui-icon>\n        </span>\n        <span\n          *ngIf=\"isLabel\"\n          class=\"label\"\n          id=\"label\"\n          uiEllipseText\n          [isMultiline]=\"true\"\n          (onChangeTextState)=\"onLabelEllipsisChange($event)\"\n        >\n          {{ label }}\n        </span>\n        <span class=\"icon\" *ngIf=\"iconPosition === 'right' && !!icon\" aria-hidden=\"true\"><ui-icon\n          [color]=\"'inherit'\" [applicationTheme]=\"applicationTheme\" [name]=\"icon\" [filled]=\"isFilledIcon\"\n          [size]=\"size === 'small' ? '16' : '24'\" [useFullIconName]=\"this.variant === 'primary' || this.variant === 'secondary'\"></ui-icon></span>\n      </span>\n      </ng-template>\n    </button>\n    <a\n      #buttonElement\n      [ngClass]=\"classCss\"\n      [ngStyle]=\"styleCss\"\n      [disabled]=\"disabled\"\n      (click)=\"buttonClick($event)\"\n      (mouseenter)=\"buttonHover($event)\"\n      (mouseleave)=\"buttonHover($event)\"\n      (mousedown)=\"onPressed($event)\"\n      (mouseup)=\"onPressed($event)\"\n      (keydown)=\"onKeydown($event);\"\n      (keyup)=\"onKeyup($event)\"\n      [disableRipple]=\"true\"\n      *ngIf=\"!isButtonLink\"\n      [attr.aria-required]=\"ariaRequired\"\n      [attr.aria-label]=\"ariaLabel\"\n      [attr.aria-labelledby]=\"'labelledby-link'\"\n      [attr.aria-describedby]=\"'describedby-link'\"\n      [attr.aria-disabled]=\"disabled\"\n      [matTooltip]=\"tooltip ? tooltip : labelEllipsis ? label : ''\"\n      [matTooltipClass]=\"applicationTheme\"\n      role=\"link\"\n      [href]=\"url\"\n      [target]=\"urlTarget\"\n      mat-flat-button>\n      <span id=\"describedby-link\" [style.display]=\"'none'\">\n        {{ ariaDescribedby }}\n      </span>\n      <span id=\"labelledby-link\" [style.display]=\"'none'\">\n        {{ ariaLabelledby }}\n      </span>\n      <span class=\"icon-label-wrapper\">\n        {{ label }}\n      </span>\n    </a>\n  </div>\n</div>\n"]}
449
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/button/button.component.ts","../../../../../projects/tgo-canopy-ui/components/button/button.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/use-lifecycle-interface */\nimport {\n  AfterViewInit,\n  booleanAttribute,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { IconName } from '../icon/icon.model';\nimport {\n  ButtonBadgeConfig,\n  ButtonColor,\n  ButtonIconPosition,\n  ButtonSize,\n  ButtonState,\n  ButtonType,\n  IconButtonSize,\n  LinkUrlTarget\n} from './button.model';\nimport { adjustLightness } from '../../utils/color-contrast';\nimport { MatButton } from '@angular/material/button';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { TooltipPosition } from '@angular/material/tooltip';\nimport { FocusOrigin } from \"@angular/cdk/a11y\";\n\n@Component({\n  selector: 'ui-button',\n  templateUrl: './button.component.html',\n  styleUrls: ['./button.component.scss']\n})\nexport class ButtonComponent implements OnInit, AfterViewInit {\n  @HostBinding('style.pointer-events')\n  get enabled(): string {\n    return this.disabled ? 'none' : 'all';\n  }\n\n  @ViewChild('tooltipElement') tooltipElement: ElementRef<HTMLElement>;\n\n  /**\n   * Define button height\n   *\n   * @type {ButtonSize}\n   * @memberof ButtonComponent\n   */\n  @Input() size: ButtonSize = 'big';\n  /**\n   * Background color of the button while in active state\n   *\n   * @type {ButtonColor}\n   * @memberof ButtonComponent\n   */\n  @HostBinding('attr.btn-variant')\n  @Input()\n  variant: ButtonColor = 'primary';\n\n  /**\n   * Text content to appear on the button\n   *\n   * @memberof ButtonComponent\n   */\n  @Input() label = '';\n\n  /**\n   * Positioning of the icon (when existant)\n   *\n   * @type {ButtonIconPosition}\n   * @memberof ButtonComponent\n   */\n  @Input() iconPosition?: ButtonIconPosition = 'right';\n\n  /**\n   * Define if button has only icon without text\n   *\n   * @memberof ButtonComponent\n   */\n  @Input() justIcon = false;\n\n  /**\n   * Name of ui-icon\n   *\n   * @type {IconName}\n   * @memberof ButtonComponent\n   */\n  @Input() iconName: IconName = '';\n\n  /**\n   * Indicator if the button should be disabled\n   *\n   * @memberof ButtonComponent\n   */\n  @Input() disabled = false;\n\n  /**\n   * Indicator if the loading icon should be shown\n   *\n   * @memberof ButtonComponent\n   */\n  @Input() loading = false;\n\n  /**\n   * Indicator of the button width\n   *\n   * @memberof ButtonComponent\n   */\n  @Input() fullWidth = false;\n\n  /**\n   * Url of button if it is a link\n   *\n   * @memberof ButtonComponent\n   */\n  @Input() url?: string;\n\n  /**\n   * Url's target of button if it is a link\n   *\n   * @type {@type {LinkUrlTarget}}\n   * @memberof ButtonComponent\n   */\n  @Input() urlTarget?: LinkUrlTarget;\n\n  /**\n   * Button value\n   *\n   * @memberof ButtonComponent\n   */\n  @Input() value?: string;\n\n  /**\n   * @property tooltip\n   * @description The tooltip that is displayed on hover. Required for icon-button type\n   * @type {string}\n   * @memberof ButtonComponent\n   */\n  @Input() tooltip = '';\n\n  /**\n   * @property isPremium\n   * @description The icon that is displayed for Premium button\n   * @type {boolean}\n   * @memberof ButtonComponent\n   */\n  @Input() isPremium = false;\n\n  /**\n   * The type of the button.\n   *\n   * @type {ButtonType}\n   * @memberof ButtonComponent\n   * @default 'button'\n   */\n  @Input() type: ButtonType = 'button';\n\n  /**\n   * Color of the button.\n   * Defaults to Test Gorilla primary color.\n   *\n   * @type {string}\n   * @memberof ButtonComponent\n   */\n  @Input() companyColor: string | null = '';\n\n  /**\n   * Config for the button badge variation\n   * @type {ButtonBadgeConfig}\n   * @property badgeType Type of badge on the button\n   * @property badgeLabel Label text for the badge\n   * @property badgeNotificationAmount The amount for notification in the badge\n   */\n  @Input() buttonBadgeConfig: ButtonBadgeConfig | undefined;\n\n  /**\n   *\n   * Defines the application theme where buttons is used\n   *\n   * @type {ApplicationTheme}\n   * @memberof ButtonComponent\n   */\n  @HostBinding('attr.theme')\n  @Input()\n  applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   *\n   * Disabled button scale on click\n   *\n   * @type {boolean}\n   * @memberof ButtonComponent\n   */\n  @Input() disabledScaleOnClick = false;\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 ButtonComponent\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 ButtonComponent\n   */\n  @Input() ariaRequired = false;\n\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 ButtonComponent\n   */\n  @Input() ariaLabelledby = '';\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 ButtonComponent\n   */\n  @Input() ariaDescribedby = '';\n\n  /**\n   * Prevents default button click behavior\n   * @type {boolean}\n   * @memberof ButtonComponent\n   */\n  @Input({ transform: booleanAttribute }) preventDefault = false;\n\n  /**\n   * Ghost variant with white background\n   * @type {boolean}\n   * @memberof ButtonComponent\n   */\n  @Input({ transform: booleanAttribute }) hasBackground = false;\n\n  /**\n   * Sets tooltip position\n   *\n   * @type {TooltipPosition}\n   * @memberof ButtonComponent\n   */\n  @Input() tooltipPosition: TooltipPosition = 'below';\n\n  @Input() role: string = 'button';\n\n  @Output() buttonClickEvent: EventEmitter<Event> = new EventEmitter<Event>();\n\n  @Output() buttonHoverEvent: EventEmitter<Event> = new EventEmitter<Event>();\n\n  @ViewChild('buttonElement', { static: false }) buttonElement: MatButton;\n\n\n  get isDisabled(): boolean {\n    return this.disabled;\n  }\n\n  @HostBinding('style.--color')\n  get compColor() {\n    return this.getCompanyColor;\n  }\n\n  classCss: string;\n  styleCss: any;\n  isButtonLink: boolean;\n  isLabel: boolean;\n  buttonState: ButtonState;\n  hover = false;\n  iconButtonSize: IconButtonSize = '40';\n  allowButtonTypeForPremium: ButtonColor[] = ['secondary', 'primary', 'ghost', 'outlined', 'destructive'];\n  isFilledIcon: boolean;\n  coloredIcons = ['Google-in-line', 'Google', 'Google-filled'];\n  labelEllipsis = false;\n  icon: IconName = '';\n\n  get typeIncluded(): boolean {\n    return this.allowButtonTypeForPremium.includes(this.variant);\n  }\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  ngOnInit(): void {\n    this.classCss = this.setCssClass();\n    this.styleCss = this.setCssStyle();\n    this.isButtonLink = this.showButtonLink();\n    this.isLabel = this.showLabel();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['disabled']) {\n      this.buttonState = 'default';\n    }\n    if (!this.applicationTheme) {\n      this.applicationTheme = 'light';\n    }\n    if (changes['type']) {\n      this.isButtonLink = this.showButtonLink();\n    }\n    if (changes['loading']) {\n      this.isLabel = this.showLabel();\n    }\n    if (changes['iconName']) {\n      this.icon = changes['iconName'].currentValue;\n    }\n    if (\n      changes['type'] ||\n      changes['fullWidth'] ||\n      changes['iconName'] ||\n      changes['justIcon'] ||\n      changes['iconPosition'] ||\n      changes['disabled'] ||\n      changes['companyColor'] ||\n      changes['variant'] ||\n      changes['applicationTheme']\n    ) {\n      this.classCss = this.setCssClass();\n      this.styleCss = this.setCssStyle();\n    }\n    if (changes['variant']?.currentValue === 'icon-button' || (changes['variant']?.currentValue === 'menuTrigger' && this.applicationTheme !== 'classic')) {\n      this.iconButtonSize = this.setIconButtonSize();\n    }\n\n    this.isFilledIcon = this.applicationTheme !== 'classic' && (this.variant === 'primary' || this.variant === 'secondary');\n  }\n\n  ngAfterViewInit(): void {\n    this.tooltipElement.nativeElement.onclick = ev => {\n      ev.preventDefault();\n      ev.stopPropagation();\n    };\n    if (this.variant === 'icon-button' && !this.tooltip) {\n      console.warn('ui-button ButtonComponent\\n    [tooltip] is required for [type] icon-button!');\n    } else if (this.variant === 'destructive' && !this.icon && !this.loading && this.applicationTheme !== 'classic') {\n      console.warn('ui-button ButtonComponent\\n  [icon] is required for [type] destructive');\n    }\n  }\n\n  buttonClick(event: Event): void {\n    if (this.preventDefault) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n    this.buttonClickEvent.emit(event);\n  }\n\n  buttonHover(event: Event): void {\n    if (event.type === 'mouseenter') {\n      this.hover = true;\n      this.buttonHoverEvent.emit(event);\n      this.buttonState = 'hover';\n      if (this.shouldChangeFilledStatus && this.icon) {\n        this.icon = this.getIconName(this.iconName, '-filled');\n      }\n    } else {\n      this.hover = false;\n      if (this.shouldChangeFilledStatus && this.icon) {\n        this.icon = this.iconName;\n      }\n      this.buttonState = 'default';\n    }\n\n    this.styleCss = this.setCssStyle();\n  }\n\n  //Show or hide label\n  showLabel(): boolean {\n    return !this.loading;\n  }\n\n  //Set css class according inputs\n  setCssClass(): string {\n    const width = this.fullWidth ? 'full-width' : '';\n    const hasIcon = this.iconName === null ? '' : 'icon';\n    const justIcon = this.justIcon || this.variant === 'icon-button' ? 'only-icon' : '';\n    const iconPosition = this.iconPosition === undefined ? '' : this.iconPosition;\n    const disabled = this.disabled && this.variant === 'primary' ? 'primary-disabled' : '';\n    const variant = this.variant === 'ghost' && this.applicationTheme === 'classic' ? 'outlined' : this.variant;\n    const companyColor = this.companyColor ? 'has-company-color' : '';\n    return `${this.size} ${iconPosition} ${variant} ${width} ${hasIcon} ${justIcon} ${disabled} ${companyColor} ${this.applicationTheme}-theme`;\n  }\n\n  setCssStyle(): any {\n    this.buttonState = this.disabled ? 'disabled' : this.buttonState;\n    const styleObj: any = {};\n\n    if ((this.variant === 'primary' || this.variant === 'text') && this.applicationTheme !== 'classic' && (this.buttonState === 'hover' || this.buttonState === 'pressed')) {\n      styleObj[this.variant === 'primary' ? 'background-color' : 'color'] = adjustLightness(this.getCompanyColor, this.buttonState);\n      if (this.variant === 'text') {\n        styleObj['--active-color'] = this.companyColor ? adjustLightness(this.getCompanyColor, this.buttonState) : '#666666';\n      }\n    } else if ((this.variant === 'primary' || this.variant === 'text') && this.applicationTheme === 'classic' && this.buttonState !== 'default') {\n      styleObj[this.variant === 'primary' ? 'background-color' : 'color'] = adjustLightness(this.getCompanyColor, this.buttonState, 'classic');\n    } else if (this.getCompanyColor && (this.variant === 'link' || this.variant === 'tertiary' || this.variant === 'icon-button')) {\n      styleObj['color'] = this.getCompanyColor;\n    } else if (this.hasBackground) {\n      styleObj['--ghost-background'] = '#ffffff';\n    }\n    return styleObj;\n  }\n\n  //Show or hide spinner\n  get showSpinner(): boolean {\n    const isNotTab = this.variant !== 'tab';\n    const isNotLink = this.variant !== 'link';\n    const isLoading = this.loading === true;\n    return isLoading && isNotTab && isNotLink;\n  }\n\n  //Show button with <button> or <a> tag\n  showButtonLink(): boolean {\n    return this.variant !== 'link';\n  }\n\n  setIconButtonSize(): IconButtonSize {\n    return this.size === 'big' ? '40' : this.size === 'small' ? '24' : '32';\n  }\n\n  onPressed(ev: Event): void {\n    if (ev.type === 'mousedown') {\n      this.buttonState = 'pressed';\n    } else {\n      this.buttonState = this.hover ? 'hover' : 'default';\n    }\n\n    this.styleCss = this.setCssStyle();\n  }\n\n  focus(origin?: FocusOrigin): void {\n    this.buttonElement.focus(origin)\n  }\n\n  get getCompanyColor(): string {\n    return this.companyColor || (this.variant === 'text' ? this.applicationTheme === 'dark' ? '#ffffff' : '#242424' : (this.applicationTheme === 'classic' ? '#46A997' : '#D410AA'));\n  }\n\n  get shouldChangeFilledStatus(): boolean {\n    return this.applicationTheme !== 'classic' && this.variant !== 'primary' && this.variant !== 'secondary' && !this.coloredIcons.includes(this.icon);\n  }\n\n  onKeydown(event: KeyboardEvent): void {\n    if (event.key === ' ') {\n      event.preventDefault();\n      const target = event.target as HTMLElement;\n      target.click();\n    }\n\n    if (event.key === 'Enter' || event.key === ' ') {\n      this.buttonState = 'pressed';\n      this.styleCss = this.setCssStyle();\n    }\n  }\n\n  onKeyup(event: KeyboardEvent): void {\n    if (event.key === 'Enter' || event.key === ' ') {\n      this.buttonState = this.hover ? 'hover' : 'default';\n      this.styleCss = this.setCssStyle();\n    }\n  }\n\n  onLabelEllipsisChange(state: boolean): void {\n    this.labelEllipsis = state;\n  }\n\n  getIconName(iconName: string, defaultValue: string): IconName {\n    if (iconName.includes('filled')) {\n      return iconName.replace(/filled/, 'in-line') as IconName\n    } else if (iconName.includes('in-line')) {\n      return iconName.replace(/in-line/, 'filled') as IconName\n    } else {\n      return iconName + defaultValue as IconName;\n    }\n  }\n}\n","<div #tooltipElement class=\"tooltip\"\n     [matTooltip]=\"tooltip ? tooltip : labelEllipsis ? label : ''\"\n     [matTooltipClass]=\"applicationTheme\"\n></div>\n<div\n  class=\"button-wrapper\"\n  [ngClass]=\"{ 'full-width': fullWidth, 'rounded-icon': applicationTheme !== 'classic' && icon && !label, link: !isButtonLink }\"\n>\n  <div class=\"button-container\"\n       [ngClass]=\"{ 'disabled': disabled, 'button-scale': buttonState === 'pressed' && applicationTheme !== 'classic' && !disabledScaleOnClick }\"\n  >\n     <span *ngIf=\"isPremium && typeIncluded\" class=\"right-top\">\n     <img [attr.src]=\"'/images/premium.svg'\" [alt]=\"'premium-icon'\">\n   </span>\n    <ui-badge\n      id=\"badge\"\n      *ngIf=\"buttonBadgeConfig?.badgeType\"\n      [rebrandColor]=\"buttonBadgeConfig?.rebrandColor ?? 'brand'\"\n      [variant]=\"buttonBadgeConfig!.badgeType!\"\n      [label]=\"buttonBadgeConfig?.badgeLabel ?? ''\"\n      [notificationsAmount]=\"buttonBadgeConfig?.badgeNotificationAmount ?? 0\"\n      class=\"right-top\"\n      [ngClass]=\"{ 'badge-primary': buttonBadgeConfig?.badgeType === 'primary', 'badge-notification': buttonBadgeConfig?.badgeType === 'notification' }\"\n    ></ui-badge>\n    <button\n      [style]=\"'--icon-button-size:' + iconButtonSize + 'px'\"\n      [ngClass]=\"classCss\"\n      [ngStyle]=\"styleCss\"\n      [disabled]=\"disabled\"\n      (click)=\"buttonClick($event)\"\n      (mouseleave)=\"buttonHover($event)\"\n      (mouseenter)=\"buttonHover($event)\"\n      (mousedown)=\"onPressed($event)\"\n      (mouseup)=\"onPressed($event)\"\n      (keydown)=\"onKeydown($event)\"\n      (keyup)=\"onKeyup($event)\"\n      *ngIf=\"isButtonLink\"\n      [attr.aria-required]=\"ariaRequired\"\n      [attr.aria-label]=\"ariaLabel\"\n      [attr.aria-labelledby]=\"'labelledby'\"\n      [attr.aria-describedby]=\"'describedby'\"\n      [attr.aria-disabled]=\"disabled\"\n      [type]=\"type\"\n      [disableRipple]=\"applicationTheme !== 'classic'\"\n      [matTooltip]=\"tooltip ? tooltip : labelEllipsis ? label : ''\"\n      [matTooltipClass]=\"applicationTheme\"\n      [matTooltipPosition]=\"tooltipPosition\"\n      #buttonElement\n      [attr.role]=\"role\"\n      mat-flat-button>\n      <span id=\"describedby\" [style.display]=\"'none'\">\n        {{ (isPremium ? (label + ' ' + ('BUTTON.PREMIUM_FEATURE' | uiTranslate | async)) : ariaDescribedby) }}\n      </span>\n      <span id=\"labelledby\" [style.display]=\"'none'\">\n        {{ ariaLabelledby }}\n      </span>\n      <ng-container *ngIf=\"showSpinner; else icons\">\n        <span class=\"spinner-wrapper\">\n          <mat-spinner class=\"position-spinner\" aria-label=\"loading\" mode=\"indeterminate\" diameter=\"24\"></mat-spinner>\n        </span>\n      </ng-container>\n      <ng-template #icons>\n      <span class=\"icon-only-wrapper\" *ngIf=\"justIcon && !!icon\">\n        <span\n          class=\"icon only\"\n          role=\"label\"\n        >\n          <ui-icon\n            [color]=\"'inherit'\"\n            [applicationTheme]=\"applicationTheme\"\n            [name]=\"icon\"\n            [filled]=\"isFilledIcon\"\n            [useFullIconName]=\"this.variant === 'primary' || this.variant === 'secondary'\"\n            [size]=\"size === 'small' ? '16' : '24'\"\n          ></ui-icon>\n        </span>\n      </span>\n\n        <span class=\"icon-label-wrapper\" [ngClass]=\"{'center-text': iconName === ''}\" *ngIf=\"!justIcon\">\n        <span\n          class=\"icon\"\n          *ngIf=\"iconPosition === 'left' && !!iconName\"\n          aria-hidden=\"true\"\n        >\n          <ui-icon\n            [color]=\"'inherit'\"\n            [applicationTheme]=\"applicationTheme\"\n            [name]=\"icon\"\n            [filled]=\"isFilledIcon\"\n            [useFullIconName]=\"this.variant === 'primary' || this.variant === 'secondary'\"\n            [size]=\"size === 'small' ? '16' : '24'\"\n          ></ui-icon>\n        </span>\n        <span\n          *ngIf=\"isLabel\"\n          class=\"label\"\n          id=\"label\"\n          uiEllipseText\n          [isMultiline]=\"true\"\n          (onChangeTextState)=\"onLabelEllipsisChange($event)\"\n        >\n          {{ label }}\n        </span>\n        <span class=\"icon\" *ngIf=\"iconPosition === 'right' && !!icon\" aria-hidden=\"true\"><ui-icon\n          [color]=\"'inherit'\" [applicationTheme]=\"applicationTheme\" [name]=\"icon\" [filled]=\"isFilledIcon\"\n          [size]=\"size === 'small' ? '16' : '24'\" [useFullIconName]=\"this.variant === 'primary' || this.variant === 'secondary'\"></ui-icon></span>\n      </span>\n      </ng-template>\n    </button>\n    <a\n      #buttonElement\n      [ngClass]=\"classCss\"\n      [ngStyle]=\"styleCss\"\n      [disabled]=\"disabled\"\n      (click)=\"buttonClick($event)\"\n      (mouseenter)=\"buttonHover($event)\"\n      (mouseleave)=\"buttonHover($event)\"\n      (mousedown)=\"onPressed($event)\"\n      (mouseup)=\"onPressed($event)\"\n      (keydown)=\"onKeydown($event);\"\n      (keyup)=\"onKeyup($event)\"\n      [disableRipple]=\"true\"\n      *ngIf=\"!isButtonLink\"\n      [attr.aria-required]=\"ariaRequired\"\n      [attr.aria-label]=\"ariaLabel\"\n      [attr.aria-labelledby]=\"'labelledby-link'\"\n      [attr.aria-describedby]=\"'describedby-link'\"\n      [attr.aria-disabled]=\"disabled\"\n      [matTooltip]=\"tooltip ? tooltip : labelEllipsis ? label : ''\"\n      [matTooltipClass]=\"applicationTheme\"\n      role=\"link\"\n      [href]=\"url\"\n      [target]=\"urlTarget\"\n      mat-flat-button>\n      <span id=\"describedby-link\" [style.display]=\"'none'\">\n        {{ ariaDescribedby }}\n      </span>\n      <span id=\"labelledby-link\" [style.display]=\"'none'\">\n        {{ ariaLabelledby }}\n      </span>\n      <span class=\"icon-label-wrapper\">\n        {{ label }}\n      </span>\n    </a>\n  </div>\n</div>\n"]}