All files / header-dropdown si-header-dropdown-item.component.ts

92.3% Statements 12/13
50% Branches 1/2
100% Functions 1/1
92.3% Lines 12/13

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54                                                1x   112x   112x   112x   112x   112x   112x       112x 112x       11x 3x 3x            
/**
 * Copyright (c) Siemens 2016 - 2025
 * SPDX-License-Identifier: MIT
 */
import { NgClass } from '@angular/common';
import { ChangeDetectionStrategy, Component, HostListener, inject, input } from '@angular/core';
import { SiIconComponent } from '@siemens/element-ng/icon';
 
import { SiHeaderDropdownTriggerDirective } from './si-header-dropdown-trigger.directive';
import { SI_HEADER_WITH_DROPDOWNS } from './si-header.model';
 
/**
 * Creates a dropdown-item. Must be used within an {@link SiHeaderDropdownComponent}.
 */
@Component({
  selector: 'si-header-dropdown-item, a[si-header-dropdown-item], button[si-header-dropdown-item]',
  imports: [NgClass, SiIconComponent],
  templateUrl: './si-header-dropdown-item.component.html',
  styleUrl: './si-header-dropdown-item.component.scss',
  changeDetection: ChangeDetectionStrategy.OnPush,
  host: {
    class: 'dropdown-item focus-inside'
  }
})
export class SiHeaderDropdownItemComponent {
  /** Optional icon that will be rendered before the label. */
  readonly icon = input<string>();
  /** Badge that is rendered after the label. */
  readonly badge = input<string | number>();
  /** Badge (always red) that is attached to the icon. */
  readonly iconBadge = input<string | number>();
  /** Color of the badge (not iconBadge). */
  readonly badgeColor = input<string>();
  /** Whether the icon is checked with a radio or check mark. */
  readonly checked = input<'radio' | 'check' | ''>();
 
  protected readonly ownTrigger = inject(SiHeaderDropdownTriggerDirective, {
    self: true,
    optional: true
  });
  protected readonly parentTrigger = inject(SiHeaderDropdownTriggerDirective, { skipSelf: true });
  protected readonly navbar = inject(SI_HEADER_WITH_DROPDOWNS, { optional: true });
 
  @HostListener('click')
  protected click(): void {
    if (!this.ownTrigger) {
      this.parentTrigger.close({ all: true });
      Iif (this.navbar?.onDropdownItemTriggered) {
        this.navbar?.onDropdownItemTriggered();
      }
    }
  }
}