@seniorsistemas/angular-components 17.9.1 → 17.9.3

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.
Files changed (30) hide show
  1. package/bundles/seniorsistemas-angular-components.umd.js +60 -27
  2. package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
  3. package/bundles/seniorsistemas-angular-components.umd.min.js +1 -1
  4. package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
  5. package/components/kanban/components/kanban-column/kanban-column.component.d.ts +2 -0
  6. package/components/kanban/components/kanban-item/kanban-item.component.d.ts +7 -4
  7. package/components/kanban/kanban.component.d.ts +7 -5
  8. package/components/kanban/models/index.d.ts +1 -1
  9. package/components/kanban/models/kanban-data.d.ts +9 -2
  10. package/components/tooltip/tooltip.directive.d.ts +1 -2
  11. package/esm2015/components/kanban/components/kanban-column/kanban-column.component.js +14 -2
  12. package/esm2015/components/kanban/components/kanban-item/kanban-item.component.js +20 -6
  13. package/esm2015/components/kanban/kanban.component.js +26 -18
  14. package/esm2015/components/kanban/models/index.js +1 -1
  15. package/esm2015/components/kanban/models/kanban-data.js +1 -1
  16. package/esm2015/components/navigation-button/navigation-button.component.js +5 -1
  17. package/esm2015/components/tooltip/tooltip.directive.js +7 -14
  18. package/esm5/components/kanban/components/kanban-column/kanban-column.component.js +16 -3
  19. package/esm5/components/kanban/components/kanban-item/kanban-item.component.js +22 -7
  20. package/esm5/components/kanban/kanban.component.js +26 -18
  21. package/esm5/components/kanban/models/index.js +1 -1
  22. package/esm5/components/kanban/models/kanban-data.js +1 -1
  23. package/esm5/components/navigation-button/navigation-button.component.js +5 -1
  24. package/esm5/components/tooltip/tooltip.directive.js +7 -14
  25. package/fesm2015/seniorsistemas-angular-components.js +58 -27
  26. package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
  27. package/fesm5/seniorsistemas-angular-components.js +60 -27
  28. package/fesm5/seniorsistemas-angular-components.js.map +1 -1
  29. package/package.json +1 -1
  30. package/seniorsistemas-angular-components.metadata.json +1 -1
@@ -1 +1 @@
1
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2FuYmFuLWRhdGEuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9rYW5iYW4vbW9kZWxzL2thbmJhbi1kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUaWVyZWRNZW51SXRlbURhdGEgfSBmcm9tIFwiLi4vLi4vdGllcmVkLW1lbnUvbW9kZWxzL3RpZXJlZC1tZW51LWl0ZW0tZGF0YVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEthbmJhbkRhdGEge1xuICAgIGNvbHVtbnM6IEthbmJhbkNvbHVtbltdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEthbmJhbkNvbHVtbiB7XG4gICAgaWQ/OiBzdHJpbmc7XG4gICAgdGl0bGU6IHN0cmluZztcbiAgICBpdGVtczogS2FuYmFuSXRlbVtdO1xuICAgIG9wdGlvbnM/OiBUaWVyZWRNZW51SXRlbURhdGFbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBLYW5iYW5JdGVtIHtcbiAgICBvcHRpb25zPzogVGllcmVkTWVudUl0ZW1EYXRhW107XG4gICAgZGlzYWJsZWQ/OiBib29sZWFuO1xuICAgIGRhdGE6IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBLYW5iYW5JdGVtTW92ZWREYXRhIHtcbiAgICBpdGVtczogS2FuYmFuSXRlbVtdLFxuICAgIHByZXZpb3VzQ29sdW1uOiBLYW5iYW5Db2x1bW47XG4gICAgdGFyZ2V0Q29sdW1uOiBLYW5iYW5Db2x1bW47XG59XG4iXX0=
1
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2FuYmFuLWRhdGEuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9rYW5iYW4vbW9kZWxzL2thbmJhbi1kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUaWVyZWRNZW51SXRlbURhdGEgfSBmcm9tIFwiLi4vLi4vdGllcmVkLW1lbnUvbW9kZWxzL3RpZXJlZC1tZW51LWl0ZW0tZGF0YVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEthbmJhbkRhdGEge1xuICAgIGNvbHVtbnM6IEthbmJhbkNvbHVtbltdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEthbmJhbkNvbHVtbiB7XG4gICAgaWQ/OiBzdHJpbmc7XG4gICAgdGl0bGU6IHN0cmluZztcbiAgICBpdGVtczogS2FuYmFuSXRlbVtdO1xuICAgIG9wdGlvbnM/OiBLYW5iYW5Db2x1bW5PcHRpb25bXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBLYW5iYW5JdGVtIHtcbiAgICBvcHRpb25zPzogS2FuYmFuSXRlbU9wdGlvbltdO1xuICAgIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgICBmcm96ZW4/OiBib29sZWFuO1xuICAgIGRhdGE6IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBLYW5iYW5JdGVtTW92ZWREYXRhIHtcbiAgICBpdGVtczogS2FuYmFuSXRlbVtdLFxuICAgIHByZXZpb3VzQ29sdW1uOiBLYW5iYW5Db2x1bW47XG4gICAgdGFyZ2V0Q29sdW1uOiBLYW5iYW5Db2x1bW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgS2FuYmFuQ29sdW1uT3B0aW9uIGV4dGVuZHMgT21pdDxUaWVyZWRNZW51SXRlbURhdGEsICdjb21tYW5kJz4ge1xuICAgIGNvbW1hbmQ6IChjb2x1bW46IEthbmJhbkNvbHVtbikgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBLYW5iYW5JdGVtT3B0aW9uIGV4dGVuZHMgT21pdDxUaWVyZWRNZW51SXRlbURhdGEsICdjb21tYW5kJz4ge1xuICAgIGNvbW1hbmQ6IChpdGVtOiBLYW5iYW5JdGVtKSA9PiB2b2lkO1xufVxuIl19
@@ -29,6 +29,10 @@ var NavigationButtonComponent = /** @class */ (function () {
29
29
  this._value = this.defaultValue;
30
30
  var index = this.steps.findIndex(function (step) { return step.value === _this._value; });
31
31
  this.currentIndex = index !== -1 ? index : 0;
32
+ this.stepChanged.emit({
33
+ previous: undefined,
34
+ current: this.steps[this.currentIndex],
35
+ });
32
36
  this.changeDetectorRef.detectChanges();
33
37
  }
34
38
  };
@@ -124,4 +128,4 @@ var NavigationButtonComponent = /** @class */ (function () {
124
128
  return NavigationButtonComponent;
125
129
  }());
126
130
  export { NavigationButtonComponent };
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation-button.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/navigation-button/navigation-button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, forwardRef, OnInit, AfterViewInit, ChangeDetectorRef } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\nimport { NavigationButtonItem } from \"./models/navigation-button-item\";\nimport { TieredMenuItemData } from \"../tiered-menu\";\nimport { NavigationButtonStepChangedInfo } from \"./models\";\n\n@Component({\n    selector: \"s-navigation-button\",\n    templateUrl: \"./navigation-button.component.html\",\n    styleUrls: [\"./navigation-button.component.scss\"],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => NavigationButtonComponent),\n            multi: true,\n        },\n    ],\n})\nexport class NavigationButtonComponent implements ControlValueAccessor, OnInit, AfterViewInit {\n    @Input()\n    public steps: NavigationButtonItem[];\n\n    @Input()\n    public defaultValue: unknown;\n\n    @Input()\n    public tooltip: string;\n\n    @Input()\n    public changeOnInit = false;\n\n    @Output()\n    public stepChanged: EventEmitter<NavigationButtonStepChangedInfo> = new EventEmitter();\n\n    public currentIndex = 0;\n    public isDisabled = false;\n    public tieredMenuItems: TieredMenuItemData[] = [];\n\n    private _onChange: (value: unknown) => void;\n    private _onTouched: () => void;\n    private _value: unknown;\n\n    constructor(private readonly changeDetectorRef: ChangeDetectorRef) { }\n\n    public ngOnInit(): void {\n        this._createTieredMenuItems();\n\n        if (this.changeOnInit) {\n            this.stepChanged.emit({\n                previous: undefined,\n                current: this.steps[this.currentIndex],\n            });\n        }\n    }\n\n    public ngAfterViewInit(): void {\n        this._setDefaultValue();\n    }\n\n    private _setDefaultValue(): void {\n        if (this.defaultValue) {\n            this._value = this.defaultValue;\n\n            const index = this.steps.findIndex((step) => step.value === this._value);\n            this.currentIndex = index !== -1 ? index : 0;\n\n            this.changeDetectorRef.detectChanges();\n        }\n    }\n\n    public writeValue(value: unknown): void {\n        this._value = value;\n\n        const index = this.steps.findIndex((step) => step.value === this._value);\n        this.currentIndex = index !== -1 ? index : 0;\n    }\n\n    public registerOnChange(onChange: (value: unknown) => void): void {\n        this._onChange = onChange;\n    }\n\n    public registerOnTouched(onTouched: () => void): void {\n        this._onTouched = onTouched;\n    }\n\n    public setDisabledState?(isDisabled: boolean): void {\n        this.isDisabled = isDisabled;\n    }\n\n    public onNext(): void {\n        if (this.isDisabled) return;\n\n        const previous = this.steps[this.currentIndex];\n\n        if (this.currentIndex < this.steps.length - 1) {\n            this.currentIndex++;\n\n            const current = this.steps[this.currentIndex];\n\n            this._onChange && this._onChange(current.value);\n            this.stepChanged.emit({ previous, current });\n        }\n\n        this._onTouched && this._onTouched();\n    }\n\n    public onPrevious(): void {\n        if (this.isDisabled) return;\n\n        const previous = this.steps[this.currentIndex];\n\n        if (this.currentIndex > 0) {\n            this.currentIndex--;\n\n            const current = this.steps[this.currentIndex];\n\n            this._onChange && this._onChange(current.value);\n            this.stepChanged.emit({ previous, current });\n        }\n\n        this._onTouched && this._onTouched();\n    }\n\n    private _createTieredMenuItems() {\n        this.steps.forEach((step: NavigationButtonItem) => {\n            this.tieredMenuItems.push({\n                label: step.label,\n                command: () => {\n                    const index = this.steps.findIndex((s) => s === step);\n                    if (this.currentIndex !== index) {\n                        this._onChange && this._onChange(step.value);\n                        this.stepChanged.emit({ previous: this.steps[this.currentIndex], current: step });\n                        this.currentIndex = index;\n                    }\n\n                    this._onTouched && this._onTouched();\n                },\n            });\n        });\n    }\n}\n"]}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation-button.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/navigation-button/navigation-button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, forwardRef, OnInit, AfterViewInit, ChangeDetectorRef } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\nimport { NavigationButtonItem } from \"./models/navigation-button-item\";\nimport { TieredMenuItemData } from \"../tiered-menu\";\nimport { NavigationButtonStepChangedInfo } from \"./models\";\n\n@Component({\n    selector: \"s-navigation-button\",\n    templateUrl: \"./navigation-button.component.html\",\n    styleUrls: [\"./navigation-button.component.scss\"],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => NavigationButtonComponent),\n            multi: true,\n        },\n    ],\n})\nexport class NavigationButtonComponent implements ControlValueAccessor, OnInit, AfterViewInit {\n    @Input()\n    public steps: NavigationButtonItem[];\n\n    @Input()\n    public defaultValue: unknown;\n\n    @Input()\n    public tooltip: string;\n\n    @Input()\n    public changeOnInit = false;\n\n    @Output()\n    public stepChanged: EventEmitter<NavigationButtonStepChangedInfo> = new EventEmitter();\n\n    public currentIndex = 0;\n    public isDisabled = false;\n    public tieredMenuItems: TieredMenuItemData[] = [];\n\n    private _onChange: (value: unknown) => void;\n    private _onTouched: () => void;\n    private _value: unknown;\n\n    constructor(private readonly changeDetectorRef: ChangeDetectorRef) { }\n\n    public ngOnInit(): void {\n        this._createTieredMenuItems();\n\n        if (this.changeOnInit) {\n            this.stepChanged.emit({\n                previous: undefined,\n                current: this.steps[this.currentIndex],\n            });\n        }\n    }\n\n    public ngAfterViewInit(): void {\n        this._setDefaultValue();\n    }\n\n    private _setDefaultValue(): void {\n        if (this.defaultValue) {\n            this._value = this.defaultValue;\n\n            const index = this.steps.findIndex((step) => step.value === this._value);\n            this.currentIndex = index !== -1 ? index : 0;\n            this.stepChanged.emit({\n                previous: undefined,\n                current: this.steps[this.currentIndex],\n            });\n\n            this.changeDetectorRef.detectChanges();\n        }\n    }\n\n    public writeValue(value: unknown): void {\n        this._value = value;\n\n        const index = this.steps.findIndex((step) => step.value === this._value);\n        this.currentIndex = index !== -1 ? index : 0;\n    }\n\n    public registerOnChange(onChange: (value: unknown) => void): void {\n        this._onChange = onChange;\n    }\n\n    public registerOnTouched(onTouched: () => void): void {\n        this._onTouched = onTouched;\n    }\n\n    public setDisabledState?(isDisabled: boolean): void {\n        this.isDisabled = isDisabled;\n    }\n\n    public onNext(): void {\n        if (this.isDisabled) return;\n\n        const previous = this.steps[this.currentIndex];\n\n        if (this.currentIndex < this.steps.length - 1) {\n            this.currentIndex++;\n\n            const current = this.steps[this.currentIndex];\n\n            this._onChange && this._onChange(current.value);\n            this.stepChanged.emit({ previous, current });\n        }\n\n        this._onTouched && this._onTouched();\n    }\n\n    public onPrevious(): void {\n        if (this.isDisabled) return;\n\n        const previous = this.steps[this.currentIndex];\n\n        if (this.currentIndex > 0) {\n            this.currentIndex--;\n\n            const current = this.steps[this.currentIndex];\n\n            this._onChange && this._onChange(current.value);\n            this.stepChanged.emit({ previous, current });\n        }\n\n        this._onTouched && this._onTouched();\n    }\n\n    private _createTieredMenuItems() {\n        this.steps.forEach((step: NavigationButtonItem) => {\n            this.tieredMenuItems.push({\n                label: step.label,\n                command: () => {\n                    const index = this.steps.findIndex((s) => s === step);\n                    if (this.currentIndex !== index) {\n                        this._onChange && this._onChange(step.value);\n                        this.stepChanged.emit({ previous: this.steps[this.currentIndex], current: step });\n                        this.currentIndex = index;\n                    }\n\n                    this._onTouched && this._onTouched();\n                },\n            });\n        });\n    }\n}\n"]}
@@ -54,14 +54,13 @@ var TooltipDirective = /** @class */ (function () {
54
54
  TooltipDirective.prototype.updateTooltipVisibilityWhenFocusOnInput = function () {
55
55
  var _this = this;
56
56
  if (this.focusedInputRef) {
57
- var inputFocus = this.focusedInputRef;
58
- var icon_1 = this.getIconFromFocusedInput(inputFocus);
59
- this.renderer.listen(inputFocus, 'focus', function () {
57
+ var icon_1 = this.getIconFromFocusedInput();
58
+ this.renderer.listen(this.focusedInputRef, 'focus', function () {
60
59
  if (icon_1 && _this.isMatchingTooltip(icon_1)) {
61
60
  _this.createTootipByFocus(icon_1);
62
61
  }
63
62
  });
64
- this.renderer.listen(inputFocus, 'blur', function () {
63
+ this.renderer.listen(this.focusedInputRef, 'blur', function () {
65
64
  if (icon_1 && _this.isMatchingTooltip(icon_1)) {
66
65
  _this.removeTooltip(icon_1);
67
66
  _this.destroy();
@@ -71,16 +70,10 @@ var TooltipDirective = /** @class */ (function () {
71
70
  };
72
71
  /**
73
72
  * Obtém o elemento do ícone associado ao label do input em focus.
74
- * @param focusedInput O input em focus.
75
- * @returns O ícone do input em focus ou null.
73
+ * @returns O ícone do input em focus.
76
74
  */
77
- TooltipDirective.prototype.getIconFromFocusedInput = function (focusedInput) {
78
- var label = document.querySelector("label[for='" + focusedInput.id + "']");
79
- if (label) {
80
- var icon = label.nextElementSibling;
81
- return (icon === null || icon === void 0 ? void 0 : icon.classList.contains('info-sign__icon')) ? icon : null;
82
- }
83
- return null;
75
+ TooltipDirective.prototype.getIconFromFocusedInput = function () {
76
+ return this.elementRef.nativeElement;
84
77
  };
85
78
  /**
86
79
  * Verifica se o ícone tem o tooltip correspondente ao atual.
@@ -377,4 +370,4 @@ var TooltipDirective = /** @class */ (function () {
377
370
  return TooltipDirective;
378
371
  }());
379
372
  export { TooltipDirective };
380
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n   ApplicationRef,\n   ComponentFactoryResolver,\n   ComponentRef,\n   Directive,\n   ElementRef,\n   EmbeddedViewRef,\n   HostListener,\n   Injector,\n   Input,\n   OnDestroy,\n   OnInit,\n   Renderer2\n} from \"@angular/core\";\nimport { DebounceUtils } from \"../utils/debouce\";\nimport { MobileBehavior, TooltipEvent, TooltipPosition } from \"./models\";\nimport { TooltipComponent } from \"./tooltip.component\";\nimport { ElementArea } from \"./models/element-area\";\n\n@Directive({\n   selector: \"[sTooltip]\",\n})\nexport class TooltipDirective implements OnInit, OnDestroy {\n   @Input(\"sTooltip\")\n   public tooltip: string;\n\n   @Input(\"tooltipPosition\")\n   public position: TooltipPosition = TooltipPosition.Top;\n\n   @Input()\n   public showDelay = 500;\n\n   @Input()\n   public displayTime: number;\n\n   @Input()\n   public tooltipEvent = TooltipEvent.Hover;\n\n   @Input()\n   public escape = false;\n\n   @Input()\n   public visible = true;\n\n   @Input()\n   public mobileBehavior = MobileBehavior.Pressing;\n\n   @Input()\n   public focusedInputRef: HTMLInputElement;\n\n   private componentRef: ComponentRef<any> = null;\n   private showTimeout?: number;\n   private touchTimeout?: number;\n   private tooltipDivElement?: HTMLElement;\n   private readonly boundOnWindowMouseMoveFunction: (event: MouseEvent) => void;\n   private readonly debounceCreateTooltipFunction: () => void;\n\n   constructor(\n      private readonly elementRef: ElementRef,\n      private readonly appRef: ApplicationRef,\n      private readonly componentFactoryResolver: ComponentFactoryResolver,\n      private readonly injector: Injector,\n      private readonly debounceUtils: DebounceUtils,\n      private readonly renderer: Renderer2\n   ) {\n      this.boundOnWindowMouseMoveFunction = this.onWindowMouseMove.bind(this);\n      this.debounceCreateTooltipFunction = this.debounceUtils.debounceLeading(() => this.createTootip());\n   }\n\n   public ngOnInit(): void {\n      this.validatePosition();\n      this.updateTooltipVisibilityWhenFocusOnInput();\n   }\n\n   public ngOnDestroy(): void {\n      this.destroy();\n   }\n\n   private onWindowMouseMove(event: MouseEvent) {\n      if (!this.componentRef) {\n         return;\n      }\n      const elementRect = this.elementRef.nativeElement.getBoundingClientRect();\n      const toolTipRect = this.tooltipDivElement.getBoundingClientRect();\n\n      const totalElementArea = {\n         top: Math.min(elementRect.top, toolTipRect.top),\n         right: Math.max(elementRect.right, toolTipRect.right),\n         left: Math.min(elementRect.left, toolTipRect.left),\n         bottom: Math.max(elementRect.bottom, toolTipRect.bottom)\n      };\n\n      if (this.isMousePositionOutsideOfElement(event.clientX, event.clientY, totalElementArea)) {\n         this.destroy();\n      }\n   }\n\n   private isMousePositionOutsideOfElement(mouseX: number, mouseY: number, elementArea: ElementArea) {\n      return mouseX < elementArea.left || mouseX >= elementArea.right || mouseY < elementArea.top || mouseY >= elementArea.bottom;\n   }\n\n   /**\n    * Manipula a visibilidade do tooltip quando houver uma referência de input.\n    */\n   private updateTooltipVisibilityWhenFocusOnInput() {\n        if (this.focusedInputRef) {\n            const inputFocus = this.focusedInputRef;\n            const icon = this.getIconFromFocusedInput(inputFocus);\n\n            this.renderer.listen(inputFocus, 'focus', () => {\n                if (icon && this.isMatchingTooltip(icon)) {\n                    this.createTootipByFocus(icon);\n                }\n            });\n            this.renderer.listen(inputFocus, 'blur', () => {\n                if (icon && this.isMatchingTooltip(icon)) {\n                    this.removeTooltip(icon);\n                    this.destroy();\n                }\n            });\n        }\n    }\n\n    /**\n     * Obtém o elemento do ícone associado ao label do input em focus.\n     * @param focusedInput O input em focus.\n     * @returns O ícone do input em focus ou null.\n     */\n    private getIconFromFocusedInput(focusedInput: HTMLInputElement): HTMLElement | null {\n        const label = document.querySelector(`label[for='${focusedInput.id}']`);\n        if (label) {\n            const icon = label.nextElementSibling as HTMLElement;\n            return icon?.classList.contains('info-sign__icon') ? icon : null;\n        }\n        return null;\n    }\n\n    /**\n     * Verifica se o ícone tem o tooltip correspondente ao atual.\n     * @param icon O ícone do input em focus.\n     * @returns true se o tooltip corresponde; caso contrário, false.\n     */\n    private isMatchingTooltip(icon: HTMLElement): boolean {\n        const tooltipText = icon.getAttribute('ng-reflect-tooltip');\n        return this.tooltip === tooltipText;\n    }\n\n    /**\n     * Remove o tooltip associado ao ícone do input em focus.\n     * @param icon O ícone do input em focus.\n     */\n    private removeTooltip(icon: HTMLElement): void {\n        const tooltip = icon.querySelector('.tooltip') as HTMLElement;\n        if (tooltip) {\n            tooltip.remove();\n        }\n    }\n\n   // whenever the component with the tooltip is clicked I destroy the tooltip.\n   // whenever a key is pressed on the component with the tooltip I destroy the tooltip.\n   @HostListener(\"click\")\n   @HostListener(\"keydown\")\n   public onClick(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover &&\n         !navigator.userAgent.match(/Android/i) &&\n         !navigator.userAgent.match(/iPhone/i)) {\n         this.destroy();\n      }\n   }\n\n   // whenever you touch outside the component with the tooltip I destroy the tooltip.\n   @HostListener(\"document:touchstart\")\n   public onDocumentTouchStart(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         this.destroy();\n      }\n   }\n\n   @HostListener(\"focus\")\n   public onFocus(): void {\n      if (this.tooltipEvent === TooltipEvent.Focus) {\n         this.createTootip();\n      }\n   }\n\n   @HostListener(\"blur\")\n   public onBlur(): void {\n      if (this.tooltipEvent === TooltipEvent.Focus) {\n         this.destroy();\n      }\n   }\n\n   @HostListener(\"mouseenter\")\n   public onMouseEnter(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         this.debounceCreateTooltipFunction();\n      }\n   }\n\n   @HostListener(\"mouseleave\")\n   @HostListener(\"wheel\")\n   public onMouseLeave(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         this.destroy();\n      }\n   }\n\n   @HostListener(\"touchstart\")\n   public onTouchStart(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         window.clearTimeout(this.touchTimeout);\n         this.touchTimeout = window.setTimeout(\n            this.createTootip.bind(this),\n            this.mobileBehavior === MobileBehavior.Pressing ? this.showDelay : 0\n         );\n      }\n   }\n\n   @HostListener(\"touchend\")\n   public onTouchEnd(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         if (this.mobileBehavior === MobileBehavior.Pressing) {\n            window.clearTimeout(this.touchTimeout);\n            this.destroy();\n         }\n      }\n   }\n\n   private validatePosition() {\n      const containsPosition = [\n         TooltipPosition.Top,\n         TooltipPosition.Right,\n         TooltipPosition.Bottom,\n         TooltipPosition.Left,\n      ].includes(this.position);\n\n      if (!containsPosition) {\n         this.position = TooltipPosition.Top;\n         throw new Error(`Tooltip ${this.position} position is unexpected`);\n      }\n   }\n\n   private createTootip() {\n      if (this.componentRef === null && this.tooltip?.length) {\n         const domElem = this.getDomElement();\n         document.body.appendChild(domElem);\n         this.setTooltipComponentProperties();\n         this.showTimeout = window.setTimeout(this.showTooltip.bind(this), this.showDelay);\n\n         this.tooltipDivElement = domElem.querySelector('.tooltip');\n\n         if (this.displayTime) {\n            window.setTimeout(this.destroy.bind(this), this.displayTime);\n         }\n      }\n   }\n\n   private getDomElement(): HTMLElement {\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(TooltipComponent);\n        this.componentRef = componentFactory.create(this.injector);\n        this.appRef.attachView(this.componentRef.hostView);\n        return (this.componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n   }\n\n   /**\n    * Cria um tooltip para o icone do input em focus.\n    *\n    * @param icon O ícone do input em focus.\n    */\n   private createTootipByFocus(icon: HTMLElement) {\n        if (this.componentRef === null && this.tooltip?.length) {\n            const domElem = this.getDomElement();\n            const tooltip = domElem.querySelector('.tooltip') as HTMLElement;\n            icon.appendChild(tooltip);\n            this.setTooltipComponentProperties();\n\n            setTimeout(() => tooltip.classList.add(\"tooltip--visible\"), 0);\n        }\n    }\n\n   private showTooltip() {\n      if (this.componentRef !== null) {\n         this.componentRef.instance.visible = this.visible;\n\n         window.addEventListener('mousemove', this.boundOnWindowMouseMoveFunction);\n      }\n   }\n\n   private setTooltipComponentProperties() {\n      const margin = 20;\n      const anchorSize = 5;\n\n      if (this.componentRef !== null) {\n         this.componentRef.instance.tooltip = this.tooltip;\n         this.componentRef.instance.escape = this.escape;\n\n         const { left, right, top, bottom } = this.elementRef.nativeElement.getBoundingClientRect();\n\n         const tooltipHeight = bottom - top;\n         const tooltipWidth = right - left;\n         const safeSpace = 150;\n\n         let positioned = false;\n         const invalidOptions: TooltipPosition[] = [];\n\n         while (!positioned) {\n            if (invalidOptions.includes(TooltipPosition.Top)\n               && invalidOptions.includes(TooltipPosition.Bottom)\n               && invalidOptions.includes(TooltipPosition.Left)\n               && invalidOptions.includes(TooltipPosition.Right)) {\n               this.destroy();\n               throw new Error(\"No space to show tooltip\");\n            }\n\n            switch (this.position) {\n               case TooltipPosition.Top: {\n                  if (invalidOptions.includes(TooltipPosition.Top)) {\n                     this.position = TooltipPosition.Left;\n                     break;\n                  }\n\n                  const topShift = top;\n\n                  if (topShift <= tooltipHeight + safeSpace) {\n                     this.position = TooltipPosition.Bottom;\n                     invalidOptions.push(TooltipPosition.Top);\n                     positioned = false;\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(tooltipWidth / 2 + left);\n                  this.componentRef.instance.top = Math.round(top - margin - anchorSize);\n                  positioned = true;\n                  break;\n               }\n               case TooltipPosition.Bottom: {\n\n                  if (invalidOptions.includes(TooltipPosition.Bottom)) {\n                     this.position = TooltipPosition.Left;\n                     break;\n                  }\n\n                  const bottomShift = document.body.clientHeight - bottom;\n\n                  if (bottomShift <= tooltipHeight + safeSpace) {\n                     this.position = TooltipPosition.Top;\n                     invalidOptions.push(TooltipPosition.Bottom);\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(tooltipWidth / 2 + left);\n                  this.componentRef.instance.top = Math.round(bottom + margin);\n                  positioned = true;\n                  break;\n               }\n               case TooltipPosition.Left: {\n                  if (invalidOptions.includes(TooltipPosition.Left)) {\n                     this.position = TooltipPosition.Top;\n                     break;\n                  }\n\n                  const leftShift = left;\n\n                  if (leftShift <= tooltipWidth + safeSpace) {\n                     this.position = TooltipPosition.Right;\n                     invalidOptions.push(TooltipPosition.Left);\n                     positioned = false;\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(left - margin);\n                  this.componentRef.instance.top = Math.round(top + tooltipHeight / 2 - anchorSize);\n                  positioned = true;\n                  break;\n               }\n               case TooltipPosition.Right: {\n                  if (invalidOptions.includes(TooltipPosition.Right)) {\n                     this.position = TooltipPosition.Top;\n                     break;\n                  }\n\n                  const rightShift = document.body.clientWidth - right;\n\n                  if (rightShift <= tooltipWidth + safeSpace) {\n                     this.position = TooltipPosition.Left;\n                     invalidOptions.push(TooltipPosition.Right);\n                     positioned = false;\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(right + margin);\n                  this.componentRef.instance.top = Math.round(top + tooltipHeight / 2 - anchorSize);\n                  positioned = true;\n                  break;\n               }\n               default: {\n                  break;\n               }\n            }\n\n            this.componentRef.instance.position = this.position;\n         }\n      }\n   }\n\n   private destroy(): void {\n      if (this.componentRef !== null) {\n         window.clearTimeout(this.showTimeout);\n         this.appRef.detachView(this.componentRef.hostView);\n         this.componentRef.destroy();\n         this.componentRef = null;\n         this.tooltipDivElement = null;\n      }\n\n      window.removeEventListener('mousemove', this.boundOnWindowMouseMoveFunction);\n   }\n}\n"]}
373
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n   ApplicationRef,\n   ComponentFactoryResolver,\n   ComponentRef,\n   Directive,\n   ElementRef,\n   EmbeddedViewRef,\n   HostListener,\n   Injector,\n   Input,\n   OnDestroy,\n   OnInit,\n   Renderer2\n} from \"@angular/core\";\nimport { DebounceUtils } from \"../utils/debouce\";\nimport { MobileBehavior, TooltipEvent, TooltipPosition } from \"./models\";\nimport { TooltipComponent } from \"./tooltip.component\";\nimport { ElementArea } from \"./models/element-area\";\n\n@Directive({\n   selector: \"[sTooltip]\",\n})\nexport class TooltipDirective implements OnInit, OnDestroy {\n   @Input(\"sTooltip\")\n   public tooltip: string;\n\n   @Input(\"tooltipPosition\")\n   public position: TooltipPosition = TooltipPosition.Top;\n\n   @Input()\n   public showDelay = 500;\n\n   @Input()\n   public displayTime: number;\n\n   @Input()\n   public tooltipEvent = TooltipEvent.Hover;\n\n   @Input()\n   public escape = false;\n\n   @Input()\n   public visible = true;\n\n   @Input()\n   public mobileBehavior = MobileBehavior.Pressing;\n\n   @Input()\n   public focusedInputRef: HTMLInputElement;\n\n   private componentRef: ComponentRef<any> = null;\n   private showTimeout?: number;\n   private touchTimeout?: number;\n   private tooltipDivElement?: HTMLElement;\n   private readonly boundOnWindowMouseMoveFunction: (event: MouseEvent) => void;\n   private readonly debounceCreateTooltipFunction: () => void;\n\n   constructor(\n      private readonly elementRef: ElementRef,\n      private readonly appRef: ApplicationRef,\n      private readonly componentFactoryResolver: ComponentFactoryResolver,\n      private readonly injector: Injector,\n      private readonly debounceUtils: DebounceUtils,\n      private readonly renderer: Renderer2\n   ) {\n      this.boundOnWindowMouseMoveFunction = this.onWindowMouseMove.bind(this);\n      this.debounceCreateTooltipFunction = this.debounceUtils.debounceLeading(() => this.createTootip());\n   }\n\n   public ngOnInit(): void {\n      this.validatePosition();\n      this.updateTooltipVisibilityWhenFocusOnInput();\n   }\n\n   public ngOnDestroy(): void {\n      this.destroy();\n   }\n\n   private onWindowMouseMove(event: MouseEvent) {\n      if (!this.componentRef) {\n         return;\n      }\n      const elementRect = this.elementRef.nativeElement.getBoundingClientRect();\n      const toolTipRect = this.tooltipDivElement.getBoundingClientRect();\n\n      const totalElementArea = {\n         top: Math.min(elementRect.top, toolTipRect.top),\n         right: Math.max(elementRect.right, toolTipRect.right),\n         left: Math.min(elementRect.left, toolTipRect.left),\n         bottom: Math.max(elementRect.bottom, toolTipRect.bottom)\n      };\n\n      if (this.isMousePositionOutsideOfElement(event.clientX, event.clientY, totalElementArea)) {\n         this.destroy();\n      }\n   }\n\n   private isMousePositionOutsideOfElement(mouseX: number, mouseY: number, elementArea: ElementArea) {\n      return mouseX < elementArea.left || mouseX >= elementArea.right || mouseY < elementArea.top || mouseY >= elementArea.bottom;\n   }\n\n   /**\n    * Manipula a visibilidade do tooltip quando houver uma referência de input.\n    */\n   private updateTooltipVisibilityWhenFocusOnInput() {\n        if (this.focusedInputRef) {\n            const icon = this.getIconFromFocusedInput();\n\n            this.renderer.listen(this.focusedInputRef, 'focus', () => {\n                if (icon && this.isMatchingTooltip(icon)) {\n                    this.createTootipByFocus(icon);\n                }\n            });\n            this.renderer.listen(this.focusedInputRef, 'blur', () => {\n                if (icon && this.isMatchingTooltip(icon)) {\n                    this.removeTooltip(icon);\n                    this.destroy();\n                }\n            });\n        }\n    }\n\n    /**\n     * Obtém o elemento do ícone associado ao label do input em focus.\n     * @returns O ícone do input em focus.\n     */\n    private getIconFromFocusedInput(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    /**\n     * Verifica se o ícone tem o tooltip correspondente ao atual.\n     * @param icon O ícone do input em focus.\n     * @returns true se o tooltip corresponde; caso contrário, false.\n     */\n    private isMatchingTooltip(icon: HTMLElement): boolean {\n        const tooltipText = icon.getAttribute('ng-reflect-tooltip');\n        return this.tooltip === tooltipText;\n    }\n\n    /**\n     * Remove o tooltip associado ao ícone do input em focus.\n     * @param icon O ícone do input em focus.\n     */\n    private removeTooltip(icon: HTMLElement): void {\n        const tooltip = icon.querySelector('.tooltip') as HTMLElement;\n        if (tooltip) {\n            tooltip.remove();\n        }\n    }\n\n   // whenever the component with the tooltip is clicked I destroy the tooltip.\n   // whenever a key is pressed on the component with the tooltip I destroy the tooltip.\n   @HostListener(\"click\")\n   @HostListener(\"keydown\")\n   public onClick(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover &&\n         !navigator.userAgent.match(/Android/i) &&\n         !navigator.userAgent.match(/iPhone/i)) {\n         this.destroy();\n      }\n   }\n\n   // whenever you touch outside the component with the tooltip I destroy the tooltip.\n   @HostListener(\"document:touchstart\")\n   public onDocumentTouchStart(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         this.destroy();\n      }\n   }\n\n   @HostListener(\"focus\")\n   public onFocus(): void {\n      if (this.tooltipEvent === TooltipEvent.Focus) {\n         this.createTootip();\n      }\n   }\n\n   @HostListener(\"blur\")\n   public onBlur(): void {\n      if (this.tooltipEvent === TooltipEvent.Focus) {\n         this.destroy();\n      }\n   }\n\n   @HostListener(\"mouseenter\")\n   public onMouseEnter(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         this.debounceCreateTooltipFunction();\n      }\n   }\n\n   @HostListener(\"mouseleave\")\n   @HostListener(\"wheel\")\n   public onMouseLeave(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         this.destroy();\n      }\n   }\n\n   @HostListener(\"touchstart\")\n   public onTouchStart(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         window.clearTimeout(this.touchTimeout);\n         this.touchTimeout = window.setTimeout(\n            this.createTootip.bind(this),\n            this.mobileBehavior === MobileBehavior.Pressing ? this.showDelay : 0\n         );\n      }\n   }\n\n   @HostListener(\"touchend\")\n   public onTouchEnd(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         if (this.mobileBehavior === MobileBehavior.Pressing) {\n            window.clearTimeout(this.touchTimeout);\n            this.destroy();\n         }\n      }\n   }\n\n   private validatePosition() {\n      const containsPosition = [\n         TooltipPosition.Top,\n         TooltipPosition.Right,\n         TooltipPosition.Bottom,\n         TooltipPosition.Left,\n      ].includes(this.position);\n\n      if (!containsPosition) {\n         this.position = TooltipPosition.Top;\n         throw new Error(`Tooltip ${this.position} position is unexpected`);\n      }\n   }\n\n   private createTootip() {\n      if (this.componentRef === null && this.tooltip?.length) {\n         const domElem = this.getDomElement();\n         document.body.appendChild(domElem);\n         this.setTooltipComponentProperties();\n         this.showTimeout = window.setTimeout(this.showTooltip.bind(this), this.showDelay);\n\n         this.tooltipDivElement = domElem.querySelector('.tooltip');\n\n         if (this.displayTime) {\n            window.setTimeout(this.destroy.bind(this), this.displayTime);\n         }\n      }\n   }\n\n   private getDomElement(): HTMLElement {\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(TooltipComponent);\n        this.componentRef = componentFactory.create(this.injector);\n        this.appRef.attachView(this.componentRef.hostView);\n        return (this.componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n   }\n\n   /**\n    * Cria um tooltip para o icone do input em focus.\n    *\n    * @param icon O ícone do input em focus.\n    */\n   private createTootipByFocus(icon: HTMLElement) {\n        if (this.componentRef === null && this.tooltip?.length) {\n            const domElem = this.getDomElement();\n            const tooltip = domElem.querySelector('.tooltip') as HTMLElement;\n            icon.appendChild(tooltip);\n            this.setTooltipComponentProperties();\n\n            setTimeout(() => tooltip.classList.add(\"tooltip--visible\"), 0);\n        }\n    }\n\n   private showTooltip() {\n      if (this.componentRef !== null) {\n         this.componentRef.instance.visible = this.visible;\n\n         window.addEventListener('mousemove', this.boundOnWindowMouseMoveFunction);\n      }\n   }\n\n   private setTooltipComponentProperties() {\n      const margin = 20;\n      const anchorSize = 5;\n\n      if (this.componentRef !== null) {\n         this.componentRef.instance.tooltip = this.tooltip;\n         this.componentRef.instance.escape = this.escape;\n\n         const { left, right, top, bottom } = this.elementRef.nativeElement.getBoundingClientRect();\n\n         const tooltipHeight = bottom - top;\n         const tooltipWidth = right - left;\n         const safeSpace = 150;\n\n         let positioned = false;\n         const invalidOptions: TooltipPosition[] = [];\n\n         while (!positioned) {\n            if (invalidOptions.includes(TooltipPosition.Top)\n               && invalidOptions.includes(TooltipPosition.Bottom)\n               && invalidOptions.includes(TooltipPosition.Left)\n               && invalidOptions.includes(TooltipPosition.Right)) {\n               this.destroy();\n               throw new Error(\"No space to show tooltip\");\n            }\n\n            switch (this.position) {\n               case TooltipPosition.Top: {\n                  if (invalidOptions.includes(TooltipPosition.Top)) {\n                     this.position = TooltipPosition.Left;\n                     break;\n                  }\n\n                  const topShift = top;\n\n                  if (topShift <= tooltipHeight + safeSpace) {\n                     this.position = TooltipPosition.Bottom;\n                     invalidOptions.push(TooltipPosition.Top);\n                     positioned = false;\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(tooltipWidth / 2 + left);\n                  this.componentRef.instance.top = Math.round(top - margin - anchorSize);\n                  positioned = true;\n                  break;\n               }\n               case TooltipPosition.Bottom: {\n\n                  if (invalidOptions.includes(TooltipPosition.Bottom)) {\n                     this.position = TooltipPosition.Left;\n                     break;\n                  }\n\n                  const bottomShift = document.body.clientHeight - bottom;\n\n                  if (bottomShift <= tooltipHeight + safeSpace) {\n                     this.position = TooltipPosition.Top;\n                     invalidOptions.push(TooltipPosition.Bottom);\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(tooltipWidth / 2 + left);\n                  this.componentRef.instance.top = Math.round(bottom + margin);\n                  positioned = true;\n                  break;\n               }\n               case TooltipPosition.Left: {\n                  if (invalidOptions.includes(TooltipPosition.Left)) {\n                     this.position = TooltipPosition.Top;\n                     break;\n                  }\n\n                  const leftShift = left;\n\n                  if (leftShift <= tooltipWidth + safeSpace) {\n                     this.position = TooltipPosition.Right;\n                     invalidOptions.push(TooltipPosition.Left);\n                     positioned = false;\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(left - margin);\n                  this.componentRef.instance.top = Math.round(top + tooltipHeight / 2 - anchorSize);\n                  positioned = true;\n                  break;\n               }\n               case TooltipPosition.Right: {\n                  if (invalidOptions.includes(TooltipPosition.Right)) {\n                     this.position = TooltipPosition.Top;\n                     break;\n                  }\n\n                  const rightShift = document.body.clientWidth - right;\n\n                  if (rightShift <= tooltipWidth + safeSpace) {\n                     this.position = TooltipPosition.Left;\n                     invalidOptions.push(TooltipPosition.Right);\n                     positioned = false;\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(right + margin);\n                  this.componentRef.instance.top = Math.round(top + tooltipHeight / 2 - anchorSize);\n                  positioned = true;\n                  break;\n               }\n               default: {\n                  break;\n               }\n            }\n\n            this.componentRef.instance.position = this.position;\n         }\n      }\n   }\n\n   private destroy(): void {\n      if (this.componentRef !== null) {\n         window.clearTimeout(this.showTimeout);\n         this.appRef.detachView(this.componentRef.hostView);\n         this.componentRef.destroy();\n         this.componentRef = null;\n         this.tooltipDivElement = null;\n      }\n\n      window.removeEventListener('mousemove', this.boundOnWindowMouseMoveFunction);\n   }\n}\n"]}
@@ -463,14 +463,13 @@ let TooltipDirective = class TooltipDirective {
463
463
  */
464
464
  updateTooltipVisibilityWhenFocusOnInput() {
465
465
  if (this.focusedInputRef) {
466
- const inputFocus = this.focusedInputRef;
467
- const icon = this.getIconFromFocusedInput(inputFocus);
468
- this.renderer.listen(inputFocus, 'focus', () => {
466
+ const icon = this.getIconFromFocusedInput();
467
+ this.renderer.listen(this.focusedInputRef, 'focus', () => {
469
468
  if (icon && this.isMatchingTooltip(icon)) {
470
469
  this.createTootipByFocus(icon);
471
470
  }
472
471
  });
473
- this.renderer.listen(inputFocus, 'blur', () => {
472
+ this.renderer.listen(this.focusedInputRef, 'blur', () => {
474
473
  if (icon && this.isMatchingTooltip(icon)) {
475
474
  this.removeTooltip(icon);
476
475
  this.destroy();
@@ -480,16 +479,10 @@ let TooltipDirective = class TooltipDirective {
480
479
  }
481
480
  /**
482
481
  * Obtém o elemento do ícone associado ao label do input em focus.
483
- * @param focusedInput O input em focus.
484
- * @returns O ícone do input em focus ou null.
482
+ * @returns O ícone do input em focus.
485
483
  */
486
- getIconFromFocusedInput(focusedInput) {
487
- const label = document.querySelector(`label[for='${focusedInput.id}']`);
488
- if (label) {
489
- const icon = label.nextElementSibling;
490
- return (icon === null || icon === void 0 ? void 0 : icon.classList.contains('info-sign__icon')) ? icon : null;
491
- }
492
- return null;
484
+ getIconFromFocusedInput() {
485
+ return this.elementRef.nativeElement;
493
486
  }
494
487
  /**
495
488
  * Verifica se o ícone tem o tooltip correspondente ao atual.
@@ -13547,6 +13540,8 @@ var KanbanTemplateTypes;
13547
13540
  let KanbanComponent = class KanbanComponent {
13548
13541
  constructor(kanbanEventService) {
13549
13542
  this.kanbanEventService = kanbanEventService;
13543
+ this.showItemCheckboxes = true;
13544
+ this.showColumnCheckboxes = true;
13550
13545
  this.itemsMoved = new EventEmitter();
13551
13546
  this.dataUpdated = new EventEmitter();
13552
13547
  this.itemsSelected = new EventEmitter();
@@ -13605,6 +13600,8 @@ let KanbanComponent = class KanbanComponent {
13605
13600
  this.selectedItems.clear();
13606
13601
  }
13607
13602
  selectItem(event, item, column) {
13603
+ if (item.disabled || item.frozen)
13604
+ return;
13608
13605
  if (event.ctrlKey) {
13609
13606
  if (this.selectedItems.delete(item)) {
13610
13607
  this.kanbanEventService.emitUnselectItemEvent(item);
@@ -13619,6 +13616,8 @@ let KanbanComponent = class KanbanComponent {
13619
13616
  }
13620
13617
  }
13621
13618
  else {
13619
+ if (this.selectedItems.delete(item))
13620
+ return;
13622
13621
  this.selectedItems.clear();
13623
13622
  this.selectedItems.add(item);
13624
13623
  this.selectedColumn = column;
@@ -13634,9 +13633,7 @@ let KanbanComponent = class KanbanComponent {
13634
13633
  this.draggingItems.clear();
13635
13634
  }
13636
13635
  getLinkedColumns(currentColumn) {
13637
- return this.data.columns
13638
- .filter((column) => column != currentColumn)
13639
- .map((column) => column.id);
13636
+ return this.data.columns.filter((column) => column != currentColumn).map((column) => column.id);
13640
13637
  }
13641
13638
  getColumnHeaderTemplate() {
13642
13639
  return this._getCustomTemplate(KanbanTemplateTypes.ColumnHeader);
@@ -13662,7 +13659,7 @@ let KanbanComponent = class KanbanComponent {
13662
13659
  .pipe(takeUntil(this._unsubscribe$))
13663
13660
  .subscribe((column) => {
13664
13661
  column.items
13665
- .filter((item) => !item.disabled)
13662
+ .filter((item) => !item.disabled && !item.frozen)
13666
13663
  .forEach((item) => {
13667
13664
  this.selectedItems.add(item);
13668
13665
  });
@@ -13692,9 +13689,7 @@ let KanbanComponent = class KanbanComponent {
13692
13689
  });
13693
13690
  });
13694
13691
  });
13695
- this.kanbanEventService.unselectItemEvent
13696
- .pipe(takeUntil(this._unsubscribe$))
13697
- .subscribe((item) => {
13692
+ this.kanbanEventService.unselectItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe((item) => {
13698
13693
  this.selectedItems.delete(item);
13699
13694
  });
13700
13695
  }
@@ -13724,6 +13719,12 @@ KanbanComponent.ctorParameters = () => [
13724
13719
  __decorate([
13725
13720
  Input()
13726
13721
  ], KanbanComponent.prototype, "data", void 0);
13722
+ __decorate([
13723
+ Input()
13724
+ ], KanbanComponent.prototype, "showItemCheckboxes", void 0);
13725
+ __decorate([
13726
+ Input()
13727
+ ], KanbanComponent.prototype, "showColumnCheckboxes", void 0);
13727
13728
  __decorate([
13728
13729
  Output()
13729
13730
  ], KanbanComponent.prototype, "itemsMoved", void 0);
@@ -13738,26 +13739,35 @@ __decorate([
13738
13739
  ], KanbanComponent.prototype, "templates", void 0);
13739
13740
  KanbanComponent = __decorate([
13740
13741
  Component({
13741
- selector: 's-kanban',
13742
- template: "<div class=\"kanban\">\n <s-kanban-column\n *ngFor=\"let column of data.columns\"\n [data]=\"column\"\n [headerTemplate]=\"columnHeaderTemplate\">\n <div\n [id]=\"column.id\"\n style=\"height: 100%; width: 100%;\"\n cdkDropList\n #dynamicList=\"cdkDropList\"\n [cdkDropListData]=\"column.items\"\n [cdkDropListConnectedTo]=\"getLinkedColumns(column)\"\n (cdkDropListDropped)=\"drop($event)\">\n\n <ng-container *ngIf=\"!columnEmptyMessageTemplate; then defaultEmptyMessageTemplate else customEmptyMessageTemplate\"></ng-container>\n\n <ng-template #defaultEmptyMessageTemplate>\n <div *ngIf=\"!column.items.length\" class=\"empty-message\">\n <p class=\"text\">\n <span class=\"fas fa-clock\"></span>&nbsp;\n <span>{{ \"platform.angular_components.count_items_in_target\" | translate:{ count: column.items.length, target: column.title } }}</span>\n </p>\n </div>\n </ng-template>\n\n <ng-template #customEmptyMessageTemplate>\n <ng-container *ngTemplateOutlet=\"columnEmptyMessageTemplate; context: { $implicit: column }\"></ng-container>\n </ng-template>\n\n <div\n *ngFor=\"let item of column.items\"\n cdkDrag\n [cdkDragData]=\"item\"\n [cdkDragDisabled]=\"item.disabled\"\n (cdkDragStarted)=\"dragStarted()\"\n (cdkDragReleased)=\"dragReleased()\"\n (click)=\"selectItem($event, item, column)\">\n \n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n\n <ng-container *cdkDragPreview>\n <ng-container *ngIf=\"selectedItems.size > 1; then itemDraggingTemplate else itemTemplate\"></ng-container>\n </ng-container>\n\n <ng-template #itemTemplate>\n <s-kanban-item\n [item]=\"item\"\n [selected]=\"selectedItems.has(item)\"\n [headerTemplate]=\"itemHeaderTemplate\"\n [bodyTemplate]=\"itemBodyTemplate\"\n [footerTemplate]=\"itemFooterTemplate\">\n </s-kanban-item>\n </ng-template>\n\n <ng-template #itemDraggingTemplate>\n <s-kanban-item-dragging [quantityItems]=\"selectedItems.size\"></s-kanban-item-dragging>\n </ng-template>\n\n <div *cdkDragPlaceholder>\n <div class=\"placeholder\">\n <div class=\"placeholder-line\"></div>\n </div>\n </div>\n </div>\n </div>\n </s-kanban-column>\n</div>\n\n",
13743
- styles: [".kanban{display:-ms-flexbox;display:flex;gap:16px;width:100%}.kanban .empty-message{display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center;margin:16px}.kanban .empty-message .text{overflow:hidden;text-align:center;text-overflow:ellipsis;width:100%;white-space:nowrap}@media screen and (max-width:600px){.kanban{-ms-flex-direction:column;flex-direction:column}}s-kanban-column{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;min-width:292px}.placeholder{display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center}.placeholder .placeholder-line{background-color:#a5a5b2;height:1px;margin:6px 0;width:50%}"]
13742
+ selector: "s-kanban",
13743
+ template: "<div class=\"kanban\">\n <s-kanban-column\n *ngFor=\"let column of data.columns\"\n [data]=\"column\"\n [showCheckbox]=\"showColumnCheckboxes\"\n [headerTemplate]=\"columnHeaderTemplate\">\n <div\n [id]=\"column.id\"\n style=\"height: 100%; width: 100%;\"\n cdkDropList\n #dynamicList=\"cdkDropList\"\n [cdkDropListData]=\"column.items\"\n [cdkDropListConnectedTo]=\"getLinkedColumns(column)\"\n (cdkDropListDropped)=\"drop($event)\">\n\n <ng-container *ngIf=\"!columnEmptyMessageTemplate; then defaultEmptyMessageTemplate else customEmptyMessageTemplate\"></ng-container>\n\n <ng-template #defaultEmptyMessageTemplate>\n <div *ngIf=\"!column.items.length\" class=\"empty-message\">\n <p class=\"text\">\n <span class=\"fas fa-clock\"></span>&nbsp;\n <span>{{ \"platform.angular_components.count_items_in_target\" | translate:{ count: column.items.length, target: column.title } }}</span>\n </p>\n </div>\n </ng-template>\n\n <ng-template #customEmptyMessageTemplate>\n <ng-container *ngTemplateOutlet=\"columnEmptyMessageTemplate; context: { $implicit: column }\"></ng-container>\n </ng-template>\n\n <div\n *ngFor=\"let item of column.items\"\n cdkDrag\n [cdkDragData]=\"item\"\n [cdkDragDisabled]=\"item.disabled || item.frozen\"\n (cdkDragStarted)=\"dragStarted()\"\n (cdkDragReleased)=\"dragReleased()\"\n (click)=\"selectItem($event, item, column)\">\n \n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n\n <ng-container *cdkDragPreview>\n <ng-container *ngIf=\"selectedItems.size > 1; then itemDraggingTemplate else itemTemplate\"></ng-container>\n </ng-container>\n\n <ng-template #itemTemplate>\n <s-kanban-item\n [item]=\"item\"\n [selected]=\"selectedItems.has(item)\"\n [showCheckbox]=\"showItemCheckboxes\"\n [headerTemplate]=\"itemHeaderTemplate\"\n [bodyTemplate]=\"itemBodyTemplate\"\n [footerTemplate]=\"itemFooterTemplate\">\n </s-kanban-item>\n </ng-template>\n\n <ng-template #itemDraggingTemplate>\n <s-kanban-item-dragging [quantityItems]=\"selectedItems.size\"></s-kanban-item-dragging>\n </ng-template>\n\n <div *cdkDragPlaceholder>\n <div class=\"placeholder\">\n <div class=\"placeholder-line\"></div>\n </div>\n </div>\n </div>\n </div>\n </s-kanban-column>\n</div>\n\n",
13744
+ styles: [".kanban{display:-ms-flexbox;display:flex;gap:16px;overflow:auto;width:100%}.kanban .empty-message{display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center;margin:16px}.kanban .empty-message .text{overflow:hidden;text-align:center;text-overflow:ellipsis;width:100%;white-space:nowrap}@media screen and (max-width:600px){.kanban{-ms-flex-direction:column;flex-direction:column}}s-kanban-column{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;min-width:292px}.placeholder{display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center}.placeholder .placeholder-line{background-color:#a5a5b2;height:1px;margin:6px 0;width:50%}"]
13744
13745
  })
13745
13746
  ], KanbanComponent);
13746
13747
 
13747
13748
  let KanbanColumnComponent = class KanbanColumnComponent {
13748
13749
  constructor(kanbanEventService) {
13749
13750
  this.kanbanEventService = kanbanEventService;
13751
+ this.showCheckbox = true;
13750
13752
  this.selectionControl = new FormControl(false);
13751
13753
  this._unsubscribe$ = new Subject();
13752
13754
  }
13753
13755
  ngOnInit() {
13754
13756
  this._validateInputs();
13755
13757
  this._subscriveEvents();
13758
+ this._createTieredOptions();
13756
13759
  }
13757
13760
  ngOnDestroy() {
13758
13761
  this._unsubscribe$.next();
13759
13762
  this._unsubscribe$.complete();
13760
13763
  }
13764
+ _createTieredOptions() {
13765
+ const options = [];
13766
+ this.data.options.forEach((option) => {
13767
+ options.push(Object.assign(Object.assign({}, option), { command: () => { option.command(this.data); } }));
13768
+ });
13769
+ this.data.options = options;
13770
+ }
13761
13771
  _subscriveEvents() {
13762
13772
  this.selectionControl.valueChanges
13763
13773
  .pipe(takeUntil(this._unsubscribe$))
@@ -13808,13 +13818,16 @@ KanbanColumnComponent.ctorParameters = () => [
13808
13818
  __decorate([
13809
13819
  Input()
13810
13820
  ], KanbanColumnComponent.prototype, "data", void 0);
13821
+ __decorate([
13822
+ Input()
13823
+ ], KanbanColumnComponent.prototype, "showCheckbox", void 0);
13811
13824
  __decorate([
13812
13825
  Input()
13813
13826
  ], KanbanColumnComponent.prototype, "headerTemplate", void 0);
13814
13827
  KanbanColumnComponent = __decorate([
13815
13828
  Component({
13816
13829
  selector: "s-kanban-column",
13817
- template: "<div class=\"kanban-column\">\n <div class=\"kanban-column__header\">\n <div class=\"content\">\n <form>\n <input\n type=\"checkbox\"\n name=\"checkbox\"\n [formControl]=\"selectionControl\">\n </form>\n\n <ng-container *ngIf=\"!headerTemplate; then defaultHeaderTemplate else customHeaderTemplate\"></ng-container>\n \n <ng-template #defaultHeaderTemplate>\n <div class=\"header\">\n <span class=\"title\">{{ data.title }} ({{ data.items.length }})</span>\n </div>\n </ng-template>\n \n <ng-template #customHeaderTemplate>\n <ng-container *ngTemplateOutlet=\"headerTemplate; context: { $implicit: data }\"></ng-container>\n </ng-template>\n </div>\n <s-button\n *ngIf=\"data.options\"\n priority=\"default\"\n [disabled]=\"false\"\n [auxiliary]=\"true\"\n size=\"small\"\n [model]=\"data.options\">\n </s-button>\n </div>\n <div class=\"kanban-column__body\">\n <ng-content></ng-content>\n </div>\n</div>",
13830
+ template: "<div class=\"kanban-column\">\n <div class=\"kanban-column__header\">\n <div class=\"content\">\n <form>\n <input\n *ngIf=\"showCheckbox\"\n type=\"checkbox\"\n name=\"checkbox\"\n [formControl]=\"selectionControl\">\n </form>\n\n <ng-container *ngIf=\"!headerTemplate; then defaultHeaderTemplate else customHeaderTemplate\"></ng-container>\n \n <ng-template #defaultHeaderTemplate>\n <div class=\"header\">\n <span class=\"title\">{{ data.title }} ({{ data.items.length }})</span>\n </div>\n </ng-template>\n \n <ng-template #customHeaderTemplate>\n <ng-container *ngTemplateOutlet=\"headerTemplate; context: { $implicit: data }\"></ng-container>\n </ng-template>\n </div>\n <s-button\n *ngIf=\"data.options\"\n priority=\"default\"\n [disabled]=\"false\"\n [auxiliary]=\"true\"\n size=\"small\"\n [model]=\"data.options\">\n </s-button>\n </div>\n <div class=\"kanban-column__body\">\n <ng-content></ng-content>\n </div>\n</div>",
13818
13831
  styles: [".kanban-column{-ms-flex-align:center;align-items:center;background-color:#fbfafc;border:1px solid #dedce5;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;height:100%;min-height:120px;-webkit-user-select:none;-ms-user-select:none;user-select:none;width:100%}.kanban-column .kanban-column__header{-ms-flex-align:center;align-items:center;border-bottom:1px solid #dedce5;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between;padding:16px 16px 8px;width:100%}.kanban-column .kanban-column__header .content{display:-ms-flexbox;display:flex;gap:16px}.kanban-column .kanban-column__header .content .teste{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;font-family:\"Open Sans\" sans-serif}.kanban-column .kanban-column__header .content .teste .title{font-size:14px;font-weight:800}.kanban-column .kanban-column__header .content .teste .description{font-size:12px}.kanban-column .kanban-column__body{display:-ms-flexbox;display:flex;height:100%;-ms-flex-pack:center;justify-content:center;width:100%}"]
13819
13832
  })
13820
13833
  ], KanbanColumnComponent);
@@ -13839,6 +13852,10 @@ let KanbanItemComponent = class KanbanItemComponent {
13839
13852
  constructor(_kanbanEventService) {
13840
13853
  this._kanbanEventService = _kanbanEventService;
13841
13854
  this.selected = false;
13855
+ this.showCheckbox = true;
13856
+ }
13857
+ ngOnInit() {
13858
+ this._createTieredOptions();
13842
13859
  }
13843
13860
  onSelectedChange(value) {
13844
13861
  if (value) {
@@ -13848,6 +13865,13 @@ let KanbanItemComponent = class KanbanItemComponent {
13848
13865
  this._kanbanEventService.emitUnselectItemEvent(this.item);
13849
13866
  }
13850
13867
  }
13868
+ _createTieredOptions() {
13869
+ const options = [];
13870
+ this.item.options.forEach((option) => {
13871
+ options.push(Object.assign(Object.assign({}, option), { command: () => { option.command(this.item); } }));
13872
+ });
13873
+ this.item.options = options;
13874
+ }
13851
13875
  };
13852
13876
  KanbanItemComponent.ctorParameters = () => [
13853
13877
  { type: KanbanEventService }
@@ -13858,6 +13882,9 @@ __decorate([
13858
13882
  __decorate([
13859
13883
  Input()
13860
13884
  ], KanbanItemComponent.prototype, "selected", void 0);
13885
+ __decorate([
13886
+ Input()
13887
+ ], KanbanItemComponent.prototype, "showCheckbox", void 0);
13861
13888
  __decorate([
13862
13889
  Input()
13863
13890
  ], KanbanItemComponent.prototype, "headerTemplate", void 0);
@@ -13869,9 +13896,9 @@ __decorate([
13869
13896
  ], KanbanItemComponent.prototype, "footerTemplate", void 0);
13870
13897
  KanbanItemComponent = __decorate([
13871
13898
  Component({
13872
- selector: 's-kanban-item',
13873
- template: "<p-tieredMenu\n #optionsMenu\n [popup]=\"true\"\n appendTo=\"body\"\n [baseZIndex]=\"9999\"\n [model]=\"item.options\">\n</p-tieredMenu>\n\n<div\n class=\"kanban-item\"\n [ngClass]=\"{\n 'kanban-item--selected': selected && !item.disabled,\n 'kanban-item--disabled': item.disabled\n }\">\n <div class=\"kanban-item__header\">\n <div class=\"content\">\n <form>\n <input\n *ngIf=\"!item.disabled\"\n type=\"checkbox\"\n name=\"checkbox\"\n [(ngModel)]=\"selected\"\n (ngModelChange)=\"onSelectedChange($event)\"\n (click)=\"$event.stopPropagation()\">\n </form>\n <ng-container *ngTemplateOutlet=\"headerTemplate; context: { $implicit: item }\"></ng-container>\n </div>\n <button\n *ngIf=\"item.options && !item.disabled\"\n class=\"options-button\"\n (click)=\"optionsMenu.toggle($event); $event.stopPropagation();\">\n <i class=\"fas fa-ellipsis-v\"></i>\n </button>\n </div>\n <div class=\"kanban-item__body\">\n <ng-container *ngTemplateOutlet=\"bodyTemplate; context: { $implicit: item }\"></ng-container>\n </div>\n <div *ngIf=\"footerTemplate\" class=\"kanban-item__footer\">\n <ng-container *ngTemplateOutlet=\"footerTemplate; context: { $implicit: item }\"></ng-container> \n </div>\n</div>",
13874
- styles: [".kanban-item{background-color:#fff;border-radius:4px;box-shadow:0 1px 5px 0 rgba(0,0,0,.25);cursor:pointer;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;margin:16px;min-width:260px;padding:16px;-webkit-user-select:none;-ms-user-select:none;user-select:none}.kanban-item .kanban-item__header{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.kanban-item .kanban-item__header .content{display:-ms-flexbox;display:flex;gap:16px}.kanban-item .kanban-item__header .options-button{background-color:transparent;border:none;cursor:pointer;margin-right:-8px;padding:0 8px}.kanban-item .kanban-item__body{margin:16px 0}.kanban-item .kanban-item__footer{border-top:1px solid #dedce5;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.kanban-item .kanban-item__footer .date-info{-ms-flex-align:center;align-items:center;color:#6e7280;display:-ms-flexbox;display:flex;font-family:\"Open Sans\" sans-serif;font-size:12px;gap:4px;line-height:150%}.kanban-item--selected{border:1px solid #428bca}.kanban-item--disabled{opacity:50%}"]
13899
+ selector: "s-kanban-item",
13900
+ template: "<p-tieredMenu\n #optionsMenu\n [popup]=\"true\"\n appendTo=\"body\"\n [baseZIndex]=\"9999\"\n [model]=\"item.options\">\n</p-tieredMenu>\n\n<div\n class=\"kanban-item\"\n [ngClass]=\"{\n 'kanban-item--selected': selected && !item.disabled,\n 'kanban-item--disabled': item.disabled,\n 'kanban-item--frozen': !item.disabled && item.frozen\n }\">\n <div class=\"kanban-item__header\">\n <div class=\"content\">\n <form>\n <input\n *ngIf=\"showCheckbox && !item.disabled && !item.frozen\"\n type=\"checkbox\"\n name=\"checkbox\"\n [(ngModel)]=\"selected\"\n (ngModelChange)=\"onSelectedChange($event)\"\n (click)=\"$event.stopPropagation()\">\n </form>\n <ng-container *ngTemplateOutlet=\"headerTemplate; context: { $implicit: item }\"></ng-container>\n </div>\n <button\n *ngIf=\"item.options && !item.disabled\"\n class=\"options-button\"\n (click)=\"optionsMenu.toggle($event); $event.stopPropagation();\">\n <i class=\"fas fa-ellipsis-v\"></i>\n </button>\n </div>\n <div class=\"kanban-item__body\">\n <ng-container *ngTemplateOutlet=\"bodyTemplate; context: { $implicit: item }\"></ng-container>\n </div>\n <div *ngIf=\"footerTemplate\" class=\"kanban-item__footer\">\n <ng-container *ngTemplateOutlet=\"footerTemplate; context: { $implicit: item }\"></ng-container> \n </div>\n</div>",
13901
+ styles: [".kanban-item{background-color:#fff;border-radius:4px;box-shadow:0 1px 5px 0 rgba(0,0,0,.25);cursor:pointer;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;margin:16px;min-width:260px;padding:16px;-webkit-user-select:none;-ms-user-select:none;user-select:none}.kanban-item .kanban-item__header{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.kanban-item .kanban-item__header .content{display:-ms-flexbox;display:flex;gap:16px}.kanban-item .kanban-item__header .options-button{background-color:transparent;border:none;cursor:pointer;margin-right:-8px;padding:0 8px}.kanban-item .kanban-item__body{margin:16px 0}.kanban-item .kanban-item__footer{border-top:1px solid #dedce5;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.kanban-item .kanban-item__footer .date-info{-ms-flex-align:center;align-items:center;color:#6e7280;display:-ms-flexbox;display:flex;font-family:\"Open Sans\" sans-serif;font-size:12px;gap:4px;line-height:150%}.kanban-item--selected{border:1px solid #428bca}.kanban-item--disabled{opacity:50%}.kanban-item--frozen{box-shadow:none}"]
13875
13902
  })
13876
13903
  ], KanbanItemComponent);
13877
13904
 
@@ -13931,6 +13958,10 @@ let NavigationButtonComponent = NavigationButtonComponent_1 = class NavigationBu
13931
13958
  this._value = this.defaultValue;
13932
13959
  const index = this.steps.findIndex((step) => step.value === this._value);
13933
13960
  this.currentIndex = index !== -1 ? index : 0;
13961
+ this.stepChanged.emit({
13962
+ previous: undefined,
13963
+ current: this.steps[this.currentIndex],
13964
+ });
13934
13965
  this.changeDetectorRef.detectChanges();
13935
13966
  }
13936
13967
  }