@kirbydesign/designsystem 8.2.0-rc.2 → 8.3.0

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 (193) hide show
  1. package/README.md +7 -0
  2. package/action-group/action-group.component.d.ts +10 -6
  3. package/button/button.component.d.ts +2 -1
  4. package/button/public_api.d.ts +1 -1
  5. package/dropdown/keyboard-handler.service.d.ts +1 -1
  6. package/esm2020/action-group/action-group.component.mjs +25 -29
  7. package/esm2020/button/button.component.mjs +3 -3
  8. package/esm2020/button/public_api.mjs +2 -2
  9. package/esm2020/card/card.component.mjs +2 -2
  10. package/esm2020/dropdown/dropdown.component.mjs +4 -4
  11. package/esm2020/dropdown/dropdown.module.mjs +1 -1
  12. package/esm2020/dropdown/keyboard-handler.service.mjs +12 -7
  13. package/esm2020/header/header.component.mjs +12 -26
  14. package/esm2020/header/public_api.mjs +2 -2
  15. package/esm2020/item/item.component.mjs +2 -2
  16. package/esm2020/lib/index.mjs +3 -1
  17. package/esm2020/lib/kirby.module.mjs +22 -5
  18. package/esm2020/list/list-item/list-item.component.mjs +2 -2
  19. package/esm2020/list/list.component.mjs +2 -2
  20. package/esm2020/menu/kirbydesign-designsystem-menu.mjs +5 -0
  21. package/esm2020/menu/menu.component.mjs +69 -0
  22. package/esm2020/menu/public_api.mjs +2 -0
  23. package/esm2020/modal/modal/footer/modal-footer.component.mjs +3 -3
  24. package/esm2020/modal/v2/footer/footer.component.mjs +2 -2
  25. package/esm2020/modal/v2/modal-routing/modal-routing.component.mjs +3 -3
  26. package/esm2020/page/page-footer/page-footer.component.mjs +2 -2
  27. package/esm2020/page/page.component.mjs +37 -30
  28. package/esm2020/page/public_api.mjs +2 -12
  29. package/esm2020/shared/floating/floating.directive.mjs +91 -24
  30. package/esm2020/shared/floating/public_api.mjs +2 -2
  31. package/esm2020/tab-navigation/kirbydesign-designsystem-tab-navigation.mjs +5 -0
  32. package/esm2020/tab-navigation/public_api.mjs +4 -0
  33. package/esm2020/tab-navigation/tab-navigation/tab-navigation.component.mjs +121 -0
  34. package/esm2020/tab-navigation/tab-navigation-item/tab-navigation-item.component.mjs +17 -0
  35. package/esm2020/tab-navigation/tab-navigation.module.mjs +19 -0
  36. package/fesm2015/kirbydesign-designsystem-accordion.mjs +0 -1
  37. package/fesm2015/kirbydesign-designsystem-action-group.mjs +25 -30
  38. package/fesm2015/kirbydesign-designsystem-action-group.mjs.map +1 -1
  39. package/fesm2015/kirbydesign-designsystem-alert-experimental.mjs +0 -1
  40. package/fesm2015/kirbydesign-designsystem-avatar.mjs +0 -1
  41. package/fesm2015/kirbydesign-designsystem-button.mjs +2 -3
  42. package/fesm2015/kirbydesign-designsystem-button.mjs.map +1 -1
  43. package/fesm2015/kirbydesign-designsystem-calendar.mjs +0 -1
  44. package/fesm2015/kirbydesign-designsystem-card.mjs +2 -3
  45. package/fesm2015/kirbydesign-designsystem-card.mjs.map +1 -1
  46. package/fesm2015/kirbydesign-designsystem-chart.mjs +0 -1
  47. package/fesm2015/kirbydesign-designsystem-checkbox.mjs +0 -1
  48. package/fesm2015/kirbydesign-designsystem-data-table.mjs +0 -1
  49. package/fesm2015/kirbydesign-designsystem-divider.mjs +0 -1
  50. package/fesm2015/kirbydesign-designsystem-dropdown.mjs +15 -11
  51. package/fesm2015/kirbydesign-designsystem-dropdown.mjs.map +1 -1
  52. package/fesm2015/kirbydesign-designsystem-empty-state.mjs +0 -1
  53. package/fesm2015/kirbydesign-designsystem-fab-sheet.mjs +0 -1
  54. package/fesm2015/kirbydesign-designsystem-flag.mjs +0 -1
  55. package/fesm2015/kirbydesign-designsystem-form-field.mjs +0 -1
  56. package/fesm2015/kirbydesign-designsystem-grid.mjs +0 -1
  57. package/fesm2015/kirbydesign-designsystem-header.mjs +12 -29
  58. package/fesm2015/kirbydesign-designsystem-header.mjs.map +1 -1
  59. package/fesm2015/kirbydesign-designsystem-helpers-scss.mjs +0 -1
  60. package/fesm2015/kirbydesign-designsystem-helpers.mjs +0 -1
  61. package/fesm2015/kirbydesign-designsystem-icon.mjs +0 -1
  62. package/fesm2015/kirbydesign-designsystem-item-group.mjs +0 -1
  63. package/fesm2015/kirbydesign-designsystem-item-sliding.mjs +0 -1
  64. package/fesm2015/kirbydesign-designsystem-item.mjs +2 -3
  65. package/fesm2015/kirbydesign-designsystem-item.mjs.map +1 -1
  66. package/fesm2015/kirbydesign-designsystem-kirby-app.mjs +0 -1
  67. package/fesm2015/kirbydesign-designsystem-kirby-ionic-module.mjs +0 -1
  68. package/fesm2015/kirbydesign-designsystem-list.mjs +4 -5
  69. package/fesm2015/kirbydesign-designsystem-list.mjs.map +1 -1
  70. package/fesm2015/kirbydesign-designsystem-loading-overlay.mjs +0 -1
  71. package/fesm2015/kirbydesign-designsystem-menu.mjs +76 -0
  72. package/fesm2015/kirbydesign-designsystem-menu.mjs.map +1 -0
  73. package/fesm2015/kirbydesign-designsystem-modal-v2.mjs +4 -5
  74. package/fesm2015/kirbydesign-designsystem-modal-v2.mjs.map +1 -1
  75. package/fesm2015/kirbydesign-designsystem-modal.mjs +2 -3
  76. package/fesm2015/kirbydesign-designsystem-modal.mjs.map +1 -1
  77. package/fesm2015/kirbydesign-designsystem-page.mjs +38 -32
  78. package/fesm2015/kirbydesign-designsystem-page.mjs.map +1 -1
  79. package/fesm2015/kirbydesign-designsystem-popover.mjs +0 -1
  80. package/fesm2015/kirbydesign-designsystem-progress-circle.mjs +0 -1
  81. package/fesm2015/kirbydesign-designsystem-radio.mjs +0 -1
  82. package/fesm2015/kirbydesign-designsystem-range.mjs +0 -1
  83. package/fesm2015/kirbydesign-designsystem-reorder-list.mjs +0 -1
  84. package/fesm2015/kirbydesign-designsystem-router-outlet.mjs +0 -1
  85. package/fesm2015/kirbydesign-designsystem-section-header.mjs +0 -1
  86. package/fesm2015/kirbydesign-designsystem-shared-floating.mjs +92 -25
  87. package/fesm2015/kirbydesign-designsystem-shared-floating.mjs.map +1 -1
  88. package/fesm2015/kirbydesign-designsystem-shared-portal.mjs +0 -1
  89. package/fesm2015/kirbydesign-designsystem-shared.mjs +0 -1
  90. package/fesm2015/kirbydesign-designsystem-slide-button.mjs +0 -1
  91. package/fesm2015/kirbydesign-designsystem-slide.mjs +0 -1
  92. package/fesm2015/kirbydesign-designsystem-spinner.mjs +0 -1
  93. package/fesm2015/kirbydesign-designsystem-tab-navigation.mjs +156 -0
  94. package/fesm2015/kirbydesign-designsystem-tab-navigation.mjs.map +1 -0
  95. package/fesm2015/kirbydesign-designsystem-tabs.mjs +0 -1
  96. package/fesm2015/kirbydesign-designsystem-testing-base.mjs +0 -1
  97. package/fesm2015/kirbydesign-designsystem-testing-jasmine.mjs +0 -1
  98. package/fesm2015/kirbydesign-designsystem-testing-jest.mjs +0 -1
  99. package/fesm2015/kirbydesign-designsystem-testing.mjs +0 -1
  100. package/fesm2015/kirbydesign-designsystem-toast.mjs +0 -1
  101. package/fesm2015/kirbydesign-designsystem-toggle-button.mjs +0 -1
  102. package/fesm2015/kirbydesign-designsystem-toggle.mjs +0 -1
  103. package/fesm2015/kirbydesign-designsystem-types.mjs +0 -1
  104. package/fesm2015/kirbydesign-designsystem.mjs +23 -5
  105. package/fesm2015/kirbydesign-designsystem.mjs.map +1 -1
  106. package/fesm2020/kirbydesign-designsystem-accordion.mjs +0 -1
  107. package/fesm2020/kirbydesign-designsystem-action-group.mjs +25 -30
  108. package/fesm2020/kirbydesign-designsystem-action-group.mjs.map +1 -1
  109. package/fesm2020/kirbydesign-designsystem-alert-experimental.mjs +0 -1
  110. package/fesm2020/kirbydesign-designsystem-avatar.mjs +0 -1
  111. package/fesm2020/kirbydesign-designsystem-button.mjs +2 -3
  112. package/fesm2020/kirbydesign-designsystem-button.mjs.map +1 -1
  113. package/fesm2020/kirbydesign-designsystem-calendar.mjs +0 -1
  114. package/fesm2020/kirbydesign-designsystem-card.mjs +2 -3
  115. package/fesm2020/kirbydesign-designsystem-card.mjs.map +1 -1
  116. package/fesm2020/kirbydesign-designsystem-chart.mjs +0 -1
  117. package/fesm2020/kirbydesign-designsystem-checkbox.mjs +0 -1
  118. package/fesm2020/kirbydesign-designsystem-data-table.mjs +0 -1
  119. package/fesm2020/kirbydesign-designsystem-divider.mjs +0 -1
  120. package/fesm2020/kirbydesign-designsystem-dropdown.mjs +15 -11
  121. package/fesm2020/kirbydesign-designsystem-dropdown.mjs.map +1 -1
  122. package/fesm2020/kirbydesign-designsystem-empty-state.mjs +0 -1
  123. package/fesm2020/kirbydesign-designsystem-fab-sheet.mjs +0 -1
  124. package/fesm2020/kirbydesign-designsystem-flag.mjs +0 -1
  125. package/fesm2020/kirbydesign-designsystem-form-field.mjs +0 -1
  126. package/fesm2020/kirbydesign-designsystem-grid.mjs +0 -1
  127. package/fesm2020/kirbydesign-designsystem-header.mjs +12 -27
  128. package/fesm2020/kirbydesign-designsystem-header.mjs.map +1 -1
  129. package/fesm2020/kirbydesign-designsystem-helpers-scss.mjs +0 -1
  130. package/fesm2020/kirbydesign-designsystem-helpers.mjs +0 -1
  131. package/fesm2020/kirbydesign-designsystem-icon.mjs +0 -1
  132. package/fesm2020/kirbydesign-designsystem-item-group.mjs +0 -1
  133. package/fesm2020/kirbydesign-designsystem-item-sliding.mjs +0 -1
  134. package/fesm2020/kirbydesign-designsystem-item.mjs +2 -3
  135. package/fesm2020/kirbydesign-designsystem-item.mjs.map +1 -1
  136. package/fesm2020/kirbydesign-designsystem-kirby-app.mjs +0 -1
  137. package/fesm2020/kirbydesign-designsystem-kirby-ionic-module.mjs +0 -1
  138. package/fesm2020/kirbydesign-designsystem-list.mjs +4 -5
  139. package/fesm2020/kirbydesign-designsystem-list.mjs.map +1 -1
  140. package/fesm2020/kirbydesign-designsystem-loading-overlay.mjs +0 -1
  141. package/fesm2020/kirbydesign-designsystem-menu.mjs +76 -0
  142. package/fesm2020/kirbydesign-designsystem-menu.mjs.map +1 -0
  143. package/fesm2020/kirbydesign-designsystem-modal-v2.mjs +4 -5
  144. package/fesm2020/kirbydesign-designsystem-modal-v2.mjs.map +1 -1
  145. package/fesm2020/kirbydesign-designsystem-modal.mjs +2 -3
  146. package/fesm2020/kirbydesign-designsystem-modal.mjs.map +1 -1
  147. package/fesm2020/kirbydesign-designsystem-page.mjs +38 -32
  148. package/fesm2020/kirbydesign-designsystem-page.mjs.map +1 -1
  149. package/fesm2020/kirbydesign-designsystem-popover.mjs +0 -1
  150. package/fesm2020/kirbydesign-designsystem-progress-circle.mjs +0 -1
  151. package/fesm2020/kirbydesign-designsystem-radio.mjs +0 -1
  152. package/fesm2020/kirbydesign-designsystem-range.mjs +0 -1
  153. package/fesm2020/kirbydesign-designsystem-reorder-list.mjs +0 -1
  154. package/fesm2020/kirbydesign-designsystem-router-outlet.mjs +0 -1
  155. package/fesm2020/kirbydesign-designsystem-section-header.mjs +0 -1
  156. package/fesm2020/kirbydesign-designsystem-shared-floating.mjs +91 -25
  157. package/fesm2020/kirbydesign-designsystem-shared-floating.mjs.map +1 -1
  158. package/fesm2020/kirbydesign-designsystem-shared-portal.mjs +0 -1
  159. package/fesm2020/kirbydesign-designsystem-shared.mjs +0 -1
  160. package/fesm2020/kirbydesign-designsystem-slide-button.mjs +0 -1
  161. package/fesm2020/kirbydesign-designsystem-slide.mjs +0 -1
  162. package/fesm2020/kirbydesign-designsystem-spinner.mjs +0 -1
  163. package/fesm2020/kirbydesign-designsystem-tab-navigation.mjs +155 -0
  164. package/fesm2020/kirbydesign-designsystem-tab-navigation.mjs.map +1 -0
  165. package/fesm2020/kirbydesign-designsystem-tabs.mjs +0 -1
  166. package/fesm2020/kirbydesign-designsystem-testing-base.mjs +0 -1
  167. package/fesm2020/kirbydesign-designsystem-testing-jasmine.mjs +0 -1
  168. package/fesm2020/kirbydesign-designsystem-testing-jest.mjs +0 -1
  169. package/fesm2020/kirbydesign-designsystem-testing.mjs +0 -1
  170. package/fesm2020/kirbydesign-designsystem-toast.mjs +0 -1
  171. package/fesm2020/kirbydesign-designsystem-toggle-button.mjs +0 -1
  172. package/fesm2020/kirbydesign-designsystem-toggle.mjs +0 -1
  173. package/fesm2020/kirbydesign-designsystem-types.mjs +0 -1
  174. package/fesm2020/kirbydesign-designsystem.mjs +23 -5
  175. package/fesm2020/kirbydesign-designsystem.mjs.map +1 -1
  176. package/header/header.component.d.ts +5 -11
  177. package/header/public_api.d.ts +1 -1
  178. package/lib/index.d.ts +2 -0
  179. package/lib/kirby.module.d.ts +42 -39
  180. package/menu/index.d.ts +5 -0
  181. package/menu/menu.component.d.ts +31 -0
  182. package/menu/public_api.d.ts +1 -0
  183. package/package.json +18 -2
  184. package/page/page.component.d.ts +12 -5
  185. package/page/public_api.d.ts +1 -12
  186. package/shared/floating/floating.directive.d.ts +30 -4
  187. package/shared/floating/public_api.d.ts +1 -1
  188. package/tab-navigation/index.d.ts +5 -0
  189. package/tab-navigation/public_api.d.ts +3 -0
  190. package/tab-navigation/tab-navigation/tab-navigation.component.d.ts +30 -0
  191. package/tab-navigation/tab-navigation-item/tab-navigation-item.component.d.ts +7 -0
  192. package/tab-navigation/tab-navigation.module.d.ts +9 -0
  193. package/icon/src/README.md +0 -16
@@ -11,6 +11,13 @@ export var FloatingOffset;
11
11
  FloatingOffset[FloatingOffset["small"] = 4] = "small";
12
12
  FloatingOffset[FloatingOffset["medium"] = 8] = "medium";
13
13
  })(FloatingOffset || (FloatingOffset = {}));
14
+ export var OutletSelector;
15
+ (function (OutletSelector) {
16
+ OutletSelector["tag"] = "tag";
17
+ OutletSelector["id"] = "id";
18
+ OutletSelector["class"] = "class";
19
+ OutletSelector["name"] = "name";
20
+ })(OutletSelector || (OutletSelector = {}));
14
21
  /**
15
22
  * @summary FloatingDirective is a utility that lets you declarative anchor "popup" containers to another element.
16
23
  *
@@ -55,7 +62,7 @@ export class FloatingDirective {
55
62
  this._strategy = 'absolute';
56
63
  this._triggers = ['click'];
57
64
  this.isShown = false;
58
- this.eventListenerDisposeFns = [];
65
+ this.referenceEventListenerDisposeFns = [];
59
66
  this.triggerEventMap = new Map([
60
67
  ['click', [{ event: 'click', method: this.toggleShow.bind(this) }]],
61
68
  [
@@ -73,12 +80,19 @@ export class FloatingDirective {
73
80
  ],
74
81
  ],
75
82
  ]);
83
+ this.HTMLElements = {
84
+ id: (value) => Array.of(document.getElementById(value)),
85
+ class: (value) => Array.from(document.getElementsByClassName(value)),
86
+ name: (value) => Array.from(document.getElementsByName(value)),
87
+ tag: (value) => Array.from(document.getElementsByTagName(value)),
88
+ default: () => null,
89
+ };
76
90
  }
77
91
  /**
78
92
  * Reference to the element for which the host should anchor to
79
93
  * */
80
94
  set reference(ref) {
81
- this.tearDownEventHandling();
95
+ this.tearDownReferenceElementEventHandling();
82
96
  this._reference = ref;
83
97
  this.setupEventHandling();
84
98
  this.autoUpdatePosition();
@@ -113,7 +127,7 @@ export class FloatingDirective {
113
127
  * */
114
128
  set triggers(eventTriggers) {
115
129
  this._triggers = eventTriggers;
116
- this.tearDownEventHandling();
130
+ this.tearDownReferenceElementEventHandling();
117
131
  this.setupEventHandling();
118
132
  }
119
133
  get triggers() {
@@ -125,22 +139,31 @@ export class FloatingDirective {
125
139
  * This should be used when there's issues with the stacking context, and not as a default option.
126
140
  * */
127
141
  set DOMPortalOutlet(outlet) {
128
- this.portalDirective.outlet = outlet;
142
+ this._providedPortalOutlet = outlet;
143
+ this.portalDirective.outlet =
144
+ this.DOMPortalOutlet ?? this.getOutletElement(this.portalOutletConfig);
145
+ }
146
+ get DOMPortalOutlet() {
147
+ return this._providedPortalOutlet;
148
+ }
149
+ /**
150
+ * Defines how to automatically find and assign DOMPortalOutlet if none is provided in DOMPortalOutlet.
151
+ * If nothing is provided here and in DOMPortalOutlet, the provided strategy is used
152
+ * */
153
+ set portalOutletConfig(config) {
154
+ this._portalOutletConfig = config;
155
+ if (!this.DOMPortalOutlet) {
156
+ this.portalDirective.outlet = this.getOutletElement(config);
157
+ }
158
+ }
159
+ get portalOutletConfig() {
160
+ return this._portalOutletConfig;
129
161
  }
130
162
  onEscapeKeyPressed() {
131
163
  if (this.closeOnEscapeKey) {
132
164
  this.hide();
133
165
  }
134
166
  }
135
- onMouseClick(event) {
136
- const clickedOnHost = this.elementRef.nativeElement.contains(event.target);
137
- if (clickedOnHost) {
138
- this.handleClickInsideHostElement();
139
- }
140
- else {
141
- this.handleClickOutsideHostElement(event);
142
- }
143
- }
144
167
  ngOnInit() {
145
168
  this.addFloatStylingToHostElement();
146
169
  this.updateHostElementPosition();
@@ -150,6 +173,7 @@ export class FloatingDirective {
150
173
  if (this.isDisabled) {
151
174
  return;
152
175
  }
176
+ this.attachDocumentClickEvent();
153
177
  this.renderer.setStyle(this.elementRef.nativeElement, 'display', 'block');
154
178
  this.isShown = true;
155
179
  this.displayChanged.emit(this.isShown);
@@ -159,6 +183,7 @@ export class FloatingDirective {
159
183
  if (this.isDisabled) {
160
184
  return;
161
185
  }
186
+ this.tearDownDocumentClickEventHandling();
162
187
  this.renderer.setStyle(this.elementRef.nativeElement, 'display', 'none');
163
188
  this.isShown = false;
164
189
  this.displayChanged.emit(this.isShown);
@@ -172,11 +197,24 @@ export class FloatingDirective {
172
197
  this.show();
173
198
  }
174
199
  }
200
+ onDocumentClickWhileHostShown(event) {
201
+ const clickedOnHost = this.elementRef.nativeElement.contains(event.target);
202
+ if (clickedOnHost) {
203
+ this.handleClickInsideHostElement();
204
+ }
205
+ else {
206
+ this.handleClickOutsideHostElement(event);
207
+ }
208
+ }
175
209
  addFloatStylingToHostElement() {
176
210
  this.renderer.setStyle(this.elementRef.nativeElement, 'left', `0px`);
177
211
  this.renderer.setStyle(this.elementRef.nativeElement, 'top', `0px`);
178
212
  this.renderer.setStyle(this.elementRef.nativeElement, 'position', this.strategy);
179
213
  this.renderer.setStyle(this.elementRef.nativeElement, 'z-index', DesignTokenHelper.zLayer('popover'));
214
+ this.setDisplayStyling();
215
+ }
216
+ setDisplayStyling() {
217
+ this.renderer.setStyle(this.elementRef.nativeElement, 'display', this.isShown ? `block` : `none`);
180
218
  }
181
219
  updateHostElementPosition() {
182
220
  if (!this.reference) {
@@ -210,7 +248,7 @@ export class FloatingDirective {
210
248
  setPositionStylingOnHostElement(xPosition, yPosition) {
211
249
  this.renderer.setStyle(this.elementRef.nativeElement, 'left', `${xPosition}px`);
212
250
  this.renderer.setStyle(this.elementRef.nativeElement, 'top', `${yPosition}px`);
213
- this.renderer.setStyle(this.elementRef.nativeElement, 'display', this.isShown ? `block` : `none`);
251
+ this.setDisplayStyling();
214
252
  }
215
253
  setupEventHandling() {
216
254
  if (!this.reference || !this.triggers) {
@@ -218,6 +256,12 @@ export class FloatingDirective {
218
256
  }
219
257
  this.triggers.forEach((trigger) => this.attachTriggerEventToReferenceElement(trigger));
220
258
  }
259
+ attachDocumentClickEvent() {
260
+ if (this.documentClickEventListenerDisposeFn) {
261
+ return;
262
+ }
263
+ this.documentClickEventListenerDisposeFn = this.renderer.listen('document', 'mousedown', (event) => this.onDocumentClickWhileHostShown(event));
264
+ }
221
265
  attachTriggerEventToReferenceElement(trigger) {
222
266
  const events = this.triggerEventMap.get(trigger);
223
267
  if (!events) {
@@ -225,7 +269,7 @@ export class FloatingDirective {
225
269
  }
226
270
  events.forEach((event) => {
227
271
  const eventListenerDisposeFn = this.renderer.listen(this.reference?.nativeElement, event.event, event.method);
228
- this.eventListenerDisposeFns.push(eventListenerDisposeFn);
272
+ this.referenceEventListenerDisposeFns.push(eventListenerDisposeFn);
229
273
  });
230
274
  }
231
275
  handleClickInsideHostElement() {
@@ -239,13 +283,36 @@ export class FloatingDirective {
239
283
  this.hide();
240
284
  }
241
285
  }
242
- tearDownEventHandling() {
243
- this.eventListenerDisposeFns.forEach((eventListenerDisposeFunction) => {
286
+ getOutletElement(config) {
287
+ if (!config || !config.selector || !config.value) {
288
+ return null;
289
+ }
290
+ const elements = this.getHTMLElements(config);
291
+ if (!elements || elements.length === 0) {
292
+ throw Error(`Could not locate HTMLElement for ${config.selector}. Did you misspell it?`);
293
+ }
294
+ if (elements.length > 1) {
295
+ throw Error(`Multiple HTMLElements found for ${config.selector}.
296
+ This can lead to unintended behaviours. Provide an unique outlet`);
297
+ }
298
+ return elements[0];
299
+ }
300
+ getHTMLElements(config) {
301
+ return (this.HTMLElements[config.selector](config.value) || this.HTMLElements['default'](config.value));
302
+ }
303
+ tearDownReferenceElementEventHandling() {
304
+ this.referenceEventListenerDisposeFns.forEach((eventListenerDisposeFunction) => {
244
305
  if (eventListenerDisposeFunction != null) {
245
306
  eventListenerDisposeFunction();
246
307
  }
247
308
  });
248
- this.eventListenerDisposeFns = [];
309
+ this.referenceEventListenerDisposeFns = [];
310
+ }
311
+ tearDownDocumentClickEventHandling() {
312
+ if (this.documentClickEventListenerDisposeFn) {
313
+ this.documentClickEventListenerDisposeFn();
314
+ this.documentClickEventListenerDisposeFn = null;
315
+ }
249
316
  }
250
317
  removeAutoUpdaterRef() {
251
318
  if (this.autoUpdaterRef) {
@@ -253,12 +320,13 @@ export class FloatingDirective {
253
320
  }
254
321
  }
255
322
  ngOnDestroy() {
256
- this.tearDownEventHandling();
323
+ this.tearDownDocumentClickEventHandling();
324
+ this.tearDownReferenceElementEventHandling();
257
325
  this.removeAutoUpdaterRef();
258
326
  }
259
327
  }
260
328
  /** @nocollapse */ FloatingDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: FloatingDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.PortalDirective }], target: i0.ɵɵFactoryTarget.Directive });
261
- /** @nocollapse */ FloatingDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.4", type: FloatingDirective, isStandalone: true, selector: "[kirbyFloating]", inputs: { reference: "reference", placement: "placement", strategy: "strategy", triggers: "triggers", DOMPortalOutlet: "DOMPortalOutlet", isDisabled: "isDisabled", offset: "offset", shift: "shift", autoPlacement: "autoPlacement", closeOnSelect: "closeOnSelect", closeOnEscapeKey: "closeOnEscapeKey", closeOnBackdrop: "closeOnBackdrop" }, outputs: { displayChanged: "displayChanged" }, host: { listeners: { "document:keydown.escape": "onEscapeKeyPressed($event)", "document:mousedown": "onMouseClick($event)" } }, providers: [PortalDirective], hostDirectives: [{ directive: i1.PortalDirective }], ngImport: i0 });
329
+ /** @nocollapse */ FloatingDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.4", type: FloatingDirective, isStandalone: true, selector: "[kirbyFloating]", inputs: { reference: "reference", placement: "placement", strategy: "strategy", triggers: "triggers", DOMPortalOutlet: "DOMPortalOutlet", portalOutletConfig: "portalOutletConfig", isDisabled: "isDisabled", offset: "offset", shift: "shift", autoPlacement: "autoPlacement", closeOnSelect: "closeOnSelect", closeOnEscapeKey: "closeOnEscapeKey", closeOnBackdrop: "closeOnBackdrop" }, outputs: { displayChanged: "displayChanged" }, host: { listeners: { "document:keydown.escape": "onEscapeKeyPressed($event)" } }, providers: [PortalDirective], hostDirectives: [{ directive: i1.PortalDirective }], ngImport: i0 });
262
330
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: FloatingDirective, decorators: [{
263
331
  type: Directive,
264
332
  args: [{
@@ -277,6 +345,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImpor
277
345
  type: Input
278
346
  }], DOMPortalOutlet: [{
279
347
  type: Input
348
+ }], portalOutletConfig: [{
349
+ type: Input
280
350
  }], isDisabled: [{
281
351
  type: Input
282
352
  }], offset: [{
@@ -296,8 +366,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImpor
296
366
  }], onEscapeKeyPressed: [{
297
367
  type: HostListener,
298
368
  args: ['document:keydown.escape', ['$event']]
299
- }], onMouseClick: [{
300
- type: HostListener,
301
- args: ['document:mousedown', ['$event']]
302
369
  }] } });
303
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"floating.directive.js","sourceRoot":"","sources":["../../../../../../libs/designsystem/shared/floating/src/floating.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  Renderer2,\n} from '@angular/core';\nimport {\n  autoPlacement,\n  autoUpdate,\n  computePosition,\n  offset,\n  shift,\n  Strategy,\n} from '@floating-ui/dom';\nimport { ComputePositionConfig, Middleware, Placement } from '@floating-ui/core/src/types';\nimport { DesignTokenHelper } from '@kirbydesign/core';\nimport { from } from 'rxjs';\nimport { PortalDirective } from '@kirbydesign/designsystem/shared/portal';\n\nexport type TriggerEvent = 'hover' | 'click' | 'focus';\n\nexport enum FloatingOffset {\n  none = 0,\n  small = 4,\n  medium = 8,\n}\n\ninterface EventMethods {\n  event: string;\n  method: () => void;\n}\n\ntype EventListenerDisposeFn = () => void;\n\n/**\n * @summary FloatingDirective is a utility that lets you declarative anchor \"popup\" containers to another element.\n *\n * Uses floating-ui, with this directive wraps the functionality: https://floating-ui.com/docs/getting-started\n *\n * Uses PortalDirective to enable functionality for portaling the floated content. This should be used when needed\n * and not as the default option.\n */\n@Directive({\n  selector: '[kirbyFloating]',\n  providers: [PortalDirective],\n  hostDirectives: [PortalDirective],\n  standalone: true,\n})\nexport class FloatingDirective implements OnInit, OnDestroy {\n  /**\n   * Reference to the element for which the host should anchor to\n   * */\n  @Input() public set reference(ref: ElementRef) {\n    this.tearDownEventHandling();\n    this._reference = ref;\n    this.setupEventHandling();\n    this.autoUpdatePosition();\n  }\n\n  public get reference(): ElementRef | undefined {\n    return this._reference;\n  }\n\n  /**\n   * How the host should be placed relative to the reference. Can be affected by middleware\n   * */\n  @Input() public set placement(placement: Placement) {\n    this._placement = placement;\n    this.updateHostElementPosition();\n  }\n\n  public get placement() {\n    return this._placement;\n  }\n\n  /**\n   * The strategy for how the host should be positioned.\n   * */\n  @Input() public set strategy(strategy: Strategy) {\n    this._strategy = strategy;\n    this.updateHostElementPosition();\n  }\n\n  public get strategy(): Strategy {\n    return this._strategy;\n  }\n\n  /**\n   * Defines when the host should be displayed/hidden, i.e. click will attach a click listener to the reference\n   * that makes the host toggle display. Supports multiple triggers, to provide functionality for combinations\n   * like click/focus.\n   * */\n  @Input() public set triggers(eventTriggers: Array<TriggerEvent>) {\n    this._triggers = eventTriggers;\n    this.tearDownEventHandling();\n    this.setupEventHandling();\n  }\n\n  public get triggers(): Array<TriggerEvent> {\n    return this._triggers;\n  }\n\n  /**\n   * The HTMLElement for which the content should portal into.\n   * Providing an outlet enables the portal, if nothing is provided, the provided strategy is used.\n   * This should be used when there's issues with the stacking context, and not as a default option.\n   * */\n  @Input() public set DOMPortalOutlet(outlet: HTMLElement | undefined) {\n    this.portalDirective.outlet = outlet;\n  }\n\n  /**\n   * Prevent host from being toggled if set.\n   * */\n  @Input() public isDisabled: boolean = false;\n\n  /**\n   * Displaces the floating element from its core placement along the specified axes.\n   * */\n  @Input() public offset: FloatingOffset = FloatingOffset.none;\n\n  /**\n   * Moves the floating element along the specified axes in order to keep it in view.\n   * This does not always work as expected, so don't \"just\" set it.\n   * */\n  @Input() public shift: boolean = false;\n\n  /**\n   * Chooses the placement that has the most space available automatically.\n   * */\n  @Input() public autoPlacement: boolean = false;\n\n  /**\n   * Enables hiding the host by events. See variable names.\n   * */\n  @Input() public closeOnSelect: boolean = true;\n  @Input() public closeOnEscapeKey: boolean = true;\n  @Input() public closeOnBackdrop: boolean = true;\n\n  /**\n   * Enables the option to be notified when the host changes display. The new display value is provided.\n   * */\n  @Output() public displayChanged: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n  @HostListener('document:keydown.escape', ['$event'])\n  public onEscapeKeyPressed(): void {\n    if (this.closeOnEscapeKey) {\n      this.hide();\n    }\n  }\n\n  @HostListener('document:mousedown', ['$event'])\n  public onMouseClick(event: Event): void {\n    const clickedOnHost: boolean = this.elementRef.nativeElement.contains(event.target);\n    if (clickedOnHost) {\n      this.handleClickInsideHostElement();\n    } else {\n      this.handleClickOutsideHostElement(event);\n    }\n  }\n\n  private _placement: Placement = 'bottom-start';\n\n  private _strategy: Strategy = 'absolute';\n\n  private _triggers: Array<TriggerEvent> = ['click'];\n\n  private _reference: ElementRef | undefined;\n\n  private autoUpdaterRef: () => void;\n  private isShown: boolean = false;\n  private eventListenerDisposeFns: EventListenerDisposeFn[] = [];\n  private triggerEventMap: Map<TriggerEvent, EventMethods[]> = new Map([\n    ['click', [{ event: 'click', method: this.toggleShow.bind(this) }]],\n    [\n      'hover',\n      [\n        { event: 'mouseenter', method: this.show.bind(this) },\n        { event: 'mouseleave', method: this.hide.bind(this) },\n      ],\n    ],\n    [\n      'focus',\n      [\n        { event: 'focus', method: this.show.bind(this) },\n        { event: 'blur', method: this.hide.bind(this) },\n      ],\n    ],\n  ]);\n\n  public constructor(\n    private elementRef: ElementRef,\n    private renderer: Renderer2,\n    private portalDirective: PortalDirective\n  ) {}\n\n  public ngOnInit(): void {\n    this.addFloatStylingToHostElement();\n    this.updateHostElementPosition();\n  }\n\n  /* Should be accessible for programmatically setting display */\n  public show(): void {\n    if (this.isDisabled) {\n      return;\n    }\n\n    this.renderer.setStyle(this.elementRef.nativeElement, 'display', 'block');\n    this.isShown = true;\n    this.displayChanged.emit(this.isShown);\n  }\n\n  /* Should be accessible for programmatically setting display */\n  public hide(): void {\n    if (this.isDisabled) {\n      return;\n    }\n\n    this.renderer.setStyle(this.elementRef.nativeElement, 'display', 'none');\n    this.isShown = false;\n    this.displayChanged.emit(this.isShown);\n  }\n\n  /* Should be accessible for programmatically setting display */\n  public toggleShow(): void {\n    if (this.isShown) {\n      this.hide();\n    } else {\n      this.show();\n    }\n  }\n\n  private addFloatStylingToHostElement(): void {\n    this.renderer.setStyle(this.elementRef.nativeElement, 'left', `0px`);\n    this.renderer.setStyle(this.elementRef.nativeElement, 'top', `0px`);\n    this.renderer.setStyle(this.elementRef.nativeElement, 'position', this.strategy);\n    this.renderer.setStyle(\n      this.elementRef.nativeElement,\n      'z-index',\n      DesignTokenHelper.zLayer('popover')\n    );\n  }\n\n  private updateHostElementPosition(): void {\n    if (!this.reference) {\n      return;\n    }\n\n    const config: ComputePositionConfig = {\n      placement: this.placement,\n      middleware: this.getMiddlewareConfig(),\n      strategy: this.strategy,\n    } as ComputePositionConfig;\n\n    from(\n      computePosition(this.reference?.nativeElement, this.elementRef.nativeElement, config)\n    ).subscribe(({ x, y }) => this.setPositionStylingOnHostElement(x, y));\n  }\n\n  private getMiddlewareConfig(): Array<Middleware | null | undefined | false> {\n    const middleware: Array<Middleware | null | undefined | false> = [];\n    middleware.push(offset(this.offset));\n\n    if (this.shift) {\n      middleware.push(shift());\n    }\n\n    if (this.autoPlacement) {\n      middleware.push(autoPlacement());\n    }\n\n    return middleware;\n  }\n\n  private autoUpdatePosition(): void {\n    this.removeAutoUpdaterRef();\n\n    if (!this.reference) {\n      return;\n    }\n\n    this.autoUpdaterRef = autoUpdate(\n      this.reference?.nativeElement,\n      this.elementRef.nativeElement,\n      this.updateHostElementPosition.bind(this)\n    );\n  }\n\n  private setPositionStylingOnHostElement(xPosition: number, yPosition: number): void {\n    this.renderer.setStyle(this.elementRef.nativeElement, 'left', `${xPosition}px`);\n    this.renderer.setStyle(this.elementRef.nativeElement, 'top', `${yPosition}px`);\n    this.renderer.setStyle(\n      this.elementRef.nativeElement,\n      'display',\n      this.isShown ? `block` : `none`\n    );\n  }\n\n  private setupEventHandling(): void {\n    if (!this.reference || !this.triggers) {\n      return;\n    }\n\n    this.triggers.forEach((trigger: TriggerEvent) =>\n      this.attachTriggerEventToReferenceElement(trigger)\n    );\n  }\n\n  private attachTriggerEventToReferenceElement(trigger: TriggerEvent): void {\n    const events: EventMethods[] | undefined = this.triggerEventMap.get(trigger);\n\n    if (!events) {\n      throw new Error(`${trigger} is missing event definition(s)`);\n    }\n\n    events.forEach((event: EventMethods) => {\n      const eventListenerDisposeFn: EventListenerDisposeFn = this.renderer.listen(\n        this.reference?.nativeElement,\n        event.event,\n        event.method\n      );\n      this.eventListenerDisposeFns.push(eventListenerDisposeFn);\n    });\n  }\n\n  private handleClickInsideHostElement(): void {\n    if (this.closeOnSelect) {\n      this.hide();\n    }\n  }\n\n  private handleClickOutsideHostElement(event: Event): void {\n    const clickedOnReferenceWithClickTriggerEnabled: boolean =\n      this.reference?.nativeElement.contains(event.target) && this.triggers.includes('click');\n\n    if (this.closeOnBackdrop && !clickedOnReferenceWithClickTriggerEnabled) {\n      this.hide();\n    }\n  }\n\n  private tearDownEventHandling(): void {\n    this.eventListenerDisposeFns.forEach((eventListenerDisposeFunction: EventListenerDisposeFn) => {\n      if (eventListenerDisposeFunction != null) {\n        eventListenerDisposeFunction();\n      }\n    });\n    this.eventListenerDisposeFns = [];\n  }\n\n  private removeAutoUpdaterRef(): void {\n    if (this.autoUpdaterRef) {\n      this.autoUpdaterRef();\n    }\n  }\n\n  public ngOnDestroy() {\n    this.tearDownEventHandling();\n    this.removeAutoUpdaterRef();\n  }\n}\n"]}
370
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"floating.directive.js","sourceRoot":"","sources":["../../../../../../libs/designsystem/shared/floating/src/floating.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  Renderer2,\n} from '@angular/core';\nimport {\n  autoPlacement,\n  autoUpdate,\n  computePosition,\n  offset,\n  shift,\n  Strategy,\n} from '@floating-ui/dom';\nimport { ComputePositionConfig, Middleware, Placement } from '@floating-ui/core/src/types';\nimport { DesignTokenHelper } from '@kirbydesign/core';\nimport { from } from 'rxjs';\nimport { PortalDirective } from '@kirbydesign/designsystem/shared/portal';\n\nexport type TriggerEvent = 'hover' | 'click' | 'focus';\n\nexport enum FloatingOffset {\n  none = 0,\n  small = 4,\n  medium = 8,\n}\n\nexport enum OutletSelector {\n  tag = 'tag',\n  id = 'id',\n  class = 'class',\n  name = 'name',\n}\n\nexport interface PortalOutletConfig {\n  selector: OutletSelector;\n  value: string;\n}\n\ninterface EventMethods {\n  event: string;\n  method: () => void;\n}\n\ntype EventListenerDisposeFn = () => void;\n\n/**\n * @summary FloatingDirective is a utility that lets you declarative anchor \"popup\" containers to another element.\n *\n * Uses floating-ui, with this directive wraps the functionality: https://floating-ui.com/docs/getting-started\n *\n * Uses PortalDirective to enable functionality for portaling the floated content. This should be used when needed\n * and not as the default option.\n */\n@Directive({\n  selector: '[kirbyFloating]',\n  providers: [PortalDirective],\n  hostDirectives: [PortalDirective],\n  standalone: true,\n})\nexport class FloatingDirective implements OnInit, OnDestroy {\n  /**\n   * Reference to the element for which the host should anchor to\n   * */\n  @Input() public set reference(ref: ElementRef) {\n    this.tearDownReferenceElementEventHandling();\n    this._reference = ref;\n    this.setupEventHandling();\n    this.autoUpdatePosition();\n  }\n\n  public get reference(): ElementRef | undefined {\n    return this._reference;\n  }\n\n  /**\n   * How the host should be placed relative to the reference. Can be affected by middleware\n   * */\n  @Input() public set placement(placement: Placement) {\n    this._placement = placement;\n    this.updateHostElementPosition();\n  }\n\n  public get placement() {\n    return this._placement;\n  }\n\n  /**\n   * The strategy for how the host should be positioned.\n   * */\n  @Input() public set strategy(strategy: Strategy) {\n    this._strategy = strategy;\n    this.updateHostElementPosition();\n  }\n\n  public get strategy(): Strategy {\n    return this._strategy;\n  }\n\n  /**\n   * Defines when the host should be displayed/hidden, i.e. click will attach a click listener to the reference\n   * that makes the host toggle display. Supports multiple triggers, to provide functionality for combinations\n   * like click/focus.\n   * */\n  @Input() public set triggers(eventTriggers: Array<TriggerEvent>) {\n    this._triggers = eventTriggers;\n    this.tearDownReferenceElementEventHandling();\n    this.setupEventHandling();\n  }\n\n  public get triggers(): Array<TriggerEvent> {\n    return this._triggers;\n  }\n\n  /**\n   * The HTMLElement for which the content should portal into.\n   * Providing an outlet enables the portal, if nothing is provided, the provided strategy is used.\n   * This should be used when there's issues with the stacking context, and not as a default option.\n   * */\n  @Input() public set DOMPortalOutlet(outlet: HTMLElement | undefined) {\n    this._providedPortalOutlet = outlet;\n    this.portalDirective.outlet =\n      this.DOMPortalOutlet ?? this.getOutletElement(this.portalOutletConfig);\n  }\n\n  public get DOMPortalOutlet(): HTMLElement | undefined {\n    return this._providedPortalOutlet;\n  }\n\n  /**\n   * Defines how to automatically find and assign DOMPortalOutlet if none is provided in DOMPortalOutlet.\n   * If nothing is provided here and in DOMPortalOutlet, the provided strategy is used\n   * */\n  @Input() public set portalOutletConfig(config: PortalOutletConfig | undefined) {\n    this._portalOutletConfig = config;\n\n    if (!this.DOMPortalOutlet) {\n      this.portalDirective.outlet = this.getOutletElement(config);\n    }\n  }\n\n  public get portalOutletConfig(): PortalOutletConfig | undefined {\n    return this._portalOutletConfig;\n  }\n\n  /**\n   * Prevent host from being toggled if set.\n   * */\n  @Input() public isDisabled: boolean = false;\n\n  /**\n   * Displaces the floating element from its core placement along the specified axes.\n   * */\n  @Input() public offset: FloatingOffset = FloatingOffset.none;\n\n  /**\n   * Moves the floating element along the specified axes in order to keep it in view.\n   * This does not always work as expected, so don't \"just\" set it.\n   * */\n  @Input() public shift: boolean = false;\n\n  /**\n   * Chooses the placement that has the most space available automatically.\n   * */\n  @Input() public autoPlacement: boolean = false;\n\n  /**\n   * Enables hiding the host by events. See variable names.\n   * */\n  @Input() public closeOnSelect: boolean = true;\n  @Input() public closeOnEscapeKey: boolean = true;\n  @Input() public closeOnBackdrop: boolean = true;\n\n  /**\n   * Enables the option to be notified when the host changes display. The new display value is provided.\n   * */\n  @Output() public displayChanged: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n  @HostListener('document:keydown.escape', ['$event'])\n  public onEscapeKeyPressed(): void {\n    if (this.closeOnEscapeKey) {\n      this.hide();\n    }\n  }\n\n  private _placement: Placement = 'bottom-start';\n\n  private _strategy: Strategy = 'absolute';\n\n  private _providedPortalOutlet: HTMLElement | undefined;\n\n  private _portalOutletConfig: PortalOutletConfig | undefined;\n\n  private _triggers: Array<TriggerEvent> = ['click'];\n\n  private _reference: ElementRef | undefined;\n\n  private autoUpdaterRef: () => void;\n  private isShown: boolean = false;\n  private referenceEventListenerDisposeFns: EventListenerDisposeFn[] = [];\n  private documentClickEventListenerDisposeFn: EventListenerDisposeFn;\n  private triggerEventMap: Map<TriggerEvent, EventMethods[]> = new Map([\n    ['click', [{ event: 'click', method: this.toggleShow.bind(this) }]],\n    [\n      'hover',\n      [\n        { event: 'mouseenter', method: this.show.bind(this) },\n        { event: 'mouseleave', method: this.hide.bind(this) },\n      ],\n    ],\n    [\n      'focus',\n      [\n        { event: 'focus', method: this.show.bind(this) },\n        { event: 'blur', method: this.hide.bind(this) },\n      ],\n    ],\n  ]);\n\n  private HTMLElements: {\n    [key in OutletSelector | 'default']: (value?: string) => Array<Element> | null;\n  } = {\n    id: (value) => Array.of(document.getElementById(value)),\n    class: (value) => Array.from(document.getElementsByClassName(value)),\n    name: (value) => Array.from(document.getElementsByName(value)),\n    tag: (value) => Array.from(document.getElementsByTagName(value)),\n    default: () => null,\n  };\n\n  public constructor(\n    private elementRef: ElementRef,\n    private renderer: Renderer2,\n    private portalDirective: PortalDirective\n  ) {}\n\n  public ngOnInit(): void {\n    this.addFloatStylingToHostElement();\n    this.updateHostElementPosition();\n  }\n\n  /* Should be accessible for programmatically setting display */\n  public show(): void {\n    if (this.isDisabled) {\n      return;\n    }\n\n    this.attachDocumentClickEvent();\n    this.renderer.setStyle(this.elementRef.nativeElement, 'display', 'block');\n    this.isShown = true;\n    this.displayChanged.emit(this.isShown);\n  }\n\n  /* Should be accessible for programmatically setting display */\n  public hide(): void {\n    if (this.isDisabled) {\n      return;\n    }\n\n    this.tearDownDocumentClickEventHandling();\n    this.renderer.setStyle(this.elementRef.nativeElement, 'display', 'none');\n    this.isShown = false;\n    this.displayChanged.emit(this.isShown);\n  }\n\n  /* Should be accessible for programmatically setting display */\n  public toggleShow(): void {\n    if (this.isShown) {\n      this.hide();\n    } else {\n      this.show();\n    }\n  }\n\n  private onDocumentClickWhileHostShown(event: Event): void {\n    const clickedOnHost: boolean = this.elementRef.nativeElement.contains(event.target);\n    if (clickedOnHost) {\n      this.handleClickInsideHostElement();\n    } else {\n      this.handleClickOutsideHostElement(event);\n    }\n  }\n\n  private addFloatStylingToHostElement(): void {\n    this.renderer.setStyle(this.elementRef.nativeElement, 'left', `0px`);\n    this.renderer.setStyle(this.elementRef.nativeElement, 'top', `0px`);\n    this.renderer.setStyle(this.elementRef.nativeElement, 'position', this.strategy);\n    this.renderer.setStyle(\n      this.elementRef.nativeElement,\n      'z-index',\n      DesignTokenHelper.zLayer('popover')\n    );\n    this.setDisplayStyling();\n  }\n\n  private setDisplayStyling(): void {\n    this.renderer.setStyle(\n      this.elementRef.nativeElement,\n      'display',\n      this.isShown ? `block` : `none`\n    );\n  }\n\n  private updateHostElementPosition(): void {\n    if (!this.reference) {\n      return;\n    }\n\n    const config: ComputePositionConfig = {\n      placement: this.placement,\n      middleware: this.getMiddlewareConfig(),\n      strategy: this.strategy,\n    } as ComputePositionConfig;\n\n    from(\n      computePosition(this.reference?.nativeElement, this.elementRef.nativeElement, config)\n    ).subscribe(({ x, y }) => this.setPositionStylingOnHostElement(x, y));\n  }\n\n  private getMiddlewareConfig(): Array<Middleware | null | undefined | false> {\n    const middleware: Array<Middleware | null | undefined | false> = [];\n    middleware.push(offset(this.offset));\n\n    if (this.shift) {\n      middleware.push(shift());\n    }\n\n    if (this.autoPlacement) {\n      middleware.push(autoPlacement());\n    }\n\n    return middleware;\n  }\n\n  private autoUpdatePosition(): void {\n    this.removeAutoUpdaterRef();\n\n    if (!this.reference) {\n      return;\n    }\n\n    this.autoUpdaterRef = autoUpdate(\n      this.reference?.nativeElement,\n      this.elementRef.nativeElement,\n      this.updateHostElementPosition.bind(this)\n    );\n  }\n\n  private setPositionStylingOnHostElement(xPosition: number, yPosition: number): void {\n    this.renderer.setStyle(this.elementRef.nativeElement, 'left', `${xPosition}px`);\n    this.renderer.setStyle(this.elementRef.nativeElement, 'top', `${yPosition}px`);\n    this.setDisplayStyling();\n  }\n\n  private setupEventHandling(): void {\n    if (!this.reference || !this.triggers) {\n      return;\n    }\n\n    this.triggers.forEach((trigger: TriggerEvent) =>\n      this.attachTriggerEventToReferenceElement(trigger)\n    );\n  }\n\n  private attachDocumentClickEvent(): void {\n    if (this.documentClickEventListenerDisposeFn) {\n      return;\n    }\n\n    this.documentClickEventListenerDisposeFn = this.renderer.listen(\n      'document',\n      'mousedown',\n      (event) => this.onDocumentClickWhileHostShown(event)\n    );\n  }\n\n  private attachTriggerEventToReferenceElement(trigger: TriggerEvent): void {\n    const events: EventMethods[] | undefined = this.triggerEventMap.get(trigger);\n\n    if (!events) {\n      throw new Error(`${trigger} is missing event definition(s)`);\n    }\n\n    events.forEach((event: EventMethods) => {\n      const eventListenerDisposeFn: EventListenerDisposeFn = this.renderer.listen(\n        this.reference?.nativeElement,\n        event.event,\n        event.method\n      );\n      this.referenceEventListenerDisposeFns.push(eventListenerDisposeFn);\n    });\n  }\n\n  private handleClickInsideHostElement(): void {\n    if (this.closeOnSelect) {\n      this.hide();\n    }\n  }\n\n  private handleClickOutsideHostElement(event: Event): void {\n    const clickedOnReferenceWithClickTriggerEnabled: boolean =\n      this.reference?.nativeElement.contains(event.target) && this.triggers.includes('click');\n\n    if (this.closeOnBackdrop && !clickedOnReferenceWithClickTriggerEnabled) {\n      this.hide();\n    }\n  }\n\n  private getOutletElement(config: PortalOutletConfig | undefined): HTMLElement | null {\n    if (!config || !config.selector || !config.value) {\n      return null;\n    }\n\n    const elements: Array<Element> | null = this.getHTMLElements(config);\n\n    if (!elements || elements.length === 0) {\n      throw Error(`Could not locate HTMLElement for ${config.selector}. Did you misspell it?`);\n    }\n\n    if (elements.length > 1) {\n      throw Error(\n        `Multiple HTMLElements found for ${config.selector}.\n         This can lead to unintended behaviours. Provide an unique outlet`\n      );\n    }\n\n    return elements[0] as HTMLElement;\n  }\n\n  private getHTMLElements(config: PortalOutletConfig | undefined): Array<Element> | null {\n    return (\n      this.HTMLElements[config.selector](config.value) || this.HTMLElements['default'](config.value)\n    );\n  }\n\n  private tearDownReferenceElementEventHandling(): void {\n    this.referenceEventListenerDisposeFns.forEach(\n      (eventListenerDisposeFunction: EventListenerDisposeFn) => {\n        if (eventListenerDisposeFunction != null) {\n          eventListenerDisposeFunction();\n        }\n      }\n    );\n    this.referenceEventListenerDisposeFns = [];\n  }\n\n  private tearDownDocumentClickEventHandling(): void {\n    if (this.documentClickEventListenerDisposeFn) {\n      this.documentClickEventListenerDisposeFn();\n      this.documentClickEventListenerDisposeFn = null;\n    }\n  }\n\n  private removeAutoUpdaterRef(): void {\n    if (this.autoUpdaterRef) {\n      this.autoUpdaterRef();\n    }\n  }\n\n  public ngOnDestroy() {\n    this.tearDownDocumentClickEventHandling();\n    this.tearDownReferenceElementEventHandling();\n    this.removeAutoUpdaterRef();\n  }\n}\n"]}
@@ -1,2 +1,2 @@
1
- export { FloatingDirective } from './floating.directive';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZGVzaWduc3lzdGVtL3NoYXJlZC9mbG9hdGluZy9zcmMvcHVibGljX2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsaUJBQWlCLEVBQWdCLE1BQU0sc0JBQXNCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBGbG9hdGluZ0RpcmVjdGl2ZSwgVHJpZ2dlckV2ZW50IH0gZnJvbSAnLi9mbG9hdGluZy5kaXJlY3RpdmUnO1xuIl19
1
+ export { FloatingDirective, FloatingOffset, OutletSelector, } from './floating.directive';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZGVzaWduc3lzdGVtL3NoYXJlZC9mbG9hdGluZy9zcmMvcHVibGljX2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsaUJBQWlCLEVBRWpCLGNBQWMsRUFFZCxjQUFjLEdBQ2YsTUFBTSxzQkFBc0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7XG4gIEZsb2F0aW5nRGlyZWN0aXZlLFxuICBUcmlnZ2VyRXZlbnQsXG4gIEZsb2F0aW5nT2Zmc2V0LFxuICBQb3J0YWxPdXRsZXRDb25maWcsXG4gIE91dGxldFNlbGVjdG9yLFxufSBmcm9tICcuL2Zsb2F0aW5nLmRpcmVjdGl2ZSc7XG4iXX0=
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public_api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2lyYnlkZXNpZ24tZGVzaWduc3lzdGVtLXRhYi1uYXZpZ2F0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9kZXNpZ25zeXN0ZW0vdGFiLW5hdmlnYXRpb24vc3JjL2tpcmJ5ZGVzaWduLWRlc2lnbnN5c3RlbS10YWItbmF2aWdhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpY19hcGknO1xuIl19
@@ -0,0 +1,4 @@
1
+ export { TabNavigationComponent } from './tab-navigation/tab-navigation.component';
2
+ export { TabNavigationItemComponent } from './tab-navigation-item/tab-navigation-item.component';
3
+ export { TabNavigationModule } from './tab-navigation.module';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvZGVzaWduc3lzdGVtL3RhYi1uYXZpZ2F0aW9uL3NyYy9wdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLHFEQUFxRCxDQUFDO0FBQ2pHLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgVGFiTmF2aWdhdGlvbkNvbXBvbmVudCB9IGZyb20gJy4vdGFiLW5hdmlnYXRpb24vdGFiLW5hdmlnYXRpb24uY29tcG9uZW50JztcbmV4cG9ydCB7IFRhYk5hdmlnYXRpb25JdGVtQ29tcG9uZW50IH0gZnJvbSAnLi90YWItbmF2aWdhdGlvbi1pdGVtL3RhYi1uYXZpZ2F0aW9uLWl0ZW0uY29tcG9uZW50JztcbmV4cG9ydCB7IFRhYk5hdmlnYXRpb25Nb2R1bGUgfSBmcm9tICcuL3RhYi1uYXZpZ2F0aW9uLm1vZHVsZSc7XG4iXX0=
@@ -0,0 +1,121 @@
1
+ import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, HostListener, Input, Output, QueryList, ViewChild, } from '@angular/core';
2
+ import { WindowRef } from '@kirbydesign/designsystem/types';
3
+ import { KeyboardHandlerService } from '@kirbydesign/designsystem/dropdown';
4
+ import { TabNavigationItemComponent } from '../tab-navigation-item/tab-navigation-item.component';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@kirbydesign/designsystem/types";
7
+ import * as i2 from "@kirbydesign/designsystem/dropdown";
8
+ export class TabNavigationComponent {
9
+ constructor(window, keyboardHandlerService) {
10
+ this.window = window;
11
+ this.keyboardHandlerService = keyboardHandlerService;
12
+ this.DEBOUNCE_TIME_MS = 250;
13
+ this.tabElements = new Array();
14
+ this.tabButtonElements = new Array();
15
+ this._selectedIndex = -1;
16
+ this._focusIndex = -1;
17
+ this.selectedIndexChange = new EventEmitter();
18
+ /**/
19
+ }
20
+ get selectedIndex() {
21
+ return this._selectedIndex;
22
+ }
23
+ set selectedIndex(index) {
24
+ if (index !== this._selectedIndex) {
25
+ this._selectedIndex = index;
26
+ this.focusIndex = index;
27
+ this.selectTab(this.selectedIndex);
28
+ this.selectedIndexChange.emit(this.selectedIndex);
29
+ }
30
+ }
31
+ get focusIndex() {
32
+ return this._focusIndex;
33
+ }
34
+ set focusIndex(index) {
35
+ if (index !== this._focusIndex) {
36
+ this._focusIndex = index;
37
+ this.scrollToTab(this.focusIndex);
38
+ this.focusTab(this.focusIndex);
39
+ }
40
+ }
41
+ ngAfterViewInit() {
42
+ this.tabBarElement = this.tabBar.nativeElement;
43
+ this.tabs.forEach((tab) => this.tabElements.push(tab.nativeElement));
44
+ this.tabElements.forEach((tabElement) => this.tabButtonElements.push(tabElement.querySelector('[role="tab"]')));
45
+ setTimeout(() => {
46
+ this.selectTab(this.selectedIndex);
47
+ this.scrollToTab(this.focusIndex);
48
+ this.focusTab(this.focusIndex);
49
+ }, this.DEBOUNCE_TIME_MS);
50
+ }
51
+ onItemSelect(event) {
52
+ const targetTabNavItem = event.target.closest('button');
53
+ this.selectedIndex = this.tabButtonElements.indexOf(targetTabNavItem);
54
+ }
55
+ onKeydown(event) {
56
+ event.preventDefault();
57
+ this.focusIndex = this.keyboardHandlerService.handle(event, this.focusIndex, this.tabElements.length - 1, true);
58
+ }
59
+ selectTab(tabIndex) {
60
+ this.tabButtonElements.forEach((tabButtonElement, index) => {
61
+ tabButtonElement.setAttribute('aria-selected', index === tabIndex ? 'true' : 'false');
62
+ });
63
+ }
64
+ focusTab(focusIndex) {
65
+ this.tabButtonElements.forEach((tabButtonElement, index) => {
66
+ tabButtonElement.setAttribute('tabindex', index === focusIndex ? '0' : '-1');
67
+ });
68
+ if (0 <= focusIndex && focusIndex < this.tabButtonElements.length) {
69
+ this.tabButtonElements[focusIndex].focus();
70
+ }
71
+ }
72
+ scrollToTab(tabIndex) {
73
+ if (0 <= tabIndex && tabIndex < this.tabElements.length) {
74
+ const selectedTabElement = this.tabElements[tabIndex];
75
+ const selectedTabElementWidth = selectedTabElement.getBoundingClientRect().width;
76
+ const selectedTabElementOffsetLeft = selectedTabElement.offsetLeft;
77
+ const tabBarElementWidth = this.tabBarElement.getBoundingClientRect().width;
78
+ this.window.nativeWindow.requestAnimationFrame(() => {
79
+ this.tabBarElement?.scrollTo({
80
+ behavior: 'smooth',
81
+ left: Math.max(0, selectedTabElementOffsetLeft - (tabBarElementWidth - selectedTabElementWidth) / 2),
82
+ });
83
+ });
84
+ }
85
+ }
86
+ }
87
+ /** @nocollapse */ TabNavigationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TabNavigationComponent, deps: [{ token: i1.WindowRef }, { token: i2.KeyboardHandlerService }], target: i0.ɵɵFactoryTarget.Component });
88
+ /** @nocollapse */ TabNavigationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: TabNavigationComponent, selector: "kirby-tab-navigation", inputs: { selectedIndex: "selectedIndex" }, outputs: { selectedIndexChange: "selectedIndexChange" }, host: { listeners: { "click": "onItemSelect($event)", "keydown.enter": "onItemSelect($event)", "keydown.home": "onKeydown($event)", "keydown.end": "onKeydown($event)", "keydown.arrowright": "onKeydown($event)", "keydown.arrowleft": "onKeydown($event)" } }, queries: [{ propertyName: "tabs", predicate: TabNavigationItemComponent, read: ElementRef }], viewQueries: [{ propertyName: "tabBar", first: true, predicate: ["tabBar"], descendants: true }], ngImport: i0, template: "<div class=\"container\">\n <div role=\"tablist\" #tabBar>\n <ng-content></ng-content>\n </div>\n</div>\n", styles: ["div[role=tablist]{position:relative;margin:0 auto;display:flex;gap:12px;align-items:center;justify-content:left;flex-wrap:nowrap;overflow-x:scroll;-webkit-overflow-scrolling:auto;scrollbar-width:none}@media (max-width: 720px){div[role=tablist]{padding-inline:var(--padding-start) var(--padding-end)}}div[role=tablist]::-webkit-scrollbar{display:none}.container{position:relative;background-color:var(--kirby-background-color);max-width:var(--page-content-max-width, 720px)}@media (max-width: 720px){.container{margin-inline:calc(-1 * var(--padding-start)) calc(-1 * var(--padding-end))}}.container:before{content:\"\";background-color:var(--kirby-medium);position:absolute;height:1px;bottom:0;z-index:1;left:0;width:100%}@media (max-width: 752px){.container:before{left:calc(-1 * var(--padding-start, 16px));width:calc(100% + var(--padding-start, 16px) * 2)}}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
89
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TabNavigationComponent, decorators: [{
90
+ type: Component,
91
+ args: [{ selector: 'kirby-tab-navigation', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"container\">\n <div role=\"tablist\" #tabBar>\n <ng-content></ng-content>\n </div>\n</div>\n", styles: ["div[role=tablist]{position:relative;margin:0 auto;display:flex;gap:12px;align-items:center;justify-content:left;flex-wrap:nowrap;overflow-x:scroll;-webkit-overflow-scrolling:auto;scrollbar-width:none}@media (max-width: 720px){div[role=tablist]{padding-inline:var(--padding-start) var(--padding-end)}}div[role=tablist]::-webkit-scrollbar{display:none}.container{position:relative;background-color:var(--kirby-background-color);max-width:var(--page-content-max-width, 720px)}@media (max-width: 720px){.container{margin-inline:calc(-1 * var(--padding-start)) calc(-1 * var(--padding-end))}}.container:before{content:\"\";background-color:var(--kirby-medium);position:absolute;height:1px;bottom:0;z-index:1;left:0;width:100%}@media (max-width: 752px){.container:before{left:calc(-1 * var(--padding-start, 16px));width:calc(100% + var(--padding-start, 16px) * 2)}}\n"] }]
92
+ }], ctorParameters: function () { return [{ type: i1.WindowRef }, { type: i2.KeyboardHandlerService }]; }, propDecorators: { tabBar: [{
93
+ type: ViewChild,
94
+ args: ['tabBar']
95
+ }], tabs: [{
96
+ type: ContentChildren,
97
+ args: [TabNavigationItemComponent, { read: ElementRef }]
98
+ }], selectedIndex: [{
99
+ type: Input
100
+ }], selectedIndexChange: [{
101
+ type: Output
102
+ }], onItemSelect: [{
103
+ type: HostListener,
104
+ args: ['click', ['$event']]
105
+ }, {
106
+ type: HostListener,
107
+ args: ['keydown.enter', ['$event']]
108
+ }], onKeydown: [{
109
+ type: HostListener,
110
+ args: ['keydown.home', ['$event']]
111
+ }, {
112
+ type: HostListener,
113
+ args: ['keydown.end', ['$event']]
114
+ }, {
115
+ type: HostListener,
116
+ args: ['keydown.arrowright', ['$event']]
117
+ }, {
118
+ type: HostListener,
119
+ args: ['keydown.arrowleft', ['$event']]
120
+ }] } });
121
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-navigation.component.js","sourceRoot":"","sources":["../../../../../../libs/designsystem/tab-navigation/src/tab-navigation/tab-navigation.component.ts","../../../../../../libs/designsystem/tab-navigation/src/tab-navigation/tab-navigation.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  Output,\n  QueryList,\n  ViewChild,\n} from '@angular/core';\nimport { WindowRef } from '@kirbydesign/designsystem/types';\nimport { KeyboardHandlerService } from '@kirbydesign/designsystem/dropdown';\nimport { TabNavigationItemComponent } from '../tab-navigation-item/tab-navigation-item.component';\n\n@Component({\n  selector: 'kirby-tab-navigation',\n  templateUrl: './tab-navigation.component.html',\n  styleUrls: ['./tab-navigation.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TabNavigationComponent implements AfterViewInit {\n  public readonly DEBOUNCE_TIME_MS = 250;\n\n  @ViewChild('tabBar')\n  private tabBar: ElementRef<HTMLElement>;\n\n  @ContentChildren(TabNavigationItemComponent, { read: ElementRef })\n  private tabs: QueryList<ElementRef<HTMLElement>>;\n\n  private tabBarElement: HTMLElement;\n  private tabElements = new Array<HTMLElement>();\n  private tabButtonElements = new Array<HTMLElement>();\n\n  @Input()\n  get selectedIndex(): number {\n    return this._selectedIndex;\n  }\n\n  set selectedIndex(index: number) {\n    if (index !== this._selectedIndex) {\n      this._selectedIndex = index;\n\n      this.focusIndex = index;\n      this.selectTab(this.selectedIndex);\n      this.selectedIndexChange.emit(this.selectedIndex);\n    }\n  }\n  private _selectedIndex = -1;\n\n  get focusIndex(): number {\n    return this._focusIndex;\n  }\n\n  set focusIndex(index: number) {\n    if (index !== this._focusIndex) {\n      this._focusIndex = index;\n\n      this.scrollToTab(this.focusIndex);\n      this.focusTab(this.focusIndex);\n    }\n  }\n  private _focusIndex = -1;\n\n  @Output()\n  selectedIndexChange = new EventEmitter<number>();\n\n  constructor(private window: WindowRef, private keyboardHandlerService: KeyboardHandlerService) {\n    /**/\n  }\n\n  ngAfterViewInit(): void {\n    this.tabBarElement = this.tabBar.nativeElement;\n    this.tabs.forEach((tab) => this.tabElements.push(tab.nativeElement));\n    this.tabElements.forEach((tabElement) =>\n      this.tabButtonElements.push(tabElement.querySelector('[role=\"tab\"]'))\n    );\n\n    setTimeout(() => {\n      this.selectTab(this.selectedIndex);\n      this.scrollToTab(this.focusIndex);\n      this.focusTab(this.focusIndex);\n    }, this.DEBOUNCE_TIME_MS);\n  }\n\n  @HostListener('click', ['$event'])\n  @HostListener('keydown.enter', ['$event'])\n  onItemSelect(event: PointerEvent) {\n    const targetTabNavItem: HTMLElement = (event.target as HTMLElement).closest('button');\n    this.selectedIndex = this.tabButtonElements.indexOf(targetTabNavItem);\n  }\n\n  @HostListener('keydown.home', ['$event'])\n  @HostListener('keydown.end', ['$event'])\n  @HostListener('keydown.arrowright', ['$event'])\n  @HostListener('keydown.arrowleft', ['$event'])\n  onKeydown(event: KeyboardEvent) {\n    event.preventDefault();\n    this.focusIndex = this.keyboardHandlerService.handle(\n      event,\n      this.focusIndex,\n      this.tabElements.length - 1,\n      true\n    );\n  }\n\n  private selectTab(tabIndex: number): void {\n    this.tabButtonElements.forEach((tabButtonElement, index) => {\n      tabButtonElement.setAttribute('aria-selected', index === tabIndex ? 'true' : 'false');\n    });\n  }\n\n  private focusTab(focusIndex: number): void {\n    this.tabButtonElements.forEach((tabButtonElement, index) => {\n      tabButtonElement.setAttribute('tabindex', index === focusIndex ? '0' : '-1');\n    });\n\n    if (0 <= focusIndex && focusIndex < this.tabButtonElements.length) {\n      this.tabButtonElements[focusIndex].focus();\n    }\n  }\n\n  private scrollToTab(tabIndex: number): void {\n    if (0 <= tabIndex && tabIndex < this.tabElements.length) {\n      const selectedTabElement = this.tabElements[tabIndex];\n      const selectedTabElementWidth = selectedTabElement.getBoundingClientRect().width;\n      const selectedTabElementOffsetLeft = selectedTabElement.offsetLeft;\n      const tabBarElementWidth = this.tabBarElement.getBoundingClientRect().width;\n\n      this.window.nativeWindow.requestAnimationFrame(() => {\n        this.tabBarElement?.scrollTo({\n          behavior: 'smooth',\n          left: Math.max(\n            0,\n            selectedTabElementOffsetLeft - (tabBarElementWidth - selectedTabElementWidth) / 2\n          ),\n        });\n      });\n    }\n  }\n}\n","<div class=\"container\">\n  <div role=\"tablist\" #tabBar>\n    <ng-content></ng-content>\n  </div>\n</div>\n"]}
@@ -0,0 +1,17 @@
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class TabNavigationItemComponent {
4
+ constructor() {
5
+ this.label = '';
6
+ /* */
7
+ }
8
+ }
9
+ /** @nocollapse */ TabNavigationItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TabNavigationItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
10
+ /** @nocollapse */ TabNavigationItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: TabNavigationItemComponent, selector: "kirby-tab-navigation-item", inputs: { label: "label" }, ngImport: i0, template: "<button role=\"tab\" #tabButton>\n <span attr.data-text=\"{{ label }}\">{{ label }}</span>\n <ng-content></ng-content>\n</button>\n", styles: [":host{position:relative;padding-bottom:2px}:host button[role=tab]{background:transparent;color:inherit;font:inherit;cursor:pointer;display:inline-flex;flex-direction:row;align-items:center;justify-content:center;vertical-align:middle;white-space:nowrap;-webkit-user-select:none;user-select:none;text-decoration:none;margin:0;width:auto;border:none;outline:none;background-color:var(--kirby-background-color);color:var(--kirby-black);box-sizing:border-box;padding:16px;font-size:16px;line-height:24px;gap:4px}:host button[role=tab]:focus,:host button[role=tab]:hover{font-weight:700}:host button[role=tab][aria-selected=true]{font-weight:700}:host button[role=tab][aria-selected=true]:before{content:\"\";width:100%;background-color:var(--kirby-dark);position:absolute;border-radius:1px;height:2px;bottom:0;z-index:2}span[data-text]{max-width:100px;overflow:hidden;text-overflow:ellipsis}span[data-text]:before{display:block;content:attr(data-text);font-weight:700;height:0;overflow:hidden;visibility:hidden}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TabNavigationItemComponent, decorators: [{
12
+ type: Component,
13
+ args: [{ selector: 'kirby-tab-navigation-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<button role=\"tab\" #tabButton>\n <span attr.data-text=\"{{ label }}\">{{ label }}</span>\n <ng-content></ng-content>\n</button>\n", styles: [":host{position:relative;padding-bottom:2px}:host button[role=tab]{background:transparent;color:inherit;font:inherit;cursor:pointer;display:inline-flex;flex-direction:row;align-items:center;justify-content:center;vertical-align:middle;white-space:nowrap;-webkit-user-select:none;user-select:none;text-decoration:none;margin:0;width:auto;border:none;outline:none;background-color:var(--kirby-background-color);color:var(--kirby-black);box-sizing:border-box;padding:16px;font-size:16px;line-height:24px;gap:4px}:host button[role=tab]:focus,:host button[role=tab]:hover{font-weight:700}:host button[role=tab][aria-selected=true]{font-weight:700}:host button[role=tab][aria-selected=true]:before{content:\"\";width:100%;background-color:var(--kirby-dark);position:absolute;border-radius:1px;height:2px;bottom:0;z-index:2}span[data-text]{max-width:100px;overflow:hidden;text-overflow:ellipsis}span[data-text]:before{display:block;content:attr(data-text);font-weight:700;height:0;overflow:hidden;visibility:hidden}\n"] }]
14
+ }], ctorParameters: function () { return []; }, propDecorators: { label: [{
15
+ type: Input
16
+ }] } });
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLW5hdmlnYXRpb24taXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2Rlc2lnbnN5c3RlbS90YWItbmF2aWdhdGlvbi9zcmMvdGFiLW5hdmlnYXRpb24taXRlbS90YWItbmF2aWdhdGlvbi1pdGVtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZGVzaWduc3lzdGVtL3RhYi1uYXZpZ2F0aW9uL3NyYy90YWItbmF2aWdhdGlvbi1pdGVtL3RhYi1uYXZpZ2F0aW9uLWl0ZW0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBYyxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBUXRGLE1BQU0sT0FBTywwQkFBMEI7SUFJckM7UUFGQSxVQUFLLEdBQUcsRUFBRSxDQUFDO1FBR1QsS0FBSztJQUNQLENBQUM7OzBJQU5VLDBCQUEwQjs4SEFBMUIsMEJBQTBCLDZGQ1J2Qyx1SUFJQTsyRkRJYSwwQkFBMEI7a0JBTnRDLFNBQVM7K0JBQ0UsMkJBQTJCLG1CQUdwQix1QkFBdUIsQ0FBQyxNQUFNOzBFQUkvQyxLQUFLO3NCQURKLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdraXJieS10YWItbmF2aWdhdGlvbi1pdGVtJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3RhYi1uYXZpZ2F0aW9uLWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi90YWItbmF2aWdhdGlvbi1pdGVtLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBUYWJOYXZpZ2F0aW9uSXRlbUNvbXBvbmVudCB7XG4gIEBJbnB1dCgpXG4gIGxhYmVsID0gJyc7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgLyogKi9cbiAgfVxufVxuIiwiPGJ1dHRvbiByb2xlPVwidGFiXCIgI3RhYkJ1dHRvbj5cbiAgPHNwYW4gYXR0ci5kYXRhLXRleHQ9XCJ7eyBsYWJlbCB9fVwiPnt7IGxhYmVsIH19PC9zcGFuPlxuICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG48L2J1dHRvbj5cbiJdfQ==
@@ -0,0 +1,19 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { TabNavigationComponent } from './tab-navigation/tab-navigation.component';
4
+ import { TabNavigationItemComponent } from './tab-navigation-item/tab-navigation-item.component';
5
+ import * as i0 from "@angular/core";
6
+ export class TabNavigationModule {
7
+ }
8
+ /** @nocollapse */ TabNavigationModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TabNavigationModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
+ /** @nocollapse */ TabNavigationModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.0.4", ngImport: i0, type: TabNavigationModule, declarations: [TabNavigationComponent, TabNavigationItemComponent], imports: [CommonModule], exports: [TabNavigationComponent, TabNavigationItemComponent] });
10
+ /** @nocollapse */ TabNavigationModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TabNavigationModule, imports: [CommonModule] });
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TabNavigationModule, decorators: [{
12
+ type: NgModule,
13
+ args: [{
14
+ imports: [CommonModule],
15
+ declarations: [TabNavigationComponent, TabNavigationItemComponent],
16
+ exports: [TabNavigationComponent, TabNavigationItemComponent],
17
+ }]
18
+ }] });
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLW5hdmlnYXRpb24ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9kZXNpZ25zeXN0ZW0vdGFiLW5hdmlnYXRpb24vc3JjL3RhYi1uYXZpZ2F0aW9uLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUNuRixPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxxREFBcUQsQ0FBQzs7QUFPakcsTUFBTSxPQUFPLG1CQUFtQjs7bUlBQW5CLG1CQUFtQjtvSUFBbkIsbUJBQW1CLGlCQUhmLHNCQUFzQixFQUFFLDBCQUEwQixhQUR2RCxZQUFZLGFBRVosc0JBQXNCLEVBQUUsMEJBQTBCO29JQUVqRCxtQkFBbUIsWUFKcEIsWUFBWTsyRkFJWCxtQkFBbUI7a0JBTC9CLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixZQUFZLEVBQUUsQ0FBQyxzQkFBc0IsRUFBRSwwQkFBMEIsQ0FBQztvQkFDbEUsT0FBTyxFQUFFLENBQUMsc0JBQXNCLEVBQUUsMEJBQTBCLENBQUM7aUJBQzlEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBUYWJOYXZpZ2F0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi90YWItbmF2aWdhdGlvbi90YWItbmF2aWdhdGlvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGFiTmF2aWdhdGlvbkl0ZW1Db21wb25lbnQgfSBmcm9tICcuL3RhYi1uYXZpZ2F0aW9uLWl0ZW0vdGFiLW5hdmlnYXRpb24taXRlbS5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgZGVjbGFyYXRpb25zOiBbVGFiTmF2aWdhdGlvbkNvbXBvbmVudCwgVGFiTmF2aWdhdGlvbkl0ZW1Db21wb25lbnRdLFxuICBleHBvcnRzOiBbVGFiTmF2aWdhdGlvbkNvbXBvbmVudCwgVGFiTmF2aWdhdGlvbkl0ZW1Db21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBUYWJOYXZpZ2F0aW9uTW9kdWxlIHt9XG4iXX0=
@@ -92,4 +92,3 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImpor
92
92
 
93
93
  export { AccordionDirective, AccordionItemComponent, AccordionModule };
94
94
  //# sourceMappingURL=kirbydesign-designsystem-accordion.mjs.map
95
- //# sourceMappingURL=kirbydesign-designsystem-accordion.mjs.map