@testgorilla/tgo-ui 2.26.8 → 2.26.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,9 +1,9 @@
1
1
  import { AfterViewInit, ElementRef, EventEmitter, OnInit, SimpleChanges } from '@angular/core';
2
- import { IconName } from '../icon/icon.model';
3
- import { ButtonBadgeConfig, ButtonColor, ButtonIconPosition, ButtonSize, ButtonState, ButtonType, IconButtonSize, LinkUrlTarget } from './button.model';
4
2
  import { MatButton } from '@angular/material/button';
5
- import { ApplicationTheme } from '../../models/application-theme.model';
6
3
  import { TooltipPosition } from '@angular/material/tooltip';
4
+ import { ApplicationTheme } from '../../models/application-theme.model';
5
+ import { IconName } from '../icon/icon.model';
6
+ import { ButtonBadgeConfig, ButtonColor, ButtonIconPosition, ButtonSize, ButtonState, ButtonType, IconButtonSize, LinkUrlTarget } from './button.model';
7
7
  import * as i0 from "@angular/core";
8
8
  export declare class ButtonComponent implements OnInit, AfterViewInit {
9
9
  private readonly defaultAppTheme;
@@ -244,13 +244,13 @@ export class ButtonComponent {
244
244
  this.buttonHoverEvent.emit(event);
245
245
  this.buttonState = 'hover';
246
246
  if (this.shouldChangeFilledStatus && this.icon) {
247
- this.icon = this.getIconName(this.icon, '-filled');
247
+ this.icon = this.getIconName(this.iconName, '-filled');
248
248
  }
249
249
  }
250
250
  else {
251
251
  this.hover = false;
252
252
  if (this.shouldChangeFilledStatus && this.icon) {
253
- this.icon = this.getIconName(this.icon, '-in-line');
253
+ this.icon = this.iconName;
254
254
  }
255
255
  this.buttonState = 'default';
256
256
  }
@@ -442,4 +442,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
442
442
  type: HostBinding,
443
443
  args: ['style.--color']
444
444
  }] } });
445
- //# 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';\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  @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.icon, '-filled');\n      }\n    } else {\n      this.hover = false;\n      if (this.shouldChangeFilledStatus && this.icon) {\n        this.icon = this.getIconName(this.icon, '-in-line');\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(): void {\n    this.buttonElement.focus();\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      role=\"button\"\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"]}
445
+ //# 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 { MatButton } from '@angular/material/button';\nimport { TooltipPosition } from '@angular/material/tooltip';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { adjustLightness } from '../../utils/color-contrast';\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';\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  @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(): void {\n    this.buttonElement.focus();\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      role=\"button\"\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"]}
@@ -5350,13 +5350,13 @@ class ButtonComponent {
5350
5350
  this.buttonHoverEvent.emit(event);
5351
5351
  this.buttonState = 'hover';
5352
5352
  if (this.shouldChangeFilledStatus && this.icon) {
5353
- this.icon = this.getIconName(this.icon, '-filled');
5353
+ this.icon = this.getIconName(this.iconName, '-filled');
5354
5354
  }
5355
5355
  }
5356
5356
  else {
5357
5357
  this.hover = false;
5358
5358
  if (this.shouldChangeFilledStatus && this.icon) {
5359
- this.icon = this.getIconName(this.icon, '-in-line');
5359
+ this.icon = this.iconName;
5360
5360
  }
5361
5361
  this.buttonState = 'default';
5362
5362
  }