desy-angular 5.2.0 → 6.0.1

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 (152) hide show
  1. package/bundles/desy-angular.umd.js +1435 -118
  2. package/bundles/desy-angular.umd.js.map +1 -1
  3. package/bundles/desy-angular.umd.min.js +1 -15
  4. package/bundles/desy-angular.umd.min.js.map +1 -1
  5. package/desy-angular.d.ts +39 -27
  6. package/desy-angular.metadata.json +1 -1
  7. package/esm2015/desy-angular.js +40 -28
  8. package/esm2015/lib/desy-buttons/components/button/button.component.js +4 -4
  9. package/esm2015/lib/desy-buttons/components/button-loader/button-loader.component.js +2 -2
  10. package/esm2015/lib/desy-buttons/components/dropdown/dropdown.component.js +8 -5
  11. package/esm2015/lib/desy-buttons/components/listbox/listbox.component.js +2 -2
  12. package/esm2015/lib/desy-buttons/components/toggle/toggle.component.js +6 -3
  13. package/esm2015/lib/desy-commons/components/description/description.component.js +3 -2
  14. package/esm2015/lib/desy-commons/components/divider/divider.component.js +15 -0
  15. package/esm2015/lib/desy-commons/components/icon/icon.component.js +3 -2
  16. package/esm2015/lib/desy-commons/desy-commons.module.js +6 -3
  17. package/esm2015/lib/desy-commons/interfaces/description-data.js +1 -1
  18. package/esm2015/lib/desy-commons/interfaces/divider-data.js +2 -0
  19. package/esm2015/lib/desy-commons/interfaces/icon-data.js +1 -1
  20. package/esm2015/lib/desy-commons/interfaces/index.js +2 -1
  21. package/esm2015/lib/desy-forms/components/character-count/character-count.component.js +2 -2
  22. package/esm2015/lib/desy-forms/components/checkboxes/checkbox-item/checkbox-item.component.js +5 -4
  23. package/esm2015/lib/desy-forms/components/checkboxes/checkboxes.component.js +3 -3
  24. package/esm2015/lib/desy-forms/components/date-input/date-input.component.js +11 -4
  25. package/esm2015/lib/desy-forms/components/file-upload/file-upload.component.js +11 -5
  26. package/esm2015/lib/desy-forms/components/input/input.component.js +16 -3
  27. package/esm2015/lib/desy-forms/components/input-group/input-group-input/input-group-input.component.js +2 -1
  28. package/esm2015/lib/desy-forms/components/input-group/input-group-select/input-group-select.component.js +2 -1
  29. package/esm2015/lib/desy-forms/components/input-group/input-group.component.js +2 -2
  30. package/esm2015/lib/desy-forms/components/radios/radio-item/radio-item.component.js +3 -3
  31. package/esm2015/lib/desy-forms/components/radios/radios.component.js +2 -2
  32. package/esm2015/lib/desy-forms/components/search-bar/search-bar.component.js +7 -3
  33. package/esm2015/lib/desy-forms/components/select/select.component.js +2 -2
  34. package/esm2015/lib/desy-forms/components/textarea/textarea.component.js +9 -4
  35. package/esm2015/lib/desy-forms/components/tree/tree-item/tree-item.component.js +2 -2
  36. package/esm2015/lib/desy-forms/components/tree/tree.component.js +3 -3
  37. package/esm2015/lib/desy-forms/interfaces/item-input-group-data.js +1 -1
  38. package/esm2015/lib/desy-modals/components/dialog/dialog.component.js +3 -3
  39. package/esm2015/lib/desy-modals/components/modal/modal-button-loader-primary/modal-button-loader-primary.component.js +20 -0
  40. package/esm2015/lib/desy-modals/components/modal/modal-button-loader-secondary/modal-button-loader-secondary.component.js +19 -0
  41. package/esm2015/lib/desy-modals/components/modal/modal-button-primary/modal-button-primary.component.js +3 -3
  42. package/esm2015/lib/desy-modals/components/modal/modal-button-secondary/modal-button-secondary.component.js +3 -3
  43. package/esm2015/lib/desy-modals/components/modal/modal.component.js +15 -3
  44. package/esm2015/lib/desy-modals/desy-modals.module.js +7 -1
  45. package/esm2015/lib/desy-modals/interfaces/modal-button-data.js +1 -1
  46. package/esm2015/lib/desy-nav/components/footer/footer.component.js +9 -2
  47. package/esm2015/lib/desy-nav/components/header/header-custom-navigation/header-custom-navigation.component.js +11 -0
  48. package/esm2015/lib/desy-nav/components/header/header-navigation/header-navigation.component.js +2 -2
  49. package/esm2015/lib/desy-nav/components/header/header-offcanvas/header-offcanvas-button/header-offcanvas-button.component.js +2 -2
  50. package/esm2015/lib/desy-nav/components/header/header-subnav/header-subnav.component.js +2 -2
  51. package/esm2015/lib/desy-nav/components/header/header.component.js +10 -2
  52. package/esm2015/lib/desy-nav/components/menu-navigation/components/menu-navigation-item/menu-navigation-item.component.js +35 -0
  53. package/esm2015/lib/desy-nav/components/menu-navigation/components/menu-navigation-subitem/menu-navigation-subitem.component.js +31 -0
  54. package/esm2015/lib/desy-nav/components/menu-navigation/menu-navigation.component.js +568 -0
  55. package/esm2015/lib/desy-nav/components/menubar/menubar.component.js +33 -5
  56. package/esm2015/lib/desy-nav/desy-nav.module.js +15 -2
  57. package/esm2015/lib/desy-nav/interfaces/header-navigation-item-data.js +1 -1
  58. package/esm2015/lib/desy-nav/interfaces/index.js +4 -1
  59. package/esm2015/lib/desy-nav/interfaces/menu-navigation-item-sub-item-sub-item.js +2 -0
  60. package/esm2015/lib/desy-nav/interfaces/menu-navigation-item-sub-item.js +2 -0
  61. package/esm2015/lib/desy-nav/interfaces/menu-navigation.js +2 -0
  62. package/esm2015/lib/desy-pagination/components/pagination/pagination.component.js +48 -5
  63. package/esm2015/lib/desy-pagination/components/pagination-item-perpage/pagination-item-perpage.component.js +15 -0
  64. package/esm2015/lib/desy-pagination/components/pagination-listbox-label/pagination-listbox-label.component.js +14 -0
  65. package/esm2015/lib/desy-pagination/desy-pagination.module.js +9 -3
  66. package/esm2015/lib/desy-pagination/interfaces/index.js +1 -1
  67. package/esm2015/lib/desy-tables/components/table-advanced/components/table-advanced-header-cell.component.js +16 -3
  68. package/esm2015/lib/desy-tables/components/table-advanced/components/table-advanced-select.component.js +22 -0
  69. package/esm2015/lib/desy-tables/components/table-advanced/table-advanced.component.js +34 -3
  70. package/esm2015/lib/desy-tables/desy-tables.module.js +5 -2
  71. package/esm2015/lib/desy-tables/interfaces/head-cell-data.js +1 -1
  72. package/esm2015/lib/desy-views/components/accordion/accordion-header/accordion-header.component.js +1 -1
  73. package/esm2015/lib/desy-views/components/accordion/accordion-item/accordion-item.component.js +12 -2
  74. package/esm2015/lib/desy-views/components/accordion/accordion.component.js +32 -4
  75. package/esm2015/lib/desy-views/components/accordion-history/accordion-history-item/accordion-history-item.component.js +31 -0
  76. package/esm2015/lib/desy-views/components/accordion-history/accordion-history.component.js +15 -0
  77. package/esm2015/lib/desy-views/components/accordion-history/accordion-item-hide-button/accordion-item-hide-button.component.js +14 -0
  78. package/esm2015/lib/desy-views/components/accordion-history/accordion-item-show-button/accordion-item-show-button.component.js +14 -0
  79. package/esm2015/lib/desy-views/components/collapsible/collapsible.component.js +2 -2
  80. package/esm2015/lib/desy-views/components/item/item.component.js +23 -5
  81. package/esm2015/lib/desy-views/components/media-object/media-object.component.js +37 -4
  82. package/esm2015/lib/desy-views/components/spinner/spinner.component.js +33 -4
  83. package/esm2015/lib/desy-views/components/status/status.component.js +36 -5
  84. package/esm2015/lib/desy-views/components/status-item/status-item.component.js +35 -4
  85. package/esm2015/lib/desy-views/components/tabs/tabs.component.js +36 -5
  86. package/esm2015/lib/desy-views/components/tooltip/tooltip.component.js +36 -5
  87. package/esm2015/lib/desy-views/desy-views.module.js +14 -2
  88. package/esm2015/public-api.js +5 -1
  89. package/fesm2015/desy-angular.js +1322 -91
  90. package/fesm2015/desy-angular.js.map +1 -1
  91. package/lib/desy-buttons/components/button/button.component.d.ts +2 -2
  92. package/lib/desy-buttons/components/dropdown/dropdown.component.d.ts +5 -4
  93. package/lib/desy-buttons/components/toggle/toggle.component.d.ts +2 -0
  94. package/lib/desy-commons/components/description/description.component.d.ts +1 -0
  95. package/lib/desy-commons/components/divider/divider.component.d.ts +6 -0
  96. package/lib/desy-commons/components/icon/icon.component.d.ts +1 -0
  97. package/lib/desy-commons/interfaces/description-data.d.ts +1 -0
  98. package/lib/desy-commons/interfaces/divider-data.d.ts +4 -0
  99. package/lib/desy-commons/interfaces/icon-data.d.ts +1 -0
  100. package/lib/desy-commons/interfaces/index.d.ts +1 -0
  101. package/lib/desy-forms/components/checkboxes/checkbox-item/checkbox-item.component.d.ts +1 -1
  102. package/lib/desy-forms/components/date-input/date-input.component.d.ts +6 -3
  103. package/lib/desy-forms/components/file-upload/file-upload.component.d.ts +6 -2
  104. package/lib/desy-forms/components/input/input.component.d.ts +5 -2
  105. package/lib/desy-forms/components/input-group/input-group-input/input-group-input.component.d.ts +1 -0
  106. package/lib/desy-forms/components/input-group/input-group-select/input-group-select.component.d.ts +1 -0
  107. package/lib/desy-forms/components/radios/radio-item/radio-item.component.d.ts +1 -1
  108. package/lib/desy-forms/components/search-bar/search-bar.component.d.ts +5 -3
  109. package/lib/desy-forms/components/textarea/textarea.component.d.ts +3 -1
  110. package/lib/desy-forms/components/tree/tree.component.d.ts +1 -1
  111. package/lib/desy-forms/interfaces/item-input-group-data.d.ts +1 -0
  112. package/lib/desy-modals/components/dialog/dialog.component.d.ts +1 -1
  113. package/lib/desy-modals/components/modal/modal-button-loader-primary/modal-button-loader-primary.component.d.ts +8 -0
  114. package/lib/desy-modals/components/modal/modal-button-loader-secondary/modal-button-loader-secondary.component.d.ts +7 -0
  115. package/lib/desy-modals/components/modal/modal-button-primary/modal-button-primary.component.d.ts +3 -3
  116. package/lib/desy-modals/components/modal/modal-button-secondary/modal-button-secondary.component.d.ts +3 -3
  117. package/lib/desy-modals/components/modal/modal.component.d.ts +8 -0
  118. package/lib/desy-modals/interfaces/modal-button-data.d.ts +16 -0
  119. package/lib/desy-nav/components/footer/footer.component.d.ts +5 -0
  120. package/lib/desy-nav/components/header/header-custom-navigation/header-custom-navigation.component.d.ts +3 -0
  121. package/lib/desy-nav/components/header/header.component.d.ts +5 -0
  122. package/lib/desy-nav/components/menu-navigation/components/menu-navigation-item/menu-navigation-item.component.d.ts +22 -0
  123. package/lib/desy-nav/components/menu-navigation/components/menu-navigation-subitem/menu-navigation-subitem.component.d.ts +19 -0
  124. package/lib/desy-nav/components/menu-navigation/menu-navigation.component.d.ts +80 -0
  125. package/lib/desy-nav/components/menubar/menubar.component.d.ts +16 -2
  126. package/lib/desy-nav/interfaces/header-navigation-item-data.d.ts +1 -0
  127. package/lib/desy-nav/interfaces/index.d.ts +3 -0
  128. package/lib/desy-nav/interfaces/menu-navigation-item-sub-item-sub-item.d.ts +14 -0
  129. package/lib/desy-nav/interfaces/menu-navigation-item-sub-item.d.ts +6 -0
  130. package/lib/desy-nav/interfaces/menu-navigation.d.ts +17 -0
  131. package/lib/desy-pagination/components/pagination/pagination.component.d.ts +15 -4
  132. package/lib/desy-pagination/components/pagination-item-perpage/pagination-item-perpage.component.d.ts +7 -0
  133. package/lib/desy-pagination/components/pagination-listbox-label/pagination-listbox-label.component.d.ts +4 -0
  134. package/lib/desy-tables/components/table-advanced/components/table-advanced-header-cell.component.d.ts +7 -0
  135. package/lib/desy-tables/components/table-advanced/components/table-advanced-select.component.d.ts +9 -0
  136. package/lib/desy-tables/components/table-advanced/table-advanced.component.d.ts +8 -0
  137. package/lib/desy-tables/interfaces/head-cell-data.d.ts +3 -0
  138. package/lib/desy-views/components/accordion/accordion-item/accordion-item.component.d.ts +4 -0
  139. package/lib/desy-views/components/accordion/accordion.component.d.ts +17 -3
  140. package/lib/desy-views/components/accordion-history/accordion-history-item/accordion-history-item.component.d.ts +9 -0
  141. package/lib/desy-views/components/accordion-history/accordion-history.component.d.ts +6 -0
  142. package/lib/desy-views/components/accordion-history/accordion-item-hide-button/accordion-item-hide-button.component.d.ts +4 -0
  143. package/lib/desy-views/components/accordion-history/accordion-item-show-button/accordion-item-show-button.component.d.ts +4 -0
  144. package/lib/desy-views/components/item/item.component.d.ts +8 -4
  145. package/lib/desy-views/components/media-object/media-object.component.d.ts +19 -3
  146. package/lib/desy-views/components/spinner/spinner.component.d.ts +17 -2
  147. package/lib/desy-views/components/status/status.component.d.ts +18 -2
  148. package/lib/desy-views/components/status-item/status-item.component.d.ts +18 -3
  149. package/lib/desy-views/components/tabs/tabs.component.d.ts +18 -3
  150. package/lib/desy-views/components/tooltip/tooltip.component.d.ts +18 -3
  151. package/package.json +2 -2
  152. package/public-api.d.ts +4 -0
@@ -0,0 +1,568 @@
1
+ import { ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, HostBinding, Input, Output, ViewChild, ViewChildren } from '@angular/core';
2
+ import { AccessibilityComponent } from '../../../shared/components';
3
+ import { MenubaritemDirective } from '../menubar/directives/menubaritem.directive';
4
+ import { MenuNavigationItemComponent } from './components/menu-navigation-item/menu-navigation-item.component';
5
+ import { MenuNavigationSubitemComponent } from './components/menu-navigation-subitem/menu-navigation-subitem.component';
6
+ export class MenuNavigationComponent extends AccessibilityComponent {
7
+ constructor(changeDetectorRef) {
8
+ super();
9
+ this.changeDetectorRef = changeDetectorRef;
10
+ this.itemsChange = new EventEmitter();
11
+ this.activeItemChange = new EventEmitter();
12
+ this.activeSubItemChange = new EventEmitter();
13
+ this.cfg = true;
14
+ this.viewInit = false;
15
+ this.currentFocusItemIndex = 0;
16
+ }
17
+ ngOnChanges(changes) {
18
+ this.roleData = this.role ? this.role : null;
19
+ this.ariaLabelData = this.ariaLabel ? this.ariaLabel : null;
20
+ this.ariaDescribedbyData = this.ariaDescribedBy ? this.ariaDescribedBy : null;
21
+ this.ariaLabelledbyData = this.ariaLabelledBy ? this.ariaLabelledBy : null;
22
+ this.ariaHiddenData = this.ariaHidden ? this.ariaHidden : null;
23
+ this.ariaDisabledData = this.ariaDisabled ? this.ariaDisabled : null;
24
+ this.ariaControlsData = this.ariaControls ? this.ariaControls : null;
25
+ this.ariaCurrentData = this.ariaCurrent ? this.ariaCurrent : null;
26
+ this.ariaLiveData = this.ariaLive ? this.ariaLive : null;
27
+ this.ariaExpandedData = this.ariaExpanded ? this.ariaExpanded : null;
28
+ this.ariaErrormessageData = this.ariaErrorMessage ? this.ariaErrorMessage : null;
29
+ this.ariaHaspopupData = this.ariaHasPopup ? this.ariaHasPopup : null;
30
+ this.ariaModalData = this.ariaModal ? this.ariaModal : null;
31
+ if (this.viewInit) {
32
+ this.checkChanges();
33
+ }
34
+ }
35
+ ngAfterViewInit() {
36
+ this.viewInit = true;
37
+ this.checkChanges();
38
+ }
39
+ checkChanges() {
40
+ if (!this.menuItems) {
41
+ return;
42
+ }
43
+ this.menuData = [];
44
+ this.getItems().forEach((_, index) => {
45
+ const itemData = {
46
+ open: false,
47
+ currentFocusSubItemIndex: 0,
48
+ currentFocusSubSubItemIndex: 0,
49
+ menuItem: this.menuItems.toArray()[index]
50
+ };
51
+ this.menuData.push(itemData);
52
+ });
53
+ if (this.viewInit) {
54
+ this.checkRequired();
55
+ }
56
+ const lastCurrentFocusItemIndex = this.currentFocusItemIndex;
57
+ const items = this.getItems();
58
+ if (items) {
59
+ while (!this.isItemFocusable(this.currentFocusItemIndex % items.length)) {
60
+ this.currentFocusItemIndex = (this.currentFocusItemIndex + items.length + 1) % items.length;
61
+ if (this.currentFocusItemIndex === lastCurrentFocusItemIndex) {
62
+ break;
63
+ }
64
+ }
65
+ }
66
+ }
67
+ /*
68
+ * Eventos
69
+ */
70
+ handleMenuFocusIn() {
71
+ this.isFocused = true;
72
+ this.changeDetectorRef.detectChanges();
73
+ }
74
+ handleMenuFocusOut(event) {
75
+ if (!this.menunavigation.nativeElement.contains(event.relatedTarget)) {
76
+ this.closeMenu();
77
+ }
78
+ this.isFocused = false;
79
+ this.changeDetectorRef.detectChanges();
80
+ }
81
+ handleMenuItemClick(event, itemIndex) {
82
+ if (this.hasPopupMenu(itemIndex)) {
83
+ event.preventDefault();
84
+ const isOpen = this.menuData[itemIndex].open;
85
+ this.closeMenu();
86
+ if (!isOpen) {
87
+ this.openMenu(itemIndex);
88
+ }
89
+ }
90
+ else {
91
+ this.activateMenuItem(itemIndex);
92
+ }
93
+ }
94
+ handleMenuItemKeydown(event, itemIndex) {
95
+ switch (event.key) {
96
+ case 'Enter':
97
+ case ' ':
98
+ case 'ArrowDown':
99
+ if (this.hasPopupMenu(itemIndex)) {
100
+ this.openMenu(itemIndex);
101
+ setTimeout(() => this.focusFirstSubItem(itemIndex));
102
+ event.stopPropagation();
103
+ event.preventDefault();
104
+ }
105
+ break;
106
+ case 'Escape':
107
+ if (this.hasPopupMenu(itemIndex)) {
108
+ this.closeMenu(itemIndex);
109
+ }
110
+ event.stopPropagation();
111
+ event.preventDefault();
112
+ break;
113
+ case 'ArrowLeft':
114
+ this.focusNextAvailableItem(itemIndex, -1);
115
+ event.stopPropagation();
116
+ event.preventDefault();
117
+ break;
118
+ case 'ArrowRight':
119
+ this.focusNextAvailableItem(itemIndex, +1);
120
+ event.stopPropagation();
121
+ event.preventDefault();
122
+ break;
123
+ case 'ArrowUp':
124
+ if (this.hasPopupMenu(itemIndex)) {
125
+ this.openMenu(itemIndex);
126
+ setTimeout(() => this.focusLastSubItem(itemIndex));
127
+ }
128
+ event.stopPropagation();
129
+ event.preventDefault();
130
+ break;
131
+ case 'Home':
132
+ case 'PageUp':
133
+ if (this.hasPopupMenu(itemIndex)) {
134
+ this.closeMenu();
135
+ }
136
+ this.focusFirstItem();
137
+ event.stopPropagation();
138
+ event.preventDefault();
139
+ break;
140
+ case 'End':
141
+ case 'PageDown':
142
+ if (this.hasPopupMenu(itemIndex)) {
143
+ this.closeMenu();
144
+ }
145
+ this.focusLastItem();
146
+ event.stopPropagation();
147
+ event.preventDefault();
148
+ break;
149
+ default:
150
+ if (this.isPrintableChar(event.key)) {
151
+ this.focusItemByFirstChar(event.key);
152
+ event.stopPropagation();
153
+ event.preventDefault();
154
+ }
155
+ break;
156
+ }
157
+ }
158
+ handleMenuItemMouseOver(itemIndex) {
159
+ this.focusItem(itemIndex, true);
160
+ }
161
+ handlePopupMenuItemClick(itemIndex, subItemIndex, subSubItemIndex) {
162
+ this.activatePopupMenuItem(itemIndex, subItemIndex, subSubItemIndex);
163
+ this.focusItem(itemIndex);
164
+ this.closeMenu(itemIndex);
165
+ }
166
+ handlePopupMenuItemKeydown(event, itemIndex, subItemIndex, subSubItemIndex) {
167
+ const currentSubIndex = this.menuData[itemIndex].currentFocusSubItemIndex;
168
+ const currentSubSubIndex = this.menuData[itemIndex].currentFocusSubSubItemIndex;
169
+ const items = this.getItems();
170
+ switch (event.key) {
171
+ case ' ':
172
+ this.activatePopupMenuItem(itemIndex, subItemIndex, subSubItemIndex);
173
+ if (this.mustCloseAfterSelectPopupItem(itemIndex, subItemIndex, subSubItemIndex)) {
174
+ this.closeMenu(itemIndex);
175
+ this.focusItem(itemIndex);
176
+ }
177
+ event.stopPropagation();
178
+ event.preventDefault();
179
+ break;
180
+ case 'Enter':
181
+ this.activatePopupMenuItem(itemIndex, subItemIndex, subSubItemIndex);
182
+ this.closeMenu(itemIndex);
183
+ this.focusItem(itemIndex);
184
+ event.stopPropagation();
185
+ event.preventDefault();
186
+ break;
187
+ case 'Escape':
188
+ this.closeMenu(itemIndex);
189
+ this.focusItem(itemIndex);
190
+ event.stopPropagation();
191
+ event.preventDefault();
192
+ break;
193
+ case 'ArrowUp':
194
+ this.focusNextAvailableSubItem(itemIndex, currentSubIndex, currentSubSubIndex, -1);
195
+ // this.focusSubItem(itemIndex, (currentSubIndex + listLength - 1) % listLength);
196
+ event.stopPropagation();
197
+ event.preventDefault();
198
+ break;
199
+ case 'ArrowDown':
200
+ this.focusNextAvailableSubItem(itemIndex, currentSubIndex, currentSubSubIndex, +1);
201
+ // this.focusSubItem(itemIndex, (currentSubIndex + listLength + 1) % listLength);
202
+ event.stopPropagation();
203
+ event.preventDefault();
204
+ break;
205
+ case 'ArrowLeft':
206
+ this.closeMenu(itemIndex);
207
+ this.focusItem((itemIndex + items.length - 1) % items.length);
208
+ event.stopPropagation();
209
+ event.preventDefault();
210
+ break;
211
+ case 'ArrowRight':
212
+ this.closeMenu(itemIndex);
213
+ this.focusItem((itemIndex + items.length + 1) % items.length);
214
+ event.stopPropagation();
215
+ event.preventDefault();
216
+ break;
217
+ case 'Home':
218
+ case 'PageUp':
219
+ this.focusFirstSubItem(itemIndex);
220
+ event.stopPropagation();
221
+ event.preventDefault();
222
+ break;
223
+ case 'End':
224
+ case 'PageDown':
225
+ this.focusLastSubItem(itemIndex);
226
+ event.stopPropagation();
227
+ event.preventDefault();
228
+ break;
229
+ case 'Tab':
230
+ this.closeMenu(itemIndex);
231
+ this.focusItem(itemIndex);
232
+ break;
233
+ default:
234
+ if (this.isPrintableChar(event.key)) {
235
+ this.focusSubItemByFirstChar(itemIndex, event.key);
236
+ event.stopPropagation();
237
+ event.preventDefault();
238
+ }
239
+ break;
240
+ }
241
+ }
242
+ handlePopupMenuItemMouseOver(itemIndex, subItemIndex, subSubItemIndex) {
243
+ this.focusSubItem(itemIndex, subItemIndex, subSubItemIndex);
244
+ }
245
+ /*
246
+ * Comunes
247
+ */
248
+ checkRequired() {
249
+ const items = this.getItems();
250
+ }
251
+ activateMenuItem(itemIndex) {
252
+ const items = this.getItems();
253
+ this.activeItemChange.emit(items[itemIndex]);
254
+ if (items[itemIndex] instanceof MenuNavigationItemComponent) {
255
+ items[itemIndex].selected.emit();
256
+ }
257
+ }
258
+ activatePopupMenuItem(itemIndex, subItemIndex, subSubItemIndex) {
259
+ const items = this.getItems();
260
+ const subItems = this.getItemSubitems(items[itemIndex]);
261
+ let item = subItems[subItemIndex];
262
+ this.itemsChange.emit(items);
263
+ this.activeSubItemChange.emit(item);
264
+ if (item instanceof MenuNavigationSubitemComponent) {
265
+ item.selected.emit();
266
+ }
267
+ }
268
+ mustCloseAfterSelectPopupItem(itemIndex, subItemIndex, subSubItemIndex) {
269
+ const items = this.getItems();
270
+ const subItems = this.getItemSubitems(items[itemIndex]);
271
+ let item = subItems[subItemIndex];
272
+ return item.role !== 'menuitemcheckbox' && item.role !== 'menuitemradio';
273
+ }
274
+ openMenu(itemIndex) {
275
+ const wasOpened = this.menuData[itemIndex].open;
276
+ this.menuData[itemIndex].open = true;
277
+ if (wasOpened) {
278
+ this.activateMenuItem(itemIndex);
279
+ }
280
+ }
281
+ closeMenu(itemIndex) {
282
+ if (itemIndex !== null && itemIndex !== undefined) {
283
+ this.menuData[itemIndex].open = false;
284
+ }
285
+ else {
286
+ this.menuData.forEach(item => item.open = false);
287
+ }
288
+ }
289
+ hasPopupMenu(itemIndex) {
290
+ const items = this.getItems();
291
+ const subItems = this.getItemSubitems(items[itemIndex]);
292
+ return items[itemIndex].sub && subItems && subItems.length > 0;
293
+ }
294
+ isPrintableChar(str) {
295
+ return str.length === 1 && !!str.match(/\S/);
296
+ }
297
+ /*
298
+ * Comunes - focus
299
+ */
300
+ focusItem(itemIndex, hover) {
301
+ const hasFocus = this.menunavigation.nativeElement.contains(document.activeElement);
302
+ const isOpen = this.menuData[this.currentFocusItemIndex].open;
303
+ if (!hover || hasFocus) {
304
+ this.menuData[itemIndex].menuItem.link.nativeElement.focus();
305
+ }
306
+ this.closeMenu();
307
+ if (isOpen && this.hasPopupMenu(itemIndex)) {
308
+ this.openMenu(itemIndex);
309
+ }
310
+ this.currentFocusItemIndex = itemIndex;
311
+ }
312
+ focusNextAvailableItem(fromItemIndex, step) {
313
+ let nextItem = fromItemIndex;
314
+ const items = this.getItems();
315
+ do {
316
+ nextItem = (nextItem + items.length + step) % items.length;
317
+ } while (!this.isItemFocusable(nextItem) && nextItem !== fromItemIndex);
318
+ if (nextItem !== fromItemIndex) {
319
+ this.focusItem(nextItem);
320
+ }
321
+ }
322
+ focusFirstItem() {
323
+ if (this.isItemFocusable(0)) {
324
+ this.focusItem(0);
325
+ }
326
+ else {
327
+ this.focusNextAvailableItem(0, +1);
328
+ }
329
+ }
330
+ focusLastItem() {
331
+ const items = this.getItems();
332
+ if (this.isItemFocusable(items.length - 1)) {
333
+ this.focusItem(items.length - 1);
334
+ }
335
+ else {
336
+ this.focusNextAvailableItem(items.length - 1, -1);
337
+ }
338
+ }
339
+ isItemFocusable(itemIndex) {
340
+ return !this.getItems()[itemIndex].disabled;
341
+ }
342
+ focusItemByFirstChar(char) {
343
+ const itemContents = this.menuItems.map(menuItem => menuItem.itemContentWrapper.nativeElement.textContent);
344
+ let index = this.currentFocusItemIndex;
345
+ let foundIndex = -1;
346
+ do {
347
+ index = (index + itemContents.length + 1) % itemContents.length;
348
+ if (itemContents[index] && itemContents[index].trim().substr(0, 1).toLowerCase() === char.toLowerCase()
349
+ && this.isItemFocusable(index)) {
350
+ foundIndex = index;
351
+ }
352
+ } while (foundIndex === -1 && index !== this.currentFocusItemIndex);
353
+ if (foundIndex >= 0) {
354
+ this.focusItem(foundIndex);
355
+ }
356
+ }
357
+ focusSubItem(itemIndex, subItemIndex, subSubItemIndex) {
358
+ if (this.menuData[itemIndex].menuItem.popupMenuItems.length > 0) {
359
+ const menuDataIndex = subItemIndex;
360
+ this.menuData[itemIndex].currentFocusSubItemIndex = subItemIndex;
361
+ this.menuData[itemIndex].currentFocusSubSubItemIndex = subSubItemIndex;
362
+ const elem = this.menuData[itemIndex].menuItem.popupMenuItems.toArray()[menuDataIndex].nativeElement;
363
+ if (elem) {
364
+ elem.focus();
365
+ }
366
+ else {
367
+ console.error('No subitem to focus');
368
+ }
369
+ }
370
+ else {
371
+ console.error('No subitems');
372
+ }
373
+ }
374
+ focusNextAvailableSubItem(itemIndex, fromItemSubIndex, fromItemSubSubIndex, step) {
375
+ let nextSubIndex = fromItemSubIndex;
376
+ let nextSubSubIndex = fromItemSubSubIndex;
377
+ let allSubItemsChecked;
378
+ const items = this.getItems();
379
+ do {
380
+ const nextIndexes = this.getNextSubItemIndexes(items, itemIndex, nextSubIndex, nextSubSubIndex, step);
381
+ nextSubIndex = nextIndexes.subIndex;
382
+ nextSubSubIndex = nextIndexes.subSubIndex;
383
+ allSubItemsChecked = (fromItemSubIndex === nextSubIndex && fromItemSubSubIndex === nextSubSubIndex);
384
+ } while (!this.isSubItemFocusable(itemIndex, nextSubIndex, nextSubSubIndex) && !allSubItemsChecked);
385
+ if (!allSubItemsChecked) {
386
+ this.focusSubItem(itemIndex, nextSubIndex, nextSubSubIndex);
387
+ }
388
+ }
389
+ focusFirstSubItem(itemIndex) {
390
+ let firstSubSubItem = null;
391
+ const items = this.getItems();
392
+ const subItems = this.getItemSubitems(items[itemIndex]);
393
+ if (subItems && subItems.length > 0) {
394
+ firstSubSubItem = 0;
395
+ }
396
+ if (this.isSubItemFocusable(itemIndex, 0, firstSubSubItem)) {
397
+ this.focusSubItem(itemIndex, 0, firstSubSubItem);
398
+ }
399
+ else {
400
+ this.focusNextAvailableSubItem(itemIndex, 0, firstSubSubItem, +1);
401
+ }
402
+ }
403
+ focusLastSubItem(itemIndex) {
404
+ const items = this.getItems();
405
+ const subItems = this.getItemSubitems(items[itemIndex]);
406
+ const lastItemIndex = subItems.length - 1;
407
+ const lastItem = subItems[lastItemIndex];
408
+ let lastSubSubItem = null;
409
+ if (this.isSubItemFocusable(itemIndex, lastItemIndex, lastSubSubItem)) {
410
+ this.focusSubItem(itemIndex, lastItemIndex, lastSubSubItem);
411
+ }
412
+ else {
413
+ this.focusNextAvailableSubItem(itemIndex, lastItemIndex, lastSubSubItem, -1);
414
+ }
415
+ }
416
+ isSubItemFocusable(itemIndex, subItemIndex, subSubItemIndex) {
417
+ const items = this.getItems();
418
+ const subItems = this.getItemSubitems(items[itemIndex]);
419
+ let item = subItems[subItemIndex];
420
+ let isFocusable = false;
421
+ if (item.role !== 'separator' && item.role !== 'none') {
422
+ isFocusable = true;
423
+ }
424
+ return isFocusable;
425
+ }
426
+ focusSubItemByFirstChar(itemIndex, char) {
427
+ const itemContents = this.menuItems.toArray()[itemIndex].popupMenuItems.map(menuItem => menuItem.nativeElement.textContent);
428
+ let subItemIndex = this.menuData[itemIndex].currentFocusSubItemIndex;
429
+ let subSubItemIndex = this.menuData[itemIndex].currentFocusSubSubItemIndex;
430
+ let foundSubIndex = -1;
431
+ let foundSubSubIndex = null;
432
+ let allSubItemsChecked = false;
433
+ const items = this.getItems();
434
+ do {
435
+ const nextIndexes = this.getNextSubItemIndexes(items, itemIndex, subItemIndex, subSubItemIndex, +1);
436
+ subItemIndex = nextIndexes.subIndex;
437
+ subSubItemIndex = nextIndexes.subSubIndex;
438
+ const index = subItemIndex;
439
+ if (itemContents[index] && itemContents[index].trim().substr(0, 1).toLowerCase() === char.toLowerCase()
440
+ && this.isSubItemFocusable(itemIndex, subItemIndex, subSubItemIndex)) {
441
+ foundSubIndex = subItemIndex;
442
+ foundSubSubIndex = subSubItemIndex;
443
+ }
444
+ allSubItemsChecked = (this.menuData[itemIndex].currentFocusSubItemIndex === subItemIndex
445
+ && this.menuData[itemIndex].currentFocusSubSubItemIndex === subSubItemIndex);
446
+ } while (foundSubIndex === -1 && !allSubItemsChecked);
447
+ if (foundSubIndex >= 0) {
448
+ this.focusSubItem(itemIndex, foundSubIndex, foundSubSubIndex);
449
+ }
450
+ }
451
+ /*
452
+ * Metodos para facilitar contenido
453
+ */
454
+ getItems() {
455
+ let items;
456
+ if (this.itemComponentList && this.itemComponentList.length > 0) {
457
+ items = this.itemComponentList.toArray();
458
+ }
459
+ else {
460
+ items = this.items;
461
+ }
462
+ return items;
463
+ }
464
+ getItemSubitems(item) {
465
+ let subItems = [];
466
+ if (item instanceof MenuNavigationItemComponent) {
467
+ subItems = item.getSubItems();
468
+ }
469
+ if (!subItems || subItems.length === 0) {
470
+ subItems = item.sub ? item.sub.items : [];
471
+ }
472
+ return subItems;
473
+ }
474
+ getNextSubItemIndexes(items, itemIndex, nextSubIndex, nextSubSubIndex, step) {
475
+ const subItems = this.getItemSubitems(items[itemIndex]);
476
+ let checkNextSubItem = true;
477
+ if (checkNextSubItem) {
478
+ nextSubIndex = (nextSubIndex + step + subItems.length) % subItems.length;
479
+ }
480
+ return { subIndex: nextSubIndex, subSubIndex: nextSubSubIndex };
481
+ }
482
+ getIdPrefix() {
483
+ return this.idPrefix ? this.idPrefix : this.id + 'menunavigation-item';
484
+ }
485
+ getItemId(item, index) {
486
+ let id;
487
+ if (item) {
488
+ if (item.id) {
489
+ id = item.id;
490
+ }
491
+ else {
492
+ id = index === 0 ? this.getIdPrefix() : `${this.getIdPrefix()}-${index}`;
493
+ }
494
+ }
495
+ return id;
496
+ }
497
+ getPopupStyle(itemIndex) {
498
+ let style = {};
499
+ if (this.menuData && itemIndex < this.menuData.length) {
500
+ const menuItem = this.menuData[itemIndex].menuItem;
501
+ const rect = menuItem.link.nativeElement.getBoundingClientRect();
502
+ if (this.menuData[itemIndex].open) {
503
+ style = {
504
+ position: 'absolute',
505
+ top: '0px',
506
+ left: '0px',
507
+ zIndex: 100,
508
+ display: 'block'
509
+ };
510
+ }
511
+ else {
512
+ style = {
513
+ zIndex: 0,
514
+ display: 'none'
515
+ };
516
+ }
517
+ }
518
+ return style;
519
+ }
520
+ getSubItemId(item, index, parentId) {
521
+ let id;
522
+ if (item) {
523
+ if (item.id) {
524
+ id = item.id;
525
+ }
526
+ else {
527
+ id = index === 0 ? `sub-${parentId}` : `sub-${parentId}-${index}`;
528
+ }
529
+ }
530
+ return id;
531
+ }
532
+ }
533
+ MenuNavigationComponent.decorators = [
534
+ { type: Component, args: [{
535
+ selector: 'desy-menu-navigation',
536
+ template: "<ul #menunavigation [id]=\"id + '-menu-navigation'\" class=\"flex flex-wrap gap-base\"\r\n(focusin)=\"handleMenuFocusIn()\"\r\n(focusout)=\"handleMenuFocusOut($event)\"\r\n[ngClass]=\"{ 'focus': isFocused }\"\r\n[attr.aria-label]=\"ariaLabel ? ariaLabel : null\">\r\n<ng-container *ngFor=\"let item of getItems(); index as itemIndex\">\r\n<li class=\"relative\" role=\"none\" desyMenubaritem (contentChanged)=\"checkChanges()\">\r\n <a *ngIf=\"item.href\" #link\r\n (click)=\"handleMenuItemClick($event, itemIndex)\"\r\n (keydown)=\"handleMenuItemKeydown($event, itemIndex)\"\r\n (mouseover)=\"handleMenuItemMouseOver(itemIndex)\"\r\n (desyAttributeChange)=\"checkChanges()\" [attributesToCheck]=\"'disabled'\"\r\n role=\"item.disabled ? link : null\"\r\n [id]=\"getItemId(item, itemIndex)\"\r\n [target]=\"item.target\"\r\n [href]=\"item.href\"\r\n [class]=\"['c-menu-navigation__button', item.classes] | makeHtmlList\"\r\n [ngClass]=\"{'c-menu-navigation__button--disabled': item.disabled, 'c-menu-navigation__button--primary': item.active, 'c-menu-navigation__button--has-selection': item.active}\"\r\n [attr.disabled]=\"item.disabled ? item.disabled : null\"\r\n [attr.aria-disabled]=\"item.disabled ? item.disabled : (item.ariaDisabled ? item.ariaDisabled : null)\"\r\n [attr.aria-describedby]=\"item.ariaDescribedBy ? item.ariaDescribedBy : null\"\r\n [attr.aria-labelledby]=\"item.ariaLabelledBy ? item.ariaLabelledBy : null\"\r\n [attr.aria-hidden]=\"item.ariaHidden ? item.ariaHidden : null\"\r\n [attr.aria-controls]=\"item.ariaControls ? item.ariaControls : null\"\r\n [attr.aria-current]=\"item.disabled ? 'page' : (item.ariaCurrent ? item.ariaCurrent : null)\"\r\n [attr.aria-live]=\"item.ariaLive ? item.ariaLive : null\"\r\n [attr.aria-errormessage]=\"item.ariaErrorMessage ? item.ariaErrorMessage : null\"\r\n [attr.aria-modal]=\"item.ariaModal ? item.ariaModal : null\"\r\n [attr.tabindex]=\"item.disabled ? -1 : (itemIndex === currentFocusItemIndex ? 0 : -1)\">\r\n <span class=\"inline-flex self-center max-w-xs align-middle truncate pointer-events-none\" #itemContentWrapper>\r\n <ng-container *desyCustomInnerContent=\"{ component: item, html: item.html, text: item.text}\"></ng-container>\r\n </span> \r\n </a>\r\n <button *ngIf=\"!item.href\" #link #itemContentWrapper\r\n (click)=\"handleMenuItemClick($event, itemIndex)\"\r\n (keydown)=\"handleMenuItemKeydown($event, itemIndex)\"\r\n (mouseover)=\"handleMenuItemMouseOver(itemIndex)\"\r\n (desyAttributeChange)=\"checkChanges()\" [attributesToCheck]=\"'disabled'\"\r\n aria-expanded=\"item.sub ? true : false\"\r\n aria-controls=\"item.sub ? id + '-sub-list' : ''\"\r\n [class]=\"['c-menu-navigation__button', item.classes] | makeHtmlList\"\r\n [ngClass]=\"{'c-menu-navigation__button--disabled': item.disabled, 'c-menu-navigation__button--primary': item.active, 'c-menu-navigation__button--has-selection': item.active}\"\r\n [attr.disabled]=\"item.disabled ? item.disabled : null\"\r\n [attr.aria-disabled]=\"item.disabled ? item.disabled : (item.ariaDisabled ? item.ariaDisabled : null)\"\r\n [attr.aria-describedby]=\"item.ariaDescribedBy ? item.ariaDescribedBy : null\"\r\n [attr.aria-labelledby]=\"item.ariaLabelledBy ? item.ariaLabelledBy : null\"\r\n [attr.aria-hidden]=\"item.ariaHidden ? item.ariaHidden : null\"\r\n [attr.aria-controls]=\"item.ariaControls ? item.ariaControls : null\"\r\n [attr.aria-current]=\"item.ariaCurrent ? item.ariaCurrent : null\"\r\n [attr.aria-live]=\"item.ariaLive ? item.ariaLive : null\"\r\n [attr.aria-errormessage]=\"item.ariaErrorMessage ? item.ariaErrorMessage : null\"\r\n [attr.aria-modal]=\"item.ariaModal ? item.ariaModal : null\"\r\n [attr.tabindex]=\"item.disabled ? -1 : (itemIndex === currentFocusItemIndex ? 0 : -1)\">\r\n <span *ngIf=\"item.active\" class=\"sr-only\">Item activo: </span>\r\n <span class=\"inline-flex self-center max-w-xs align-middle truncate pointer-events-none\" #itemContentWrapper>\r\n <ng-container *desyCustomInnerContent=\"{ component: item, html: item.html, text: item.text}\"></ng-container>\r\n </span>\r\n <svg *ngIf=\"item.sub\" class=\"inline-block -mr-2 align-middle -my-px pointer-events-none\" viewBox=\"0 0 96 96\" aria-hidden=\"true\" fill=\"currentColor\" focusable=\"false\" width=\"1.5em\" height=\"1.5em\"><g><path d=\"M46.71 58.037a1.823 1.823 0 002.581 0L62.048 45.28a1.823 1.823 0 00-1.29-3.113H35.243a1.823 1.823 0 00-1.291 3.113z\"/></g></svg>\r\n </button> \r\n\r\n <div *ngIf=\"item.sub && getItemSubitems(item)\" class=\"c-menu-navigation__sub absolute bottom-0 left-0\">\r\n <ul [id]=\"id + '-sub-list'\" [ngStyle]=\"getPopupStyle(itemIndex)\" #popupMenu role=\"menu\" tabindex=\"-1\"\r\n [class]=\"item.sub.classes ? item.sub.classes : 'c-menu-navigation__tooltip w-max max-w-64 border border-neutral-base shadow-md bg-white text-sm'\"\r\n [attr.aria-label]=\"item.ariaLabel ? item.ariaLabel : (item.sub.ariaLabel ? item.sub.ariaLabel : null)\"\r\n [attr.aria-describedby]=\"item.sub.ariaDescribedBy ? item.sub.ariaDescribedBy : null\"\r\n [attr.aria-labelledby]=\"item.sub.ariaLabelledBy ? item.sub.ariaLabelledBy : null\"\r\n [attr.aria-hidden]=\"item.sub.ariaHidden ? item.sub.ariaHidden : null\"\r\n [attr.aria-disabled]=\"item.sub.ariaDisabled ? item.sub.ariaDisabled : null\"\r\n [attr.aria-controls]=\"item.sub.ariaControls ? item.sub.ariaControls : null\"\r\n [attr.aria-current]=\"item.sub.ariaCurrent ? item.sub.ariaCurrent : null\"\r\n [attr.aria-live]=\"item.sub.ariaLive ? item.sub.ariaLive : null\"\r\n [attr.aria-expanded]=\"!!(menuData && menuData[itemIndex].open)\"\r\n [attr.aria-errormessage]=\"item.sub.ariaErrorMessage ? item.sub.ariaErrorMessage : null\"\r\n [attr.aria-haspopup]=\"item.sub.ariaHasPopup ? item.sub.ariaHasPopup : null\"\r\n [attr.aria-modal]=\"item.sub.ariaModal ? item.sub.ariaModal : null\">\r\n <ng-container *ngFor=\"let subItem of getItemSubitems(item); index as subItemIndex\">\t\t\t\t\r\n <li #popupMenuItem *ngIf=\"subItem.href\" role=\"none\" tabindex=\"-1\"\r\n class=\"focus:bg-primary-base focus:text-white focus:outline-none\"\r\n [id]=\"getSubItemId(subItem, subItemIndex, getItemId(item, itemIndex))\"\r\n (click)=\"handlePopupMenuItemClick(itemIndex, subItemIndex)\"\r\n (mouseover)=\"handlePopupMenuItemMouseOver(itemIndex, subItemIndex)\"\r\n (keydown)=\"handlePopupMenuItemKeydown($event, itemIndex, subItemIndex)\">\r\n <span *ngIf=\"subItem.active\" id=\"subItem.id\" #itemContentWrapper \r\n [class]=\"['flex items-center px-base py-sm text-sm font-semibold cursor-pointer hover:bg-primary-base hover:text-white', subItem.classes] | makeHtmlList\" \r\n aria-current=\"page\"\r\n \r\n [attr.aria-label]=\"item.ariaLabel ? item.ariaLabel : (subItem.ariaLabel ? subItem.ariaLabel : null)\"\r\n [attr.aria-describedby]=\"subItem.ariaDescribedBy ? subItem.ariaDescribedBy : null\"\r\n [attr.aria-labelledby]=\"subItem.ariaLabelledBy ? subItem.ariaLabelledBy : null\"\r\n [attr.aria-hidden]=\"subItem.ariaHidden ? subItem.ariaHidden : null\"\r\n [attr.aria-disabled]=\"subItem.ariaDisabled ? subItem.ariaDisabled : null\"\r\n [attr.aria-controls]=\"subItem.ariaControls ? subItem.ariaControls : null\"\r\n [attr.aria-current]=\"subItem.ariaCurrent ? subItem.ariaCurrent : null\"\r\n [attr.aria-live]=\"subItem.ariaLive ? subItem.ariaLive : null\"\r\n [attr.aria-expanded]=\"!!(menuData && menuData[subItemIndex].open)\"\r\n [attr.aria-errormessage]=\"subItem.ariaErrorMessage ? subItem.ariaErrorMessage : null\"\r\n [attr.aria-haspopup]=\"subItem.ariaHasPopup ? subItem.ariaHasPopup : null\"\r\n [attr.aria-modal]=\"subItem.ariaModal ? subItem.ariaModal : null\"\r\n (keydown)=\"handlePopupMenuItemKeydown($event, itemIndex, subItemIndex)\">\r\n <ng-container *desyCustomInnerContent=\"{ component: subItem, html: subItem.html, text: subItem.text}\"></ng-container>\r\n </span>\r\n \r\n <a *ngIf=\"!subItem.active\" #itemContentWrapper\r\n [href]=\"subItem.href\"\r\n (click)=\"handlePopupMenuItemClick(itemIndex, subItemIndex)\"\r\n (mouseover)=\"handlePopupMenuItemMouseOver(itemIndex, subItemIndex)\"\r\n (keydown)=\"handlePopupMenuItemKeydown($event, itemIndex, subItemIndex)\"\r\n (desyAttributeChange)=\"checkChanges()\"\r\n [class]=\"['flex items-center px-base py-sm text-sm hover:bg-primary-base hover:text-white focus:bg-warning-base focus:outline-none focus:shadow-outline-focus focus:text-black', subItem.classes] | makeHtmlList\"\r\n [ngClass]=\"{'pointer-events-none': subItem.disabled}\"\r\n [tabindex]=\"subItem.disabled ? -1 : null\"\r\n [target] = \"subItem.target\">\r\n <span class=\"inline-flex self-center max-w-xs align-middle truncate\" #itemContentWrapper>\r\n <ng-container *desyCustomInnerContent=\"{ component: subItem, html: subItem.html, text: subItem.text}\"></ng-container>\r\n </span>\r\n <svg *ngIf=\"subItem.disabled\" viewBox=\"0 0 140 140\" height=\"1em\" width=\"1em\" xmlns=\"http://www.w3.org/2000/svg\" class=\"inline-block align-middle ml-sm text-neutral-base fill-current\" aria-hidden=\"true\" focusable=\"false\" ><path d=\"M70 0a70 70 0 1070 70A70.08 70.08 0 0070 0zM20 70a50 50 0 0174.8-43.4 2.51 2.51 0 011.23 1.84 2.48 2.48 0 01-.71 2.1L30.54 95.32a2.51 2.51 0 01-3.94-.52A49.63 49.63 0 0120 70zm100 0a50 50 0 01-74.8 43.4 2.51 2.51 0 01-1.23-1.84 2.48 2.48 0 01.71-2.1l64.78-64.78a2.51 2.51 0 013.94.52A49.63 49.63 0 01120 70z\"/></svg>\r\n </a>\r\n </li>\r\n <li #popupMenuItem *ngIf=\"!subItem.href\" role=\"none\" tabindex=\"-1\"\r\n [id]=\"getSubItemId(subItem, subItemIndex, getItemId(item, itemIndex))\"\r\n class=\"focus:bg-primary-base focus:text-white focus:outline-none\"\r\n (click)=\"handlePopupMenuItemClick(itemIndex, subItemIndex)\"\r\n (mouseover)=\"handlePopupMenuItemMouseOver(itemIndex, subItemIndex)\"\r\n (keydown)=\"handlePopupMenuItemKeydown($event, itemIndex, subItemIndex)\">\r\n <span [id]=\"getSubItemId(subItem, subItemIndex, getItemId(item, subItemIndex))\"\r\n class=\"flex items-center px-base py-sm text-sm cursor-pointer hover:bg-primary-base hover:text-white\"\r\n [ngClass]=\"{'font-bold': subItem.active, 'pointer-events-none': subItem.disabled}\">\r\n <ng-container *desyCustomInnerContent=\"{ component: subItem, html: subItem.html, text: subItem.text}\"></ng-container>\r\n </span>\r\n <svg *ngIf=\"subItem.disabled\" viewBox=\"0 0 140 140\" height=\"1em\" width=\"1em\" xmlns=\"http://www.w3.org/2000/svg\" class=\"inline-block align-middle ml-sm text-neutral-base fill-current\" aria-hidden=\"true\" focusable=\"false\" ><path d=\"M70 0a70 70 0 1070 70A70.08 70.08 0 0070 0zM20 70a50 50 0 0174.8-43.4 2.51 2.51 0 011.23 1.84 2.48 2.48 0 01-.71 2.1L30.54 95.32a2.51 2.51 0 01-3.94-.52A49.63 49.63 0 0120 70zm100 0a50 50 0 01-74.8 43.4 2.51 2.51 0 01-1.23-1.84 2.48 2.48 0 01.71-2.1l64.78-64.78a2.51 2.51 0 013.94.52A49.63 49.63 0 01120 70z\"/></svg>\r\n </li>\r\n \r\n <li *ngIf=\"subItem.divider\" class=\"my-sm border-b border-neutral-base\">\r\n <div class=\"sr-only\">Separador</div>\r\n </li>\r\n </ng-container>\r\n </ul>\r\n </div>\r\n</li>\r\n<li #popupMenuItem *ngIf=\"item.divider\" class=\"item.divider.classes\" role=\"presentation\" aria-hidden=\"true\">\r\n <ng-container *desyCustomInnerContent=\"{ component: item.divider, html: item.divider.html, text: item.divider.text}\"></ng-container>\r\n</li>\r\n</ng-container>\r\n</ul>\r\n"
537
+ },] }
538
+ ];
539
+ MenuNavigationComponent.ctorParameters = () => [
540
+ { type: ChangeDetectorRef }
541
+ ];
542
+ MenuNavigationComponent.propDecorators = {
543
+ idPrefix: [{ type: Input }],
544
+ items: [{ type: Input }],
545
+ itemsChange: [{ type: Output }],
546
+ activeItemChange: [{ type: Output }],
547
+ activeSubItemChange: [{ type: Output }],
548
+ menunavigation: [{ type: ViewChild, args: ['menunavigation', { read: ElementRef },] }],
549
+ menuItems: [{ type: ViewChildren, args: [MenubaritemDirective,] }],
550
+ itemComponentList: [{ type: ContentChildren, args: [MenuNavigationItemComponent,] }],
551
+ classes: [{ type: Input }, { type: HostBinding, args: ['class',] }],
552
+ cfg: [{ type: HostBinding, args: ['class.c-menu-navigation',] }],
553
+ id: [{ type: Input }, { type: HostBinding, args: ['attr.id',] }],
554
+ roleData: [{ type: HostBinding, args: ['attr.role',] }],
555
+ ariaLabelData: [{ type: HostBinding, args: ['attr.aria-label',] }],
556
+ ariaDescribedbyData: [{ type: HostBinding, args: ['attr.aria-describedby',] }],
557
+ ariaLabelledbyData: [{ type: HostBinding, args: ['attr.aria-labelledby',] }],
558
+ ariaHiddenData: [{ type: HostBinding, args: ['attr.aria-hidden',] }],
559
+ ariaDisabledData: [{ type: HostBinding, args: ['attr.aria-disabled',] }],
560
+ ariaControlsData: [{ type: HostBinding, args: ['attr.aria-controls',] }],
561
+ ariaCurrentData: [{ type: HostBinding, args: ['attr.aria-current',] }],
562
+ ariaLiveData: [{ type: HostBinding, args: ['attr.aria-live',] }],
563
+ ariaExpandedData: [{ type: HostBinding, args: ['attr.aria-expanded',] }],
564
+ ariaErrormessageData: [{ type: HostBinding, args: ['attr.aria-errormessage',] }],
565
+ ariaHaspopupData: [{ type: HostBinding, args: ['attr.aria-haspopup',] }],
566
+ ariaModalData: [{ type: HostBinding, args: ['attr.aria-modal',] }]
567
+ };
568
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-navigation.component.js","sourceRoot":"","sources":["../../../../../../../projects/desy-angular/src/lib/desy-nav/components/menu-navigation/menu-navigation.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, \r\n  ChangeDetectorRef, \r\n  Component, \r\n  ContentChildren, \r\n  ElementRef, \r\n  EventEmitter, \r\n  HostBinding, \r\n  Input, \r\n  OnChanges, \r\n  Output, \r\n  QueryList, \r\n  SimpleChanges,\r\n  ViewChild, \r\n  ViewChildren } from '@angular/core';\r\nimport { AccessibilityComponent } from '../../../shared/components';\r\nimport { MenuNavigationItemSubItem, MenuNavigationItemSubItemSubItem } from '../../interfaces';\r\nimport { MenuNavigationItem } from '../../interfaces/menu-navigation';\r\nimport { MenubaritemDirective } from '../menubar/directives/menubaritem.directive';\r\nimport { MenuNavigationItemComponent } from './components/menu-navigation-item/menu-navigation-item.component';\r\nimport { MenuNavigationSubitemComponent } from './components/menu-navigation-subitem/menu-navigation-subitem.component';\r\n\r\n@Component({\r\n  selector: 'desy-menu-navigation',\r\n  templateUrl: './menu-navigation.component.html'\r\n})\r\nexport class MenuNavigationComponent extends AccessibilityComponent implements OnChanges, AfterViewInit{\r\n\r\n  @Input() idPrefix: string;\r\n  @Input() items: MenuNavigationItem[];\r\n  @Output() itemsChange = new EventEmitter<MenuNavigationItem[]>();\r\n  @Output() activeItemChange = new EventEmitter<MenuNavigationItem>();\r\n  @Output() activeSubItemChange = new EventEmitter<MenuNavigationItemSubItem | MenuNavigationItemSubItemSubItem>();\r\n\r\n  @ViewChild('menunavigation', { read: ElementRef }) menunavigation: ElementRef;\r\n  @ViewChildren(MenubaritemDirective) menuItems: QueryList<MenubaritemDirective>;\r\n  @ContentChildren(MenuNavigationItemComponent) itemComponentList: QueryList<MenuNavigationItemComponent>;\r\n\r\n  @Input() @HostBinding('class') classes: any;\r\n  @HostBinding('class.c-menu-navigation') cfg = true\r\n  @Input() @HostBinding('attr.id') id: any;\r\n\r\n  @HostBinding('attr.role') roleData: any;\r\n  @HostBinding('attr.aria-label') ariaLabelData: any;\r\n  @HostBinding('attr.aria-describedby') ariaDescribedbyData: any;\r\n  @HostBinding('attr.aria-labelledby') ariaLabelledbyData: any;\r\n  @HostBinding('attr.aria-hidden') ariaHiddenData: any;\r\n  @HostBinding('attr.aria-disabled') ariaDisabledData: any;\r\n  @HostBinding('attr.aria-controls') ariaControlsData: any;\r\n  @HostBinding('attr.aria-current') ariaCurrentData: any;\r\n  @HostBinding('attr.aria-live') ariaLiveData: any;\r\n  @HostBinding('attr.aria-expanded') ariaExpandedData: any;\r\n  @HostBinding('attr.aria-errormessage') ariaErrormessageData: any;\r\n  @HostBinding('attr.aria-haspopup') ariaHaspopupData: any;\r\n  @HostBinding('attr.aria-modal') ariaModalData: any;\r\n\r\n  menuData: any[];\r\n  viewInit = false;\r\n  isFocused: boolean;\r\n  currentFocusItemIndex = 0;\r\n\r\n  constructor(private changeDetectorRef: ChangeDetectorRef) {\r\n    super();\r\n  }\r\n\r\n  ngOnChanges(changes?: SimpleChanges): void {\r\n    this.roleData = this.role ? this.role : null;\r\n    this.ariaLabelData = this.ariaLabel ? this.ariaLabel : null;\r\n    this.ariaDescribedbyData = this.ariaDescribedBy ? this.ariaDescribedBy : null;\r\n    this.ariaLabelledbyData = this.ariaLabelledBy ? this.ariaLabelledBy : null;\r\n    this.ariaHiddenData = this.ariaHidden ? this.ariaHidden : null;\r\n    this.ariaDisabledData = this.ariaDisabled ? this.ariaDisabled : null;\r\n    this.ariaControlsData = this.ariaControls ? this.ariaControls : null;\r\n    this.ariaCurrentData = this.ariaCurrent ? this.ariaCurrent : null;\r\n    this.ariaLiveData = this.ariaLive ? this.ariaLive : null;\r\n    this.ariaExpandedData = this.ariaExpanded ? this.ariaExpanded : null;\r\n    this.ariaErrormessageData = this.ariaErrorMessage ? this.ariaErrorMessage : null;\r\n    this.ariaHaspopupData = this.ariaHasPopup ? this.ariaHasPopup : null;\r\n    this.ariaModalData = this.ariaModal ? this.ariaModal : null;\r\n    if (this.viewInit) {\r\n      this.checkChanges();\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.viewInit = true;\r\n    this.checkChanges();\r\n  }\r\n\r\n  checkChanges(): void {\r\n    if (!this.menuItems) {\r\n      return;\r\n    }\r\n    \r\n    this.menuData = [];\r\n    this.getItems().forEach((_, index) => {\r\n      const itemData = {\r\n        open: false,\r\n        currentFocusSubItemIndex: 0,\r\n        currentFocusSubSubItemIndex: 0,\r\n        menuItem: this.menuItems.toArray()[index]\r\n      };\r\n      this.menuData.push(itemData);\r\n    });\r\n\r\n    if (this.viewInit) {\r\n      this.checkRequired();\r\n    }\r\n\r\n\r\n    const lastCurrentFocusItemIndex = this.currentFocusItemIndex;\r\n    const items = this.getItems();\r\n    if (items) {\r\n      while (!this.isItemFocusable(this.currentFocusItemIndex % items.length)) {\r\n        this.currentFocusItemIndex = (this.currentFocusItemIndex + items.length + 1) % items.length;\r\n        if (this.currentFocusItemIndex === lastCurrentFocusItemIndex) {\r\n          break;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  /*\r\n   * Eventos\r\n   */\r\n\r\n  handleMenuFocusIn(): void {\r\n    this.isFocused = true;\r\n    this.changeDetectorRef.detectChanges();\r\n  }\r\n\r\n  handleMenuFocusOut(event): void {\r\n    if (!this.menunavigation.nativeElement.contains(event.relatedTarget)) {\r\n      this.closeMenu();\r\n    }\r\n    this.isFocused = false;\r\n    this.changeDetectorRef.detectChanges();\r\n  }\r\n\r\n  handleMenuItemClick(event, itemIndex: number): void {\r\n    if (this.hasPopupMenu(itemIndex)) {\r\n      event.preventDefault();\r\n      const isOpen = this.menuData[itemIndex].open;\r\n      this.closeMenu();\r\n      if (!isOpen) {\r\n        this.openMenu(itemIndex);\r\n      }\r\n    } else {\r\n      this.activateMenuItem(itemIndex);\r\n    }\r\n  }\r\n\r\n  handleMenuItemKeydown(event: KeyboardEvent, itemIndex: number): void {\r\n    switch (event.key) {\r\n      case 'Enter':\r\n      case ' ':\r\n      case 'ArrowDown':\r\n        if (this.hasPopupMenu(itemIndex)) {\r\n          this.openMenu(itemIndex);\r\n          setTimeout(() => this.focusFirstSubItem(itemIndex));\r\n          event.stopPropagation();\r\n          event.preventDefault();\r\n        }\r\n        break;\r\n\r\n      case 'Escape':\r\n        if (this.hasPopupMenu(itemIndex)) {\r\n          this.closeMenu(itemIndex);\r\n        }\r\n        event.stopPropagation();\r\n        event.preventDefault();\r\n        break;\r\n\r\n      case 'ArrowLeft':\r\n        this.focusNextAvailableItem(itemIndex, -1);\r\n        event.stopPropagation();\r\n        event.preventDefault();\r\n        break;\r\n\r\n      case 'ArrowRight':\r\n        this.focusNextAvailableItem(itemIndex, +1);\r\n        event.stopPropagation();\r\n        event.preventDefault();\r\n        break;\r\n\r\n      case 'ArrowUp':\r\n        if (this.hasPopupMenu(itemIndex)) {\r\n          this.openMenu(itemIndex);\r\n          setTimeout(() => this.focusLastSubItem(itemIndex));\r\n        }\r\n        event.stopPropagation();\r\n        event.preventDefault();\r\n        break;\r\n\r\n      case 'Home':\r\n      case 'PageUp':\r\n        if (this.hasPopupMenu(itemIndex)) {\r\n          this.closeMenu();\r\n        }\r\n        this.focusFirstItem();\r\n        event.stopPropagation();\r\n        event.preventDefault();\r\n        break;\r\n\r\n      case 'End':\r\n      case 'PageDown':\r\n        if (this.hasPopupMenu(itemIndex)) {\r\n          this.closeMenu();\r\n        }\r\n        this.focusLastItem();\r\n        event.stopPropagation();\r\n        event.preventDefault();\r\n        break;\r\n\r\n      default:\r\n        if (this.isPrintableChar(event.key)) {\r\n          this.focusItemByFirstChar(event.key);\r\n          event.stopPropagation();\r\n          event.preventDefault();\r\n        }\r\n        break;\r\n    }\r\n  }\r\n\r\n  handleMenuItemMouseOver(itemIndex: number): void {\r\n    this.focusItem(itemIndex, true);\r\n  }\r\n\r\n  handlePopupMenuItemClick(itemIndex: number, subItemIndex: number, subSubItemIndex?: number): void {\r\n    this.activatePopupMenuItem(itemIndex, subItemIndex, subSubItemIndex);\r\n    this.focusItem(itemIndex);\r\n    this.closeMenu(itemIndex);\r\n  }\r\n\r\n  handlePopupMenuItemKeydown(event: KeyboardEvent, itemIndex: number, subItemIndex: number, subSubItemIndex?: number): void {\r\n    const currentSubIndex = this.menuData[itemIndex].currentFocusSubItemIndex;\r\n    const currentSubSubIndex = this.menuData[itemIndex].currentFocusSubSubItemIndex;\r\n    const items = this.getItems();\r\n    switch (event.key) {\r\n      case ' ':\r\n        this.activatePopupMenuItem(itemIndex, subItemIndex, subSubItemIndex);\r\n        if (this.mustCloseAfterSelectPopupItem(itemIndex, subItemIndex, subSubItemIndex)) {\r\n          this.closeMenu(itemIndex);\r\n          this.focusItem(itemIndex);\r\n        }\r\n        event.stopPropagation();\r\n        event.preventDefault();\r\n        break;\r\n\r\n      case 'Enter':\r\n        this.activatePopupMenuItem(itemIndex, subItemIndex, subSubItemIndex);\r\n        this.closeMenu(itemIndex);\r\n        this.focusItem(itemIndex);\r\n        event.stopPropagation();\r\n        event.preventDefault();\r\n        break;\r\n\r\n      case 'Escape':\r\n        this.closeMenu(itemIndex);\r\n        this.focusItem(itemIndex);\r\n        event.stopPropagation();\r\n        event.preventDefault();\r\n        break;\r\n\r\n      case 'ArrowUp':\r\n        this.focusNextAvailableSubItem(itemIndex, currentSubIndex, currentSubSubIndex, -1);\r\n        // this.focusSubItem(itemIndex, (currentSubIndex + listLength - 1) % listLength);\r\n        event.stopPropagation();\r\n        event.preventDefault();\r\n        break;\r\n\r\n      case 'ArrowDown':\r\n        this.focusNextAvailableSubItem(itemIndex, currentSubIndex, currentSubSubIndex, +1);\r\n        // this.focusSubItem(itemIndex, (currentSubIndex + listLength + 1) % listLength);\r\n        event.stopPropagation();\r\n        event.preventDefault();\r\n        break;\r\n\r\n      case 'ArrowLeft':\r\n        this.closeMenu(itemIndex);\r\n        this.focusItem((itemIndex + items.length - 1) % items.length);\r\n        event.stopPropagation();\r\n        event.preventDefault();\r\n        break;\r\n\r\n      case 'ArrowRight':\r\n        this.closeMenu(itemIndex);\r\n        this.focusItem((itemIndex + items.length + 1) % items.length);\r\n        event.stopPropagation();\r\n        event.preventDefault();\r\n        break;\r\n\r\n      case 'Home':\r\n      case 'PageUp':\r\n        this.focusFirstSubItem(itemIndex);\r\n        event.stopPropagation();\r\n        event.preventDefault();\r\n        break;\r\n\r\n      case 'End':\r\n      case 'PageDown':\r\n        this.focusLastSubItem(itemIndex);\r\n        event.stopPropagation();\r\n        event.preventDefault();\r\n        break;\r\n\r\n      case 'Tab':\r\n        this.closeMenu(itemIndex);\r\n        this.focusItem(itemIndex);\r\n        break;\r\n\r\n      default:\r\n        if (this.isPrintableChar(event.key)) {\r\n          this.focusSubItemByFirstChar(itemIndex, event.key);\r\n          event.stopPropagation();\r\n          event.preventDefault();\r\n        }\r\n        break;\r\n    }\r\n  }\r\n\r\n  handlePopupMenuItemMouseOver(itemIndex: number, subItemIndex: number, subSubItemIndex?: number): void {\r\n    this.focusSubItem(itemIndex, subItemIndex, subSubItemIndex);\r\n  }\r\n\r\n  /*\r\n   * Comunes\r\n   */\r\n\r\n  checkRequired(): void {\r\n    const items = this.getItems();\r\n  }\r\n\r\n\r\n  activateMenuItem(itemIndex: number): void {\r\n    const items = this.getItems();\r\n    this.activeItemChange.emit(items[itemIndex] as MenuNavigationItem);\r\n    if (items[itemIndex] instanceof MenuNavigationItemComponent) {\r\n      (items[itemIndex] as MenuNavigationItemComponent).selected.emit();\r\n    }\r\n  }\r\n\r\n  activatePopupMenuItem(itemIndex: number, subItemIndex: number, subSubItemIndex?: number): void {\r\n    const items = this.getItems();\r\n    const subItems = this.getItemSubitems(items[itemIndex]);\r\n    let item: MenuNavigationItemSubItem|MenuNavigationItemSubItemSubItem = subItems[subItemIndex];        \r\n\r\n    this.itemsChange.emit(items);\r\n    this.activeSubItemChange.emit(item as MenuNavigationItem);\r\n    if (item instanceof MenuNavigationSubitemComponent) {\r\n      item.selected.emit();\r\n    }\r\n  }\r\n\r\n  mustCloseAfterSelectPopupItem(itemIndex: number, subItemIndex: number, subSubItemIndex?: number): boolean {\r\n    const items = this.getItems();\r\n    const subItems = this.getItemSubitems(items[itemIndex]);\r\n    let item: MenuNavigationItemSubItem|MenuNavigationItemSubItemSubItem = subItems[subItemIndex];\r\n\r\n    return item.role !== 'menuitemcheckbox' && item.role !== 'menuitemradio';\r\n  }\r\n\r\n  openMenu(itemIndex: number): void {\r\n    const wasOpened = this.menuData[itemIndex].open;\r\n    this.menuData[itemIndex].open = true;\r\n    if (wasOpened) {\r\n      this.activateMenuItem(itemIndex);\r\n    }\r\n  }\r\n\r\n  closeMenu(itemIndex?: number): void {\r\n    if (itemIndex !== null && itemIndex !== undefined) {\r\n      this.menuData[itemIndex].open = false;\r\n    } else {\r\n      this.menuData.forEach(item => item.open = false);\r\n    }\r\n  }\r\n\r\n  hasPopupMenu(itemIndex: number): boolean {\r\n    const items = this.getItems();\r\n    const subItems = this.getItemSubitems(items[itemIndex]);\r\n    return items[itemIndex].sub && subItems && subItems.length > 0;\r\n  }\r\n\r\n  private isPrintableChar(str: string): boolean {\r\n    return str.length === 1 && !!str.match(/\\S/);\r\n  }\r\n\r\n  \r\n\r\n  /*\r\n   * Comunes - focus\r\n   */\r\n\r\n  focusItem(itemIndex: number, hover?: boolean): void {\r\n    const hasFocus = this.menunavigation.nativeElement.contains(document.activeElement);\r\n    const isOpen = this.menuData[this.currentFocusItemIndex].open;\r\n\r\n    if (!hover || hasFocus) {\r\n      this.menuData[itemIndex].menuItem.link.nativeElement.focus();\r\n    }\r\n\r\n    this.closeMenu();\r\n    if (isOpen && this.hasPopupMenu(itemIndex)) {\r\n      this.openMenu(itemIndex);\r\n    }\r\n\r\n    this.currentFocusItemIndex = itemIndex;\r\n  }\r\n\r\n  focusNextAvailableItem(fromItemIndex: number, step: number): void {\r\n    let nextItem = fromItemIndex;\r\n    const items = this.getItems();\r\n    do {\r\n      nextItem = (nextItem + items.length + step) % items.length;\r\n    } while (!this.isItemFocusable(nextItem) && nextItem !== fromItemIndex);\r\n\r\n    if (nextItem !== fromItemIndex) {\r\n      this.focusItem(nextItem);\r\n    }\r\n  }\r\n\r\n  focusFirstItem(): void {\r\n    if (this.isItemFocusable(0)) {\r\n      this.focusItem(0);\r\n    } else {\r\n      this.focusNextAvailableItem(0, +1);\r\n    }\r\n  }\r\n\r\n  focusLastItem(): void {\r\n    const items = this.getItems();\r\n    if (this.isItemFocusable(items.length - 1)) {\r\n      this.focusItem(items.length - 1);\r\n    } else {\r\n      this.focusNextAvailableItem(items.length - 1, -1);\r\n    }\r\n  }\r\n\r\n  isItemFocusable(itemIndex: number): boolean {\r\n    return !this.getItems()[itemIndex].disabled;\r\n  }\r\n\r\n  focusItemByFirstChar(char: string): void {\r\n    const itemContents: string[] = this.menuItems.map(menuItem => menuItem.itemContentWrapper.nativeElement.textContent);\r\n    let index = this.currentFocusItemIndex;\r\n    let foundIndex = -1;\r\n    do {\r\n      index = (index + itemContents.length + 1) % itemContents.length;\r\n      if (itemContents[index] && itemContents[index].trim().substr(0, 1).toLowerCase() === char.toLowerCase()\r\n          && this.isItemFocusable(index)) {\r\n        foundIndex = index;\r\n      }\r\n    } while (foundIndex === -1 && index !== this.currentFocusItemIndex);\r\n\r\n    if (foundIndex >= 0) {\r\n      this.focusItem(foundIndex);\r\n    }\r\n  }\r\n\r\n  focusSubItem(itemIndex: number, subItemIndex: number, subSubItemIndex?: number): void {\r\n    if (this.menuData[itemIndex].menuItem.popupMenuItems.length > 0) {\r\n      const menuDataIndex = subItemIndex;\r\n      this.menuData[itemIndex].currentFocusSubItemIndex = subItemIndex;\r\n      this.menuData[itemIndex].currentFocusSubSubItemIndex = subSubItemIndex;\r\n      const elem = this.menuData[itemIndex].menuItem.popupMenuItems.toArray()[menuDataIndex].nativeElement;\r\n      if (elem) {\r\n        elem.focus();\r\n      } else {\r\n        console.error('No subitem to focus');\r\n      }\r\n    } else {\r\n      console.error('No subitems');\r\n    }\r\n  }\r\n\r\n  focusNextAvailableSubItem(itemIndex: number, fromItemSubIndex: number, fromItemSubSubIndex: number, step: number): void {\r\n    let nextSubIndex = fromItemSubIndex;\r\n    let nextSubSubIndex = fromItemSubSubIndex;\r\n    let allSubItemsChecked;\r\n    const items = this.getItems();\r\n    do {\r\n      const nextIndexes = this.getNextSubItemIndexes(items, itemIndex, nextSubIndex, nextSubSubIndex, step);\r\n      nextSubIndex = nextIndexes.subIndex;\r\n      nextSubSubIndex = nextIndexes.subSubIndex;\r\n      allSubItemsChecked = (fromItemSubIndex === nextSubIndex && fromItemSubSubIndex === nextSubSubIndex);\r\n    } while (!this.isSubItemFocusable(itemIndex, nextSubIndex, nextSubSubIndex) && !allSubItemsChecked);\r\n\r\n    if (!allSubItemsChecked) {\r\n      this.focusSubItem(itemIndex, nextSubIndex, nextSubSubIndex);\r\n    }\r\n  }\r\n\r\n  focusFirstSubItem(itemIndex: number): void {\r\n    let firstSubSubItem = null;\r\n    const items = this.getItems();\r\n    const subItems = this.getItemSubitems(items[itemIndex]);\r\n    if (subItems && subItems.length > 0) {\r\n      firstSubSubItem = 0;\r\n    }\r\n\r\n    if (this.isSubItemFocusable(itemIndex, 0, firstSubSubItem)) {\r\n      this.focusSubItem(itemIndex, 0, firstSubSubItem);\r\n    } else {\r\n      this.focusNextAvailableSubItem(itemIndex, 0, firstSubSubItem, +1);\r\n    }\r\n  }\r\n\r\n  focusLastSubItem(itemIndex: number): void {\r\n    const items = this.getItems();\r\n    const subItems = this.getItemSubitems(items[itemIndex]);\r\n    const lastItemIndex = subItems.length - 1;\r\n    const lastItem = subItems[lastItemIndex];\r\n    let lastSubSubItem = null;\r\n\r\n    if (this.isSubItemFocusable(itemIndex, lastItemIndex, lastSubSubItem)) {\r\n      this.focusSubItem(itemIndex, lastItemIndex, lastSubSubItem);\r\n    } else {\r\n      this.focusNextAvailableSubItem(itemIndex, lastItemIndex, lastSubSubItem, -1);\r\n    }\r\n  }\r\n\r\n  isSubItemFocusable(itemIndex: number, subItemIndex: number, subSubItemIndex?: number): boolean {\r\n    const items = this.getItems();\r\n    const subItems = this.getItemSubitems(items[itemIndex]);\r\n    let item: MenuNavigationItemSubItem|MenuNavigationItemSubItemSubItem = subItems[subItemIndex];\r\n\r\n    let isFocusable = false;\r\n    if (item.role !== 'separator' && item.role !== 'none') {\r\n      isFocusable = true;\r\n    }\r\n    return isFocusable;\r\n  }\r\n\r\n  focusSubItemByFirstChar(itemIndex: number, char: string): void {\r\n    const itemContents: string[] = this.menuItems.toArray()[itemIndex].popupMenuItems.map(menuItem => menuItem.nativeElement.textContent);\r\n    let subItemIndex = this.menuData[itemIndex].currentFocusSubItemIndex;\r\n    let subSubItemIndex = this.menuData[itemIndex].currentFocusSubSubItemIndex;\r\n    let foundSubIndex = -1;\r\n    let foundSubSubIndex = null;\r\n    let allSubItemsChecked = false;\r\n    const items = this.getItems();\r\n    do {\r\n      const nextIndexes = this.getNextSubItemIndexes(items, itemIndex, subItemIndex, subSubItemIndex, +1);\r\n      subItemIndex = nextIndexes.subIndex;\r\n      subSubItemIndex = nextIndexes.subSubIndex;\r\n      const index = subItemIndex;\r\n      if (itemContents[index] && itemContents[index].trim().substr(0, 1).toLowerCase() === char.toLowerCase()\r\n          && this.isSubItemFocusable(itemIndex, subItemIndex, subSubItemIndex)) {\r\n        foundSubIndex = subItemIndex;\r\n        foundSubSubIndex = subSubItemIndex;\r\n      }\r\n      allSubItemsChecked = (this.menuData[itemIndex].currentFocusSubItemIndex === subItemIndex\r\n        && this.menuData[itemIndex].currentFocusSubSubItemIndex === subSubItemIndex);\r\n    } while (foundSubIndex === -1 && !allSubItemsChecked);\r\n\r\n    if (foundSubIndex >= 0) {\r\n      this.focusSubItem(itemIndex, foundSubIndex, foundSubSubIndex);\r\n    }\r\n  }\r\n\r\n  /*\r\n   * Metodos para facilitar contenido\r\n   */\r\n\r\n  getItems(): MenuNavigationItem[]|MenuNavigationItemComponent[] {\r\n    let items;\r\n    if (this.itemComponentList && this.itemComponentList.length > 0) {\r\n      items = this.itemComponentList.toArray();\r\n    } else {\r\n      items = this.items;\r\n    }\r\n    return items;\r\n  }\r\n\r\n  getItemSubitems(item: MenuNavigationItem|MenuNavigationItemComponent): MenuNavigationItemSubItem[]|MenuNavigationSubitemComponent[] {\r\n    let subItems = [];\r\n    if (item instanceof MenuNavigationItemComponent){\r\n      subItems = item.getSubItems();\r\n    }\r\n\r\n    if (!subItems || subItems.length === 0) {\r\n      subItems = item.sub ? item.sub.items : [];\r\n    }\r\n    return subItems;\r\n  }\r\n\r\n  getNextSubItemIndexes(items, itemIndex, nextSubIndex, nextSubSubIndex, step): { subIndex: number, subSubIndex?: number} {\r\n    const subItems = this.getItemSubitems(items[itemIndex]);\r\n\r\n    let checkNextSubItem = true;\r\n    if (checkNextSubItem) {\r\n      nextSubIndex = (nextSubIndex + step + subItems.length) % subItems.length;\r\n    }  \r\n    return {subIndex: nextSubIndex, subSubIndex: nextSubSubIndex};\r\n  }\r\n\r\n  getIdPrefix(): string {\r\n    return this.idPrefix ? this.idPrefix : this.id + 'menunavigation-item';\r\n  }\r\n\r\n  getItemId(item, index: number): string {\r\n    let id: string;\r\n    if (item) {\r\n      if (item.id) {\r\n        id = item.id;\r\n      } else {\r\n        id = index === 0 ? this.getIdPrefix() : `${this.getIdPrefix()}-${index}`;\r\n      }\r\n    }\r\n    return id;\r\n  }\r\n\r\n  getPopupStyle(itemIndex: number): object {\r\n    let style = {};\r\n    if (this.menuData && itemIndex < this.menuData.length) {\r\n      const menuItem = this.menuData[itemIndex].menuItem;\r\n      const rect = menuItem.link.nativeElement.getBoundingClientRect();\r\n      if (this.menuData[itemIndex].open) {\r\n        style = {\r\n          position: 'absolute',\r\n          top: '0px',\r\n          left: '0px',\r\n          zIndex: 100,\r\n          display: 'block'\r\n        };\r\n      } else {\r\n        style = {\r\n          zIndex: 0,\r\n          display: 'none'\r\n        };\r\n      }\r\n    }\r\n\r\n    return style;\r\n  }\r\n\r\n  getSubItemId(item, index: number, parentId: string): string {\r\n    let id: string;\r\n    if (item) {\r\n      if (item.id) {\r\n        id = item.id;\r\n      } else {\r\n        id = index === 0 ? `sub-${parentId}` : `sub-${parentId}-${index}`;\r\n      }\r\n    }\r\n    return id;\r\n  }\r\n  \r\n}\r\n"]}