@testgorilla/tgo-ui 2.23.19 → 2.23.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.
|
@@ -118,6 +118,9 @@ export class OverflowMenuComponent {
|
|
|
118
118
|
$event.preventDefault();
|
|
119
119
|
$event.stopPropagation();
|
|
120
120
|
}
|
|
121
|
+
else {
|
|
122
|
+
this.onSelectItem($event, button.value);
|
|
123
|
+
}
|
|
121
124
|
}
|
|
122
125
|
getMenu(index) {
|
|
123
126
|
return index >= 0 && this.matmenus ? this.matmenus.find((x, i) => i == index) : null;
|
|
@@ -199,4 +202,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
199
202
|
type: ViewChild,
|
|
200
203
|
args: ['buttonElement']
|
|
201
204
|
}] } });
|
|
202
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overflow-menu.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/overflow-menu/overflow-menu.component.ts","../../../../../projects/tgo-canopy-ui/components/overflow-menu/overflow-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Inject,\n  Input,\n  NgZone,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  signal,\n  ViewChild,\n  ViewChildren,\n  ViewEncapsulation\n} from '@angular/core';\nimport { IconName } from '../icon/icon.model';\nimport { OverflowMenuButtonModify, OverflowMenuButtonsType } from './overflow-menu.model';\nimport { ApplicationTheme } from \"../../models/application-theme.model\";\nimport { MatMenu, MatMenuTrigger } from \"@angular/material/menu\";\nimport { LanguageService } from \"../../utils/localization/language.service\";\nimport { FocusMonitor } from \"@angular/cdk/a11y\";\n\n@Component({\n  selector: 'ui-overflow-menu',\n  templateUrl: './overflow-menu.component.html',\n  styleUrls: ['./overflow-menu.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n\n})\nexport class OverflowMenuComponent implements OnInit {\n  /**\n   * Menu buttons\n   *\n   * @type {OverflowMenuButtonsType[]}\n   * @memberof OverflowMenuComponent\n   */\n  @Input() buttons: OverflowMenuButtonsType[];\n\n  /**\n   * Menu icon trigger\n   *\n   * @memberof OverflowMenuComponent\n   */\n  @Input() iconTrigger: IconName = 'Menu-ellipsis';\n\n  /**\n   * Label menu\n   *\n   * @memberof OverflowMenuComponent\n   */\n  @Input() menuLabel = '';\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof OverflowMenuComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * A string representing the ARIA label for accessibility.\n   * This label is used to provide an accessible name for the input element.\n   * @type {string}\n   * @memberof OverflowMenuComponent\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 OverflowMenuComponent\n   */\n  @Input() ariaRequired = false;\n\n  /**\n   * A string representing the ARIA requirement for accessibility.\n   * This attribute is used to indicate whether an input for description.\n   * @type {text}\n   * @memberof OverflowMenuComponent\n   */\n  @Input() describedby = '';\n\n  /**\n   * The language to be used\n   *\n   * @type {Language}\n   * @memberof OverflowMenuComponent\n   */\n  @Input() language = LanguageService.defaultLanguage;\n\n  @Output() selectItem: EventEmitter<string> = new EventEmitter<string>();\n\n  @Output() menuOpened = new EventEmitter<void>();\n\n  @Output() menuClosed = new EventEmitter<void>();\n\n  @ViewChildren(MatMenu) matmenus: QueryList<MatMenu>\n  @ViewChildren(MatMenuTrigger) matTrigger: QueryList<MatMenuTrigger>\n  @ViewChild('buttonElement') buttonElement: any;\n\n  menuItems: string[] = []\n  submenus: Array<OverflowMenuButtonModify[]> = []\n\n  isMenuRendered = signal(false);\n  isMenuOpened = signal(false);\n  isFocused = signal(false);\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private focusMonitor: FocusMonitor,\n    private ngZone: NgZone\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  ngOnInit() {\n    this.createSubmenus(this.buttons, \"s0\", 1)\n    this.reindex()\n  }\n\n  ngAfterViewInit() {\n    queueMicrotask(() => {\n      this.isMenuRendered.set(true);\n    })\n\n    setTimeout(() => {\n      this.focusMonitor.monitor(this.buttonElement).subscribe(origin => this.ngZone.run(() => {\n        if (origin === 'keyboard') {\n          this.isFocused.set(true);\n        } else {\n          if (!this.isMenuOpened()) {\n            this.isFocused.set(false);\n          }\n        }\n      }));\n    }, 0)\n  }\n\n  onSelectItem(event: Event, value: string) {\n    if (!!value) {\n      this.selectItem.emit(value);\n    }\n  }\n\n  onMenuOpened(): void {\n    this.menuOpened.emit();\n    this.isMenuOpened.set(true);\n\n    if (this.isFocused()) {\n      setTimeout(() => {\n        this.matmenus.first._allItems.first.focus('keyboard');\n      }, 300)\n    }\n  }\n\n  onMenuClosed(): void {\n    this.isMenuOpened.set(false);\n    this.menuClosed.emit();\n  }\n\n  onButtonFocus(button: OverflowMenuButtonModify) {\n    button.isFocused = true;\n  }\n\n  onButtonBlur(button: OverflowMenuButtonModify) {\n    button.isFocused = false;\n  }\n\n  onButtonClick(button: OverflowMenuButtonModify, $event: Event) {\n    if (button.disabled) {\n      $event.preventDefault();\n      $event.stopPropagation();\n    }\n  }\n\n  getMenu(index: any) {\n    return index >= 0 && this.matmenus ? this.matmenus.find((x, i) => i == index)! : null\n  }\n\n  private reindex() {\n    this.submenus.forEach((menu: OverflowMenuButtonsType[]) => {\n      menu.forEach((item: OverflowMenuButtonsType, index: number) => {\n        if (item.subMenu !== -1)\n          item.subMenu = this.menuItems.indexOf(item.action + '')\n      })\n    })\n  }\n\n  private createSubmenus(menu: OverflowMenuButtonsType[], prefix: string, count: number): void {\n    this.menuItems.push(prefix);\n    this.submenus.push(\n      menu.map((item: OverflowMenuButtonsType, index: number) => {\n        return (\n          {\n            label: item.label,\n            icon: item.icon,\n            isDestructive: item.isDestructive,\n            value: item.value,\n            disabled: item.disabled,\n            btnTemplate: item.btnTemplate,\n            subMenu: item.subMenu ? 0 : -1,\n            action: item.action ? item.action : prefix+index\n          }\n        )\n      })\n    );\n\n    menu.forEach((item: OverflowMenuButtonsType, index: number) => {\n      if (item.subMenu) {\n        this.createSubmenus((item as { subMenu: OverflowMenuButtonsType[] }).subMenu, prefix + index, count + 1);\n      }\n    })\n  }\n\n  onSubmenuOpened(): void {\n    this.isMenuOpened.set(!this.isMenuOpened);\n    setTimeout(() => {\n      this.matmenus.last._allItems.first.focus('keyboard');\n    }, 300)\n  }\n}\n","<div class=\"overflow-menu-container\" [attr.theme]=\"applicationTheme\">\n\n  <button\n    #buttonElement\n    mat-icon-button\n    *ngIf=\"isMenuRendered()\"\n    [matMenuTriggerFor]=\"matmenus.first\"\n    [attr.aria-label]=\"ariaLabel\"\n    [attr.aria-required]=\"ariaRequired\"\n    [attr.aria-describedby]=\"'describedby'\"\n    [attr.aria-haspopup]=\"true\"\n    [attr.aria-expanded]=\"isMenuOpened()\"\n    (menuOpened)=\"onMenuOpened()\"\n    (menuClosed)=\"onMenuClosed()\"\n    class=\"overflow-menu-opener\"\n    [matTooltip]=\"menuLabel\"\n  >\n    <span [id]=\"'describedby'\" [style.display]=\"'none'\">{{ describedby }}</span>\n    <ui-icon\n      [name]=\"iconTrigger\"\n      [applicationTheme]=\"applicationTheme\"\n      [size]=\"'24'\"\n      [color]=\"'rebrand-black'\"\n    ></ui-icon>\n  </button>\n\n  @for (menu of submenus; track menu) {\n    <mat-menu #matMenu class=\"overflow-menu\" [overlapTrigger]=\"false\" backdropClass=\"overflow-menu-backdrop\">\n      <ng-container *ngFor=\"let button of menu; index as id\">\n        <ng-container\n          *ngIf=\"button.btnTemplate; else uiButton\"\n          [ngTemplateOutlet]=\"button.btnTemplate\"\n          [ngTemplateOutletContext]=\"{ $implicit: button }\"\n        ></ng-container>\n\n        <ng-template #uiButton>\n          <button\n            mat-menu-item\n            [matMenuTriggerFor]=\"getMenu(button.subMenu)\"\n            (menuOpened)=\"onSubmenuOpened()\"\n            (focus)=\"onButtonFocus(button);\"\n            (blur)=\"onButtonBlur(button)\"\n            [ngClass]=\"{ 'is-destructive': button.isDestructive, disabled: button.disabled }\"\n            [disableRipple]=\"true\"\n            (click)=\"onButtonClick(button, $event)\"\n            [matTooltip]=\"button.isTextEllipsed ? button.label : ''\"\n            [attr.aria-labelledby]=\"'labelledby-' + button.label + id\"\n            [attr.aria-describedby]=\"'describedby-' + button.label + id\"\n            [attr.aria-label]=\"button.ariaLabel || null\"\n            role=\"menuitem\"\n            matTooltipPosition=\"right\"\n          >\n            <span\n              [id]=\"'describedby-' + button.label + id\"\n              [style.display]=\"'none'\"\n            >\n              {{ button.disabled ? ('MENU.MENUITEM_DISABLED' | uiTranslate : language) + ' ' + (button.describedby || '') : button.describedby }}\n            </span>\n            <ui-icon\n              [name]=\"button.icon\"\n              [filled]=\"button.disabled ? false : !!button.isFocused\"\n              [applicationTheme]=\"applicationTheme\"\n              [size]=\"'24'\"\n              [color]=\"button.isDestructive ? 'red' : button.disabled ? 'dark' : 'rebrand-black'\"\n            ></ui-icon>\n            <span\n              [id]=\"'labelledby-' + button.label + id\"\n              class=\"label\"\n              uiEllipseText\n              [refresh]=\"isMenuOpened()\"\n              [maxDiffPixels]=\"1\"\n              [isMultiline]=\"true\"\n              (onChangeTextState)=\"button.isTextEllipsed = $event\"\n            >{{ button.label }}</span>\n          </button>\n        </ng-template>\n      </ng-container>\n\n      <ng-content select=\"[menu-content]\"></ng-content>\n\n    </mat-menu>\n  }\n</div>\n"]}
|
|
205
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overflow-menu.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/overflow-menu/overflow-menu.component.ts","../../../../../projects/tgo-canopy-ui/components/overflow-menu/overflow-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Inject,\n  Input,\n  NgZone,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  signal,\n  ViewChild,\n  ViewChildren,\n  ViewEncapsulation\n} from '@angular/core';\nimport { IconName } from '../icon/icon.model';\nimport { OverflowMenuButtonModify, OverflowMenuButtonsType } from './overflow-menu.model';\nimport { ApplicationTheme } from \"../../models/application-theme.model\";\nimport { MatMenu, MatMenuTrigger } from \"@angular/material/menu\";\nimport { LanguageService } from \"../../utils/localization/language.service\";\nimport { FocusMonitor } from \"@angular/cdk/a11y\";\n\n@Component({\n  selector: 'ui-overflow-menu',\n  templateUrl: './overflow-menu.component.html',\n  styleUrls: ['./overflow-menu.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n\n})\nexport class OverflowMenuComponent implements OnInit {\n  /**\n   * Menu buttons\n   *\n   * @type {OverflowMenuButtonsType[]}\n   * @memberof OverflowMenuComponent\n   */\n  @Input() buttons: OverflowMenuButtonsType[];\n\n  /**\n   * Menu icon trigger\n   *\n   * @memberof OverflowMenuComponent\n   */\n  @Input() iconTrigger: IconName = 'Menu-ellipsis';\n\n  /**\n   * Label menu\n   *\n   * @memberof OverflowMenuComponent\n   */\n  @Input() menuLabel = '';\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof OverflowMenuComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * A string representing the ARIA label for accessibility.\n   * This label is used to provide an accessible name for the input element.\n   * @type {string}\n   * @memberof OverflowMenuComponent\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 OverflowMenuComponent\n   */\n  @Input() ariaRequired = false;\n\n  /**\n   * A string representing the ARIA requirement for accessibility.\n   * This attribute is used to indicate whether an input for description.\n   * @type {text}\n   * @memberof OverflowMenuComponent\n   */\n  @Input() describedby = '';\n\n  /**\n   * The language to be used\n   *\n   * @type {Language}\n   * @memberof OverflowMenuComponent\n   */\n  @Input() language = LanguageService.defaultLanguage;\n\n  @Output() selectItem: EventEmitter<string> = new EventEmitter<string>();\n\n  @Output() menuOpened = new EventEmitter<void>();\n\n  @Output() menuClosed = new EventEmitter<void>();\n\n  @ViewChildren(MatMenu) matmenus: QueryList<MatMenu>\n  @ViewChildren(MatMenuTrigger) matTrigger: QueryList<MatMenuTrigger>\n  @ViewChild('buttonElement') buttonElement: any;\n\n  menuItems: string[] = []\n  submenus: Array<OverflowMenuButtonModify[]> = []\n\n  isMenuRendered = signal(false);\n  isMenuOpened = signal(false);\n  isFocused = signal(false);\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private focusMonitor: FocusMonitor,\n    private ngZone: NgZone\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  ngOnInit() {\n    this.createSubmenus(this.buttons, \"s0\", 1)\n    this.reindex()\n  }\n\n  ngAfterViewInit() {\n    queueMicrotask(() => {\n      this.isMenuRendered.set(true);\n    })\n\n    setTimeout(() => {\n      this.focusMonitor.monitor(this.buttonElement).subscribe(origin => this.ngZone.run(() => {\n        if (origin === 'keyboard') {\n          this.isFocused.set(true);\n        } else {\n          if (!this.isMenuOpened()) {\n            this.isFocused.set(false);\n          }\n        }\n      }));\n    }, 0)\n  }\n\n  onSelectItem(event: Event, value: string) {\n    if (!!value) {\n      this.selectItem.emit(value);\n    }\n  }\n\n  onMenuOpened(): void {\n    this.menuOpened.emit();\n    this.isMenuOpened.set(true);\n\n    if (this.isFocused()) {\n      setTimeout(() => {\n        this.matmenus.first._allItems.first.focus('keyboard');\n      }, 300)\n    }\n  }\n\n  onMenuClosed(): void {\n    this.isMenuOpened.set(false);\n    this.menuClosed.emit();\n  }\n\n  onButtonFocus(button: OverflowMenuButtonModify) {\n    button.isFocused = true;\n  }\n\n  onButtonBlur(button: OverflowMenuButtonModify) {\n    button.isFocused = false;\n  }\n\n  onButtonClick(button: OverflowMenuButtonModify, $event: Event) {\n    if (button.disabled) {\n      $event.preventDefault();\n      $event.stopPropagation();\n    } else {\n      this.onSelectItem($event, button.value)\n    }\n  }\n\n  getMenu(index: any) {\n    return index >= 0 && this.matmenus ? this.matmenus.find((x, i) => i == index)! : null\n  }\n\n  private reindex() {\n    this.submenus.forEach((menu: OverflowMenuButtonsType[]) => {\n      menu.forEach((item: OverflowMenuButtonsType, index: number) => {\n        if (item.subMenu !== -1)\n          item.subMenu = this.menuItems.indexOf(item.action + '')\n      })\n    })\n  }\n\n  private createSubmenus(menu: OverflowMenuButtonsType[], prefix: string, count: number): void {\n    this.menuItems.push(prefix);\n    this.submenus.push(\n      menu.map((item: OverflowMenuButtonsType, index: number) => {\n        return (\n          {\n            label: item.label,\n            icon: item.icon,\n            isDestructive: item.isDestructive,\n            value: item.value,\n            disabled: item.disabled,\n            btnTemplate: item.btnTemplate,\n            subMenu: item.subMenu ? 0 : -1,\n            action: item.action ? item.action : prefix+index\n          }\n        )\n      })\n    );\n\n    menu.forEach((item: OverflowMenuButtonsType, index: number) => {\n      if (item.subMenu) {\n        this.createSubmenus((item as { subMenu: OverflowMenuButtonsType[] }).subMenu, prefix + index, count + 1);\n      }\n    })\n  }\n\n  onSubmenuOpened(): void {\n    this.isMenuOpened.set(!this.isMenuOpened);\n    setTimeout(() => {\n      this.matmenus.last._allItems.first.focus('keyboard');\n    }, 300)\n  }\n}\n","<div class=\"overflow-menu-container\" [attr.theme]=\"applicationTheme\">\n\n  <button\n    #buttonElement\n    mat-icon-button\n    *ngIf=\"isMenuRendered()\"\n    [matMenuTriggerFor]=\"matmenus.first\"\n    [attr.aria-label]=\"ariaLabel\"\n    [attr.aria-required]=\"ariaRequired\"\n    [attr.aria-describedby]=\"'describedby'\"\n    [attr.aria-haspopup]=\"true\"\n    [attr.aria-expanded]=\"isMenuOpened()\"\n    (menuOpened)=\"onMenuOpened()\"\n    (menuClosed)=\"onMenuClosed()\"\n    class=\"overflow-menu-opener\"\n    [matTooltip]=\"menuLabel\"\n  >\n    <span [id]=\"'describedby'\" [style.display]=\"'none'\">{{ describedby }}</span>\n    <ui-icon\n      [name]=\"iconTrigger\"\n      [applicationTheme]=\"applicationTheme\"\n      [size]=\"'24'\"\n      [color]=\"'rebrand-black'\"\n    ></ui-icon>\n  </button>\n\n  @for (menu of submenus; track menu) {\n    <mat-menu #matMenu class=\"overflow-menu\" [overlapTrigger]=\"false\" backdropClass=\"overflow-menu-backdrop\">\n      <ng-container *ngFor=\"let button of menu; index as id\">\n        <ng-container\n          *ngIf=\"button.btnTemplate; else uiButton\"\n          [ngTemplateOutlet]=\"button.btnTemplate\"\n          [ngTemplateOutletContext]=\"{ $implicit: button }\"\n        ></ng-container>\n\n        <ng-template #uiButton>\n          <button\n            mat-menu-item\n            [matMenuTriggerFor]=\"getMenu(button.subMenu)\"\n            (menuOpened)=\"onSubmenuOpened()\"\n            (focus)=\"onButtonFocus(button);\"\n            (blur)=\"onButtonBlur(button)\"\n            [ngClass]=\"{ 'is-destructive': button.isDestructive, disabled: button.disabled }\"\n            [disableRipple]=\"true\"\n            (click)=\"onButtonClick(button, $event)\"\n            [matTooltip]=\"button.isTextEllipsed ? button.label : ''\"\n            [attr.aria-labelledby]=\"'labelledby-' + button.label + id\"\n            [attr.aria-describedby]=\"'describedby-' + button.label + id\"\n            [attr.aria-label]=\"button.ariaLabel || null\"\n            role=\"menuitem\"\n            matTooltipPosition=\"right\"\n          >\n            <span\n              [id]=\"'describedby-' + button.label + id\"\n              [style.display]=\"'none'\"\n            >\n              {{ button.disabled ? ('MENU.MENUITEM_DISABLED' | uiTranslate : language) + ' ' + (button.describedby || '') : button.describedby }}\n            </span>\n            <ui-icon\n              [name]=\"button.icon\"\n              [filled]=\"button.disabled ? false : !!button.isFocused\"\n              [applicationTheme]=\"applicationTheme\"\n              [size]=\"'24'\"\n              [color]=\"button.isDestructive ? 'red' : button.disabled ? 'dark' : 'rebrand-black'\"\n            ></ui-icon>\n            <span\n              [id]=\"'labelledby-' + button.label + id\"\n              class=\"label\"\n              uiEllipseText\n              [refresh]=\"isMenuOpened()\"\n              [maxDiffPixels]=\"1\"\n              [isMultiline]=\"true\"\n              (onChangeTextState)=\"button.isTextEllipsed = $event\"\n            >{{ button.label }}</span>\n          </button>\n        </ng-template>\n      </ng-container>\n\n      <ng-content select=\"[menu-content]\"></ng-content>\n\n    </mat-menu>\n  }\n</div>\n"]}
|
|
@@ -11659,6 +11659,9 @@ class OverflowMenuComponent {
|
|
|
11659
11659
|
$event.preventDefault();
|
|
11660
11660
|
$event.stopPropagation();
|
|
11661
11661
|
}
|
|
11662
|
+
else {
|
|
11663
|
+
this.onSelectItem($event, button.value);
|
|
11664
|
+
}
|
|
11662
11665
|
}
|
|
11663
11666
|
getMenu(index) {
|
|
11664
11667
|
return index >= 0 && this.matmenus ? this.matmenus.find((x, i) => i == index) : null;
|