@govtechsg/sgds-web-component 3.14.1-rc.0 → 3.15.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 (172) hide show
  1. package/base/dropdown-element.d.ts +2 -0
  2. package/base/dropdown-element.js +8 -2
  3. package/base/dropdown-element.js.map +1 -1
  4. package/components/Accordion/index.umd.min.js +8 -8
  5. package/components/Accordion/index.umd.min.js.map +1 -1
  6. package/components/Accordion/sgds-accordion.d.ts +1 -2
  7. package/components/Accordion/sgds-accordion.js +2 -3
  8. package/components/Accordion/sgds-accordion.js.map +1 -1
  9. package/components/Breadcrumb/index.umd.min.js +1 -1
  10. package/components/Breadcrumb/index.umd.min.js.map +1 -1
  11. package/components/ComboBox/index.umd.min.js +24 -24
  12. package/components/ComboBox/index.umd.min.js.map +1 -1
  13. package/components/ComboBox/sgds-combo-box.js +2 -2
  14. package/components/ComboBox/sgds-combo-box.js.map +1 -1
  15. package/components/Datepicker/datepicker.js +1 -1
  16. package/components/Datepicker/index.umd.min.js +3 -3
  17. package/components/Datepicker/index.umd.min.js.map +1 -1
  18. package/components/Datepicker/sgds-datepicker.js +1 -1
  19. package/components/Datepicker/sgds-datepicker.js.map +1 -1
  20. package/components/Dropdown/dropdown-menu.js +1 -1
  21. package/components/Dropdown/index.umd.min.js +1 -1
  22. package/components/Dropdown/index.umd.min.js.map +1 -1
  23. package/components/Dropdown/sgds-dropdown.js +1 -1
  24. package/components/Dropdown/sgds-dropdown.js.map +1 -1
  25. package/components/Mainnav/index.umd.min.js +8 -8
  26. package/components/Mainnav/index.umd.min.js.map +1 -1
  27. package/components/Mainnav/sgds-mainnav.d.ts +3 -1
  28. package/components/Mainnav/sgds-mainnav.js +9 -5
  29. package/components/Mainnav/sgds-mainnav.js.map +1 -1
  30. package/components/OverflowMenu/index.umd.min.js +1 -1
  31. package/components/OverflowMenu/index.umd.min.js.map +1 -1
  32. package/components/Select/index.umd.min.js +7 -7
  33. package/components/Select/index.umd.min.js.map +1 -1
  34. package/components/Select/sgds-select.js +2 -2
  35. package/components/Select/sgds-select.js.map +1 -1
  36. package/components/index.d.ts +0 -1
  37. package/components/index.js +0 -1
  38. package/components/index.js.map +1 -1
  39. package/components/index.umd.min.js +77 -130
  40. package/components/index.umd.min.js.map +1 -1
  41. package/css/fouc.css +0 -4
  42. package/css/sgds.css +2 -2
  43. package/css/utility.css +29 -18
  44. package/index.d.ts +0 -1
  45. package/index.js +0 -1
  46. package/index.js.map +1 -1
  47. package/index.umd.min.js +65 -196
  48. package/index.umd.min.js.map +1 -1
  49. package/package.json +1 -1
  50. package/react/base/dropdown-element.cjs.js +8 -2
  51. package/react/base/dropdown-element.cjs.js.map +1 -1
  52. package/react/base/dropdown-element.js +8 -2
  53. package/react/base/dropdown-element.js.map +1 -1
  54. package/react/components/Accordion/sgds-accordion.cjs.js +2 -3
  55. package/react/components/Accordion/sgds-accordion.cjs.js.map +1 -1
  56. package/react/components/Accordion/sgds-accordion.js +2 -3
  57. package/react/components/Accordion/sgds-accordion.js.map +1 -1
  58. package/react/components/ComboBox/sgds-combo-box.cjs.js +2 -2
  59. package/react/components/ComboBox/sgds-combo-box.cjs.js.map +1 -1
  60. package/react/components/ComboBox/sgds-combo-box.js +2 -2
  61. package/react/components/ComboBox/sgds-combo-box.js.map +1 -1
  62. package/react/components/Datepicker/datepicker.cjs.js +1 -1
  63. package/react/components/Datepicker/datepicker.js +1 -1
  64. package/react/components/Datepicker/sgds-datepicker.cjs.js +1 -1
  65. package/react/components/Datepicker/sgds-datepicker.cjs.js.map +1 -1
  66. package/react/components/Datepicker/sgds-datepicker.js +1 -1
  67. package/react/components/Datepicker/sgds-datepicker.js.map +1 -1
  68. package/react/components/Dropdown/dropdown-menu.cjs.js +1 -1
  69. package/react/components/Dropdown/dropdown-menu.js +1 -1
  70. package/react/components/Dropdown/sgds-dropdown.cjs.js +1 -1
  71. package/react/components/Dropdown/sgds-dropdown.cjs.js.map +1 -1
  72. package/react/components/Dropdown/sgds-dropdown.js +1 -1
  73. package/react/components/Dropdown/sgds-dropdown.js.map +1 -1
  74. package/react/components/Mainnav/sgds-mainnav.cjs.js +9 -5
  75. package/react/components/Mainnav/sgds-mainnav.cjs.js.map +1 -1
  76. package/react/components/Mainnav/sgds-mainnav.js +9 -5
  77. package/react/components/Mainnav/sgds-mainnav.js.map +1 -1
  78. package/react/components/Select/sgds-select.cjs.js +2 -2
  79. package/react/components/Select/sgds-select.cjs.js.map +1 -1
  80. package/react/components/Select/sgds-select.js +2 -2
  81. package/react/components/Select/sgds-select.js.map +1 -1
  82. package/react/index.cjs.js +48 -56
  83. package/react/index.cjs.js.map +1 -1
  84. package/react/index.d.ts +0 -4
  85. package/react/index.js +0 -4
  86. package/react/index.js.map +1 -1
  87. package/themes/responsive.css +18 -0
  88. package/base/sidebar-element.d.ts +0 -112
  89. package/base/sidebar-element.js +0 -281
  90. package/base/sidebar-element.js.map +0 -1
  91. package/components/Sidebar/index.d.ts +0 -16
  92. package/components/Sidebar/index.js +0 -10
  93. package/components/Sidebar/index.js.map +0 -1
  94. package/components/Sidebar/index.umd.min.js +0 -2501
  95. package/components/Sidebar/index.umd.min.js.map +0 -1
  96. package/components/Sidebar/sgds-sidebar-group.d.ts +0 -51
  97. package/components/Sidebar/sgds-sidebar-group.js +0 -124
  98. package/components/Sidebar/sgds-sidebar-group.js.map +0 -1
  99. package/components/Sidebar/sgds-sidebar-item.d.ts +0 -25
  100. package/components/Sidebar/sgds-sidebar-item.js +0 -73
  101. package/components/Sidebar/sgds-sidebar-item.js.map +0 -1
  102. package/components/Sidebar/sgds-sidebar-section.d.ts +0 -56
  103. package/components/Sidebar/sgds-sidebar-section.js +0 -125
  104. package/components/Sidebar/sgds-sidebar-section.js.map +0 -1
  105. package/components/Sidebar/sgds-sidebar.d.ts +0 -156
  106. package/components/Sidebar/sgds-sidebar.js +0 -412
  107. package/components/Sidebar/sgds-sidebar.js.map +0 -1
  108. package/components/Sidebar/sidebar-context.d.ts +0 -51
  109. package/components/Sidebar/sidebar-context.js +0 -45
  110. package/components/Sidebar/sidebar-context.js.map +0 -1
  111. package/components/Sidebar/sidebar-item.js +0 -6
  112. package/components/Sidebar/sidebar-item.js.map +0 -1
  113. package/components/Sidebar/sidebar-section.js +0 -6
  114. package/components/Sidebar/sidebar-section.js.map +0 -1
  115. package/components/Sidebar/sidebar.js +0 -6
  116. package/components/Sidebar/sidebar.js.map +0 -1
  117. package/react/base/sidebar-element.cjs.js +0 -286
  118. package/react/base/sidebar-element.cjs.js.map +0 -1
  119. package/react/base/sidebar-element.js +0 -282
  120. package/react/base/sidebar-element.js.map +0 -1
  121. package/react/components/Sidebar/sgds-sidebar-group.cjs.js +0 -130
  122. package/react/components/Sidebar/sgds-sidebar-group.cjs.js.map +0 -1
  123. package/react/components/Sidebar/sgds-sidebar-group.js +0 -125
  124. package/react/components/Sidebar/sgds-sidebar-group.js.map +0 -1
  125. package/react/components/Sidebar/sgds-sidebar-item.cjs.js +0 -79
  126. package/react/components/Sidebar/sgds-sidebar-item.cjs.js.map +0 -1
  127. package/react/components/Sidebar/sgds-sidebar-item.js +0 -74
  128. package/react/components/Sidebar/sgds-sidebar-item.js.map +0 -1
  129. package/react/components/Sidebar/sgds-sidebar-section.cjs.js +0 -131
  130. package/react/components/Sidebar/sgds-sidebar-section.cjs.js.map +0 -1
  131. package/react/components/Sidebar/sgds-sidebar-section.js +0 -126
  132. package/react/components/Sidebar/sgds-sidebar-section.js.map +0 -1
  133. package/react/components/Sidebar/sgds-sidebar.cjs.js +0 -418
  134. package/react/components/Sidebar/sgds-sidebar.cjs.js.map +0 -1
  135. package/react/components/Sidebar/sgds-sidebar.js +0 -413
  136. package/react/components/Sidebar/sgds-sidebar.js.map +0 -1
  137. package/react/components/Sidebar/sidebar-context.cjs.js +0 -54
  138. package/react/components/Sidebar/sidebar-context.cjs.js.map +0 -1
  139. package/react/components/Sidebar/sidebar-context.js +0 -46
  140. package/react/components/Sidebar/sidebar-context.js.map +0 -1
  141. package/react/components/Sidebar/sidebar-item.cjs.js +0 -11
  142. package/react/components/Sidebar/sidebar-item.cjs.js.map +0 -1
  143. package/react/components/Sidebar/sidebar-item.js +0 -7
  144. package/react/components/Sidebar/sidebar-item.js.map +0 -1
  145. package/react/components/Sidebar/sidebar-section.cjs.js +0 -11
  146. package/react/components/Sidebar/sidebar-section.cjs.js.map +0 -1
  147. package/react/components/Sidebar/sidebar-section.js +0 -7
  148. package/react/components/Sidebar/sidebar-section.js.map +0 -1
  149. package/react/components/Sidebar/sidebar.cjs.js +0 -11
  150. package/react/components/Sidebar/sidebar.cjs.js.map +0 -1
  151. package/react/components/Sidebar/sidebar.js +0 -7
  152. package/react/components/Sidebar/sidebar.js.map +0 -1
  153. package/react/sidebar/index.cjs.js +0 -42
  154. package/react/sidebar/index.cjs.js.map +0 -1
  155. package/react/sidebar/index.d.ts +0 -2
  156. package/react/sidebar/index.js +0 -18
  157. package/react/sidebar/index.js.map +0 -1
  158. package/react/sidebar-group/index.cjs.js +0 -40
  159. package/react/sidebar-group/index.cjs.js.map +0 -1
  160. package/react/sidebar-group/index.d.ts +0 -2
  161. package/react/sidebar-group/index.js +0 -16
  162. package/react/sidebar-group/index.js.map +0 -1
  163. package/react/sidebar-item/index.cjs.js +0 -40
  164. package/react/sidebar-item/index.cjs.js.map +0 -1
  165. package/react/sidebar-item/index.d.ts +0 -2
  166. package/react/sidebar-item/index.js +0 -16
  167. package/react/sidebar-item/index.js.map +0 -1
  168. package/react/sidebar-section/index.cjs.js +0 -40
  169. package/react/sidebar-section/index.cjs.js.map +0 -1
  170. package/react/sidebar-section/index.d.ts +0 -2
  171. package/react/sidebar-section/index.js +0 -16
  172. package/react/sidebar-section/index.js.map +0 -1
@@ -1,286 +0,0 @@
1
- 'use client';
2
- 'use strict';
3
-
4
- Object.defineProperty(exports, '__esModule', { value: true });
5
-
6
- var tslib = require('tslib');
7
- var decorators_js = require('lit/decorators.js');
8
- var dropdownElement = require('./dropdown-element.cjs.js');
9
- var sgdsElement = require('./sgds-element.cjs.js');
10
- var context = require('@lit/context');
11
- var sidebarContext = require('../components/Sidebar/sidebar-context.cjs.js');
12
-
13
- const ARROW_DOWN = "ArrowDown";
14
- const ARROW_UP = "ArrowUp";
15
- const ARROW_LEFT = "ArrowLeft";
16
- const ARROW_RIGHT = "ArrowRight";
17
- const ENTER = "Enter";
18
- /**
19
- * @summary Base class for sidebar navigation components.
20
- * Provides core functionality for sidebar items and groups including keyboard navigation,
21
- * selection state management, and nesting support. This class manages hierarchical navigation,
22
- * active state tracking, and drawer overlay coordination through context providers.
23
- *
24
- * Features:
25
- * - Multi-level keyboard navigation (Arrow keys, Enter)
26
- * - Active state management via Lit context subscription
27
- * - Support for nested hierarchies up to 3 levels deep
28
- * - Focus management and full ARIA attribute support
29
- * - Event emission for sidebar coordination (i-sgds-click)
30
- * - Automatic child element tracking and nesting level detection
31
- *
32
- * Keyboard Navigation:
33
- * - Arrow Up/Down: Navigate between siblings in the same level
34
- * - Arrow Left/Right: Navigate hierarchically (collapse/expand or move in drawer)
35
- * - Enter: Activate focused item or toggle group
36
- *
37
- * Context Management:
38
- * - Consumes: SidebarCollapsed, SidebarActiveItem, SidebarActiveGroup, SidebarDrawerItems
39
- * - Updates state based on context changes for responsive UI updates
40
- *
41
- * @internal
42
- */
43
- class SidebarElement extends sgdsElement["default"] {
44
- constructor() {
45
- super(...arguments);
46
- /**
47
- * The display title/label for the sidebar element.
48
- * Shown in the UI and used for accessibility labels (aria-label).
49
- * @attribute title
50
- * @type {string}
51
- * @default ""
52
- */
53
- this.title = "";
54
- /**
55
- * The unique name identifier for the sidebar element.
56
- * Used to identify selections in sgds-select events and manage active states.
57
- * Should be unique among siblings in the same navigation level.
58
- * @attribute name
59
- * @type {string}
60
- * @default ""
61
- */
62
- this.name = "";
63
- /** @internal */
64
- this._sidebarCollapsed = false;
65
- /** @internal */
66
- this._sidebarActiveItem = null;
67
- /** @internal */
68
- this._sidebarActiveGroup = null;
69
- /** @internal */
70
- this._drawerItems = null;
71
- /** @internal Tracks whether a drawer overlay is currently open */
72
- this._showDrawer = false;
73
- /** @internal */
74
- this._childLevel = 0;
75
- /**
76
- * Indicates whether this element is currently selected/active.
77
- * @internal
78
- */
79
- this._selected = false;
80
- /**
81
- * Indicates whether this element should be hidden based on nesting context.
82
- * @internal
83
- */
84
- this._hidden = false;
85
- /**
86
- * List of child elements assigned to this component.
87
- * @internal
88
- */
89
- this._childElements = [];
90
- /** @internal */
91
- this._childActive = false;
92
- }
93
- connectedCallback() {
94
- super.connectedCallback();
95
- this.getChildLevel();
96
- this.setAttribute("role", "option");
97
- this.setAttribute("aria-label", this.title || this.name);
98
- this.addEventListener("keydown", this._handleKeyDown);
99
- }
100
- disconnectedCallback() {
101
- super.disconnectedCallback();
102
- this.removeEventListener("keydown", this._handleKeyDown);
103
- }
104
- firstUpdated(changedProperties) {
105
- super.firstUpdated(changedProperties);
106
- this.getChildLevel();
107
- }
108
- updated() {
109
- if (this._childLevel === 1) {
110
- this._hidden = !this.closest(".sidebar-nested-overlay");
111
- }
112
- }
113
- /**
114
- * Handles slot change events and updates child elements list.
115
- * @internal
116
- * @returns {void}
117
- */
118
- _handleSlotChange() {
119
- this._childElements = this._defaultNodes;
120
- }
121
- /**
122
- * Handles click/activation events on the sidebar element.
123
- * Emits internal click event for parent sidebar to handle selection.
124
- * @internal
125
- * @param {SidebarElement} [element] - Optional element parameter (for keyboard compatibility)
126
- * @returns {void}
127
- */
128
- _handleClick() {
129
- this.emit("i-sgds-click", { detail: { element: this, level: this._childLevel } });
130
- }
131
- /**
132
- * Handles keyboard navigation events for sidebar elements.
133
- * Supports Arrow Up/Down for navigation and Arrow Left/Right for drawer management.
134
- * @internal
135
- * @param {KeyboardEvent} event - The keyboard event object
136
- * @returns {void}
137
- */
138
- _handleKeyDown(event) {
139
- var _a, _b, _c;
140
- const target = event.target;
141
- switch (event.key) {
142
- case ENTER: {
143
- event.preventDefault();
144
- event.stopPropagation();
145
- if (event.target === this)
146
- this._handleClick();
147
- return;
148
- }
149
- case ARROW_DOWN: {
150
- event.preventDefault();
151
- event.stopPropagation();
152
- const child = target._childElements[0];
153
- const isChildHidden = child === null || child === void 0 ? void 0 : child._hidden;
154
- const childElement = !isChildHidden ? child : null;
155
- const nextElement = childElement || target.nextElementSibling || target.parentElement.nextElementSibling;
156
- if (nextElement === null || nextElement === void 0 ? void 0 : nextElement.shadowRoot) {
157
- const focusTarget = nextElement.shadowRoot.querySelector("[tabindex]");
158
- focusTarget === null || focusTarget === void 0 ? void 0 : focusTarget.focus();
159
- }
160
- return;
161
- }
162
- case ARROW_UP: {
163
- event.preventDefault();
164
- event.stopPropagation();
165
- const prevSiblingChildren = (_a = target.previousElementSibling) === null || _a === void 0 ? void 0 : _a._childElements;
166
- const lastChild = prevSiblingChildren ? prevSiblingChildren[(prevSiblingChildren === null || prevSiblingChildren === void 0 ? void 0 : prevSiblingChildren.length) - 1] : null;
167
- const isChildHidden = lastChild === null || lastChild === void 0 ? void 0 : lastChild._hidden;
168
- const childElement = !isChildHidden ? lastChild : null;
169
- const prevElement = childElement || target.previousElementSibling || target.parentElement;
170
- if (prevElement === null || prevElement === void 0 ? void 0 : prevElement.shadowRoot) {
171
- const focusTarget = prevElement.shadowRoot.querySelector("[tabindex]");
172
- focusTarget === null || focusTarget === void 0 ? void 0 : focusTarget.focus();
173
- }
174
- return;
175
- }
176
- case ARROW_LEFT: {
177
- event.preventDefault();
178
- event.stopPropagation();
179
- if (this._sidebarActiveGroup === this) {
180
- // when drawer is open, close it
181
- if (this._showDrawer)
182
- this._handleClick();
183
- }
184
- else {
185
- // check if we are on the drawer, if so move back to parent
186
- const childLevel = target._childLevel;
187
- if (childLevel >= 1 && ((_b = this._sidebarActiveGroup) === null || _b === void 0 ? void 0 : _b.shadowRoot)) {
188
- const focusTarget = this._sidebarActiveGroup.shadowRoot.querySelector("[tabindex]");
189
- focusTarget === null || focusTarget === void 0 ? void 0 : focusTarget.focus();
190
- }
191
- }
192
- return;
193
- }
194
- case ARROW_RIGHT: {
195
- event.preventDefault();
196
- event.stopPropagation();
197
- if (this._sidebarActiveGroup === this) {
198
- if ((_c = this._drawerItems) === null || _c === void 0 ? void 0 : _c.length) {
199
- if (this._showDrawer) {
200
- const drawerItem = this._drawerItems[0];
201
- if (drawerItem === null || drawerItem === void 0 ? void 0 : drawerItem.shadowRoot) {
202
- const focusTarget = drawerItem.shadowRoot.querySelector("[tabindex]");
203
- focusTarget === null || focusTarget === void 0 ? void 0 : focusTarget.focus();
204
- }
205
- }
206
- else {
207
- this._handleClick();
208
- }
209
- }
210
- }
211
- else {
212
- if (this._childLevel === 0 && this._childElements.length > 0) {
213
- // when there is nested, we trigger click to show drawer
214
- this._handleClick();
215
- }
216
- }
217
- return;
218
- }
219
- }
220
- }
221
- /**
222
- * Calculates the nesting level by counting parent sgds-sidebar-group ancestors.
223
- * Level 0 = top-level element, Level 1+ = nested within another group.
224
- * Updates the _childLevel state property.
225
- * @internal
226
- * @returns {void}
227
- */
228
- getChildLevel() {
229
- let currentEle = this.parentElement;
230
- let level = 0;
231
- while (currentEle.tagName.toLowerCase() === "sgds-sidebar-group") {
232
- level += 1;
233
- currentEle = currentEle.parentElement;
234
- }
235
- const isInDrawer = currentEle.classList.contains("sidebar-nested-overlay");
236
- this._childLevel = isInDrawer ? level + 1 : level;
237
- }
238
- }
239
- SidebarElement.styles = dropdownElement.DropdownElement.styles;
240
- tslib.__decorate([
241
- decorators_js.property({ type: String, reflect: true })
242
- ], SidebarElement.prototype, "title", void 0);
243
- tslib.__decorate([
244
- decorators_js.property({ type: String, reflect: true })
245
- ], SidebarElement.prototype, "name", void 0);
246
- tslib.__decorate([
247
- context.consume({ context: sidebarContext.SidebarCollapsed, subscribe: true }),
248
- decorators_js.state()
249
- ], SidebarElement.prototype, "_sidebarCollapsed", void 0);
250
- tslib.__decorate([
251
- context.consume({ context: sidebarContext.SidebarActiveItem, subscribe: true }),
252
- decorators_js.state()
253
- ], SidebarElement.prototype, "_sidebarActiveItem", void 0);
254
- tslib.__decorate([
255
- context.consume({ context: sidebarContext.SidebarActiveGroup, subscribe: true }),
256
- decorators_js.state()
257
- ], SidebarElement.prototype, "_sidebarActiveGroup", void 0);
258
- tslib.__decorate([
259
- context.consume({ context: sidebarContext.SidebarDrawerItems, subscribe: true }),
260
- decorators_js.state()
261
- ], SidebarElement.prototype, "_drawerItems", void 0);
262
- tslib.__decorate([
263
- context.consume({ context: sidebarContext.SidebarDrawerOpen, subscribe: true }),
264
- decorators_js.state()
265
- ], SidebarElement.prototype, "_showDrawer", void 0);
266
- tslib.__decorate([
267
- decorators_js.state()
268
- ], SidebarElement.prototype, "_childLevel", void 0);
269
- tslib.__decorate([
270
- decorators_js.state()
271
- ], SidebarElement.prototype, "_selected", void 0);
272
- tslib.__decorate([
273
- decorators_js.state()
274
- ], SidebarElement.prototype, "_hidden", void 0);
275
- tslib.__decorate([
276
- decorators_js.state()
277
- ], SidebarElement.prototype, "_childElements", void 0);
278
- tslib.__decorate([
279
- decorators_js.state()
280
- ], SidebarElement.prototype, "_childActive", void 0);
281
- tslib.__decorate([
282
- decorators_js.queryAssignedElements({ flatten: true })
283
- ], SidebarElement.prototype, "_defaultNodes", void 0);
284
-
285
- exports.SidebarElement = SidebarElement;
286
- //# sourceMappingURL=sidebar-element.cjs.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sidebar-element.cjs.js","sources":["../../../src/base/sidebar-element.ts"],"sourcesContent":["import { property, queryAssignedElements, state } from \"lit/decorators.js\";\nimport { DropdownElement } from \"./dropdown-element\";\nimport { PropertyValueMap } from \"lit\";\nimport SgdsElement from \"./sgds-element\";\nimport { consume } from \"@lit/context\";\nimport {\n SidebarActiveGroup,\n SidebarActiveItem,\n SidebarCollapsed,\n SidebarDrawerItems,\n SidebarDrawerOpen\n} from \"../components/Sidebar/sidebar-context\";\n\nconst ARROW_DOWN = \"ArrowDown\";\nconst ARROW_UP = \"ArrowUp\";\nconst ARROW_LEFT = \"ArrowLeft\";\nconst ARROW_RIGHT = \"ArrowRight\";\nconst ENTER = \"Enter\";\n\n/**\n * @summary Base class for sidebar navigation components.\n * Provides core functionality for sidebar items and groups including keyboard navigation,\n * selection state management, and nesting support. This class manages hierarchical navigation,\n * active state tracking, and drawer overlay coordination through context providers.\n *\n * Features:\n * - Multi-level keyboard navigation (Arrow keys, Enter)\n * - Active state management via Lit context subscription\n * - Support for nested hierarchies up to 3 levels deep\n * - Focus management and full ARIA attribute support\n * - Event emission for sidebar coordination (i-sgds-click)\n * - Automatic child element tracking and nesting level detection\n *\n * Keyboard Navigation:\n * - Arrow Up/Down: Navigate between siblings in the same level\n * - Arrow Left/Right: Navigate hierarchically (collapse/expand or move in drawer)\n * - Enter: Activate focused item or toggle group\n *\n * Context Management:\n * - Consumes: SidebarCollapsed, SidebarActiveItem, SidebarActiveGroup, SidebarDrawerItems\n * - Updates state based on context changes for responsive UI updates\n *\n * @internal\n */\nexport class SidebarElement extends SgdsElement {\n static styles = DropdownElement.styles;\n\n /**\n * The display title/label for the sidebar element.\n * Shown in the UI and used for accessibility labels (aria-label).\n * @attribute title\n * @type {string}\n * @default \"\"\n */\n @property({ type: String, reflect: true }) title = \"\";\n\n /**\n * The unique name identifier for the sidebar element.\n * Used to identify selections in sgds-select events and manage active states.\n * Should be unique among siblings in the same navigation level.\n * @attribute name\n * @type {string}\n * @default \"\"\n */\n @property({ type: String, reflect: true }) name = \"\";\n\n /** @internal */\n @consume({ context: SidebarCollapsed, subscribe: true })\n @state()\n _sidebarCollapsed = false;\n\n /** @internal */\n @consume({ context: SidebarActiveItem, subscribe: true })\n @state()\n _sidebarActiveItem: SidebarElement | null = null;\n\n /** @internal */\n @consume({ context: SidebarActiveGroup, subscribe: true })\n @state()\n _sidebarActiveGroup: SidebarElement | null = null;\n\n /** @internal */\n @consume({ context: SidebarDrawerItems, subscribe: true })\n @state()\n _drawerItems: SidebarElement[] | null = null;\n\n /** @internal Tracks whether a drawer overlay is currently open */\n @consume({ context: SidebarDrawerOpen, subscribe: true })\n @state()\n _showDrawer = false;\n\n /** @internal */\n @state() _childLevel = 0;\n\n /**\n * Indicates whether this element is currently selected/active.\n * @internal\n */\n @state() _selected = false;\n\n /**\n * Indicates whether this element should be hidden based on nesting context.\n * @internal\n */\n @state() _hidden = false;\n\n /**\n * List of child elements assigned to this component.\n * @internal\n */\n @state()\n _childElements: SidebarElement[] = [];\n\n /** @internal */\n @state() _childActive = false;\n\n /** @internal */\n @queryAssignedElements({ flatten: true })\n private _defaultNodes!: SidebarElement[];\n\n connectedCallback() {\n super.connectedCallback();\n this.getChildLevel();\n this.setAttribute(\"role\", \"option\");\n this.setAttribute(\"aria-label\", this.title || this.name);\n this.addEventListener(\"keydown\", this._handleKeyDown);\n }\n\n disconnectedCallback() {\n super.disconnectedCallback();\n this.removeEventListener(\"keydown\", this._handleKeyDown);\n }\n\n firstUpdated(changedProperties: PropertyValueMap<this>) {\n super.firstUpdated(changedProperties);\n this.getChildLevel();\n }\n\n updated() {\n if (this._childLevel === 1) {\n this._hidden = !this.closest(\".sidebar-nested-overlay\");\n }\n }\n\n /**\n * Handles slot change events and updates child elements list.\n * @internal\n * @returns {void}\n */\n _handleSlotChange() {\n this._childElements = this._defaultNodes;\n }\n\n /**\n * Handles click/activation events on the sidebar element.\n * Emits internal click event for parent sidebar to handle selection.\n * @internal\n * @param {SidebarElement} [element] - Optional element parameter (for keyboard compatibility)\n * @returns {void}\n */\n _handleClick() {\n this.emit(\"i-sgds-click\", { detail: { element: this, level: this._childLevel } });\n }\n\n /**\n * Handles keyboard navigation events for sidebar elements.\n * Supports Arrow Up/Down for navigation and Arrow Left/Right for drawer management.\n * @internal\n * @param {KeyboardEvent} event - The keyboard event object\n * @returns {void}\n */\n private _handleKeyDown(event: KeyboardEvent) {\n const target = event.target as HTMLElement;\n\n switch (event.key) {\n case ENTER: {\n event.preventDefault();\n event.stopPropagation();\n if (event.target === this) this._handleClick();\n return;\n }\n case ARROW_DOWN: {\n event.preventDefault();\n event.stopPropagation();\n\n const child = (target as SidebarElement)._childElements[0];\n\n const isChildHidden = child?._hidden;\n const childElement = !isChildHidden ? child : null;\n const nextElement = childElement || target.nextElementSibling || target.parentElement.nextElementSibling;\n\n if (nextElement?.shadowRoot) {\n const focusTarget = nextElement.shadowRoot.querySelector(\"[tabindex]\") as HTMLElement | null;\n focusTarget?.focus();\n }\n\n return;\n }\n case ARROW_UP: {\n event.preventDefault();\n event.stopPropagation();\n\n const prevSiblingChildren = (target.previousElementSibling as SidebarElement)?._childElements;\n const lastChild = prevSiblingChildren ? prevSiblingChildren[prevSiblingChildren?.length - 1] : null;\n const isChildHidden = lastChild?._hidden;\n\n const childElement = !isChildHidden ? lastChild : null;\n const prevElement = childElement || target.previousElementSibling || target.parentElement;\n\n if (prevElement?.shadowRoot) {\n const focusTarget = prevElement.shadowRoot.querySelector(\"[tabindex]\") as HTMLElement | null;\n focusTarget?.focus();\n }\n return;\n }\n case ARROW_LEFT: {\n event.preventDefault();\n event.stopPropagation();\n\n if (this._sidebarActiveGroup === this) {\n // when drawer is open, close it\n if (this._showDrawer) this._handleClick();\n } else {\n // check if we are on the drawer, if so move back to parent\n const childLevel = (target as SidebarElement)._childLevel;\n if (childLevel >= 1 && this._sidebarActiveGroup?.shadowRoot) {\n const focusTarget = this._sidebarActiveGroup.shadowRoot.querySelector(\"[tabindex]\") as HTMLElement | null;\n focusTarget?.focus();\n }\n }\n\n return;\n }\n case ARROW_RIGHT: {\n event.preventDefault();\n event.stopPropagation();\n\n if (this._sidebarActiveGroup === this) {\n if (this._drawerItems?.length) {\n if (this._showDrawer) {\n const drawerItem = this._drawerItems[0];\n if (drawerItem?.shadowRoot) {\n const focusTarget = drawerItem.shadowRoot.querySelector(\"[tabindex]\") as HTMLElement | null;\n focusTarget?.focus();\n }\n } else {\n this._handleClick();\n }\n }\n } else {\n if (this._childLevel === 0 && this._childElements.length > 0) {\n // when there is nested, we trigger click to show drawer\n this._handleClick();\n }\n }\n\n return;\n }\n }\n }\n\n /**\n * Calculates the nesting level by counting parent sgds-sidebar-group ancestors.\n * Level 0 = top-level element, Level 1+ = nested within another group.\n * Updates the _childLevel state property.\n * @internal\n * @returns {void}\n */\n private getChildLevel() {\n let currentEle = this.parentElement;\n let level = 0;\n\n while (currentEle.tagName.toLowerCase() === \"sgds-sidebar-group\") {\n level += 1;\n currentEle = currentEle.parentElement;\n }\n\n const isInDrawer = currentEle.classList.contains(\"sidebar-nested-overlay\");\n this._childLevel = isInDrawer ? level + 1 : level;\n }\n}\n"],"names":["SgdsElement","DropdownElement","__decorate","property","consume","SidebarCollapsed","state","SidebarActiveItem","SidebarActiveGroup","SidebarDrawerItems","SidebarDrawerOpen","queryAssignedElements"],"mappings":"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"}
@@ -1,282 +0,0 @@
1
- 'use client';
2
- import { __decorate } from 'tslib';
3
- import { property, state, queryAssignedElements } from 'lit/decorators.js';
4
- import { DropdownElement } from './dropdown-element.js';
5
- import SgdsElement from './sgds-element.js';
6
- import { consume } from '@lit/context';
7
- import { SidebarCollapsed, SidebarActiveItem, SidebarActiveGroup, SidebarDrawerItems, SidebarDrawerOpen } from '../components/Sidebar/sidebar-context.js';
8
-
9
- const ARROW_DOWN = "ArrowDown";
10
- const ARROW_UP = "ArrowUp";
11
- const ARROW_LEFT = "ArrowLeft";
12
- const ARROW_RIGHT = "ArrowRight";
13
- const ENTER = "Enter";
14
- /**
15
- * @summary Base class for sidebar navigation components.
16
- * Provides core functionality for sidebar items and groups including keyboard navigation,
17
- * selection state management, and nesting support. This class manages hierarchical navigation,
18
- * active state tracking, and drawer overlay coordination through context providers.
19
- *
20
- * Features:
21
- * - Multi-level keyboard navigation (Arrow keys, Enter)
22
- * - Active state management via Lit context subscription
23
- * - Support for nested hierarchies up to 3 levels deep
24
- * - Focus management and full ARIA attribute support
25
- * - Event emission for sidebar coordination (i-sgds-click)
26
- * - Automatic child element tracking and nesting level detection
27
- *
28
- * Keyboard Navigation:
29
- * - Arrow Up/Down: Navigate between siblings in the same level
30
- * - Arrow Left/Right: Navigate hierarchically (collapse/expand or move in drawer)
31
- * - Enter: Activate focused item or toggle group
32
- *
33
- * Context Management:
34
- * - Consumes: SidebarCollapsed, SidebarActiveItem, SidebarActiveGroup, SidebarDrawerItems
35
- * - Updates state based on context changes for responsive UI updates
36
- *
37
- * @internal
38
- */
39
- class SidebarElement extends SgdsElement {
40
- constructor() {
41
- super(...arguments);
42
- /**
43
- * The display title/label for the sidebar element.
44
- * Shown in the UI and used for accessibility labels (aria-label).
45
- * @attribute title
46
- * @type {string}
47
- * @default ""
48
- */
49
- this.title = "";
50
- /**
51
- * The unique name identifier for the sidebar element.
52
- * Used to identify selections in sgds-select events and manage active states.
53
- * Should be unique among siblings in the same navigation level.
54
- * @attribute name
55
- * @type {string}
56
- * @default ""
57
- */
58
- this.name = "";
59
- /** @internal */
60
- this._sidebarCollapsed = false;
61
- /** @internal */
62
- this._sidebarActiveItem = null;
63
- /** @internal */
64
- this._sidebarActiveGroup = null;
65
- /** @internal */
66
- this._drawerItems = null;
67
- /** @internal Tracks whether a drawer overlay is currently open */
68
- this._showDrawer = false;
69
- /** @internal */
70
- this._childLevel = 0;
71
- /**
72
- * Indicates whether this element is currently selected/active.
73
- * @internal
74
- */
75
- this._selected = false;
76
- /**
77
- * Indicates whether this element should be hidden based on nesting context.
78
- * @internal
79
- */
80
- this._hidden = false;
81
- /**
82
- * List of child elements assigned to this component.
83
- * @internal
84
- */
85
- this._childElements = [];
86
- /** @internal */
87
- this._childActive = false;
88
- }
89
- connectedCallback() {
90
- super.connectedCallback();
91
- this.getChildLevel();
92
- this.setAttribute("role", "option");
93
- this.setAttribute("aria-label", this.title || this.name);
94
- this.addEventListener("keydown", this._handleKeyDown);
95
- }
96
- disconnectedCallback() {
97
- super.disconnectedCallback();
98
- this.removeEventListener("keydown", this._handleKeyDown);
99
- }
100
- firstUpdated(changedProperties) {
101
- super.firstUpdated(changedProperties);
102
- this.getChildLevel();
103
- }
104
- updated() {
105
- if (this._childLevel === 1) {
106
- this._hidden = !this.closest(".sidebar-nested-overlay");
107
- }
108
- }
109
- /**
110
- * Handles slot change events and updates child elements list.
111
- * @internal
112
- * @returns {void}
113
- */
114
- _handleSlotChange() {
115
- this._childElements = this._defaultNodes;
116
- }
117
- /**
118
- * Handles click/activation events on the sidebar element.
119
- * Emits internal click event for parent sidebar to handle selection.
120
- * @internal
121
- * @param {SidebarElement} [element] - Optional element parameter (for keyboard compatibility)
122
- * @returns {void}
123
- */
124
- _handleClick() {
125
- this.emit("i-sgds-click", { detail: { element: this, level: this._childLevel } });
126
- }
127
- /**
128
- * Handles keyboard navigation events for sidebar elements.
129
- * Supports Arrow Up/Down for navigation and Arrow Left/Right for drawer management.
130
- * @internal
131
- * @param {KeyboardEvent} event - The keyboard event object
132
- * @returns {void}
133
- */
134
- _handleKeyDown(event) {
135
- var _a, _b, _c;
136
- const target = event.target;
137
- switch (event.key) {
138
- case ENTER: {
139
- event.preventDefault();
140
- event.stopPropagation();
141
- if (event.target === this)
142
- this._handleClick();
143
- return;
144
- }
145
- case ARROW_DOWN: {
146
- event.preventDefault();
147
- event.stopPropagation();
148
- const child = target._childElements[0];
149
- const isChildHidden = child === null || child === void 0 ? void 0 : child._hidden;
150
- const childElement = !isChildHidden ? child : null;
151
- const nextElement = childElement || target.nextElementSibling || target.parentElement.nextElementSibling;
152
- if (nextElement === null || nextElement === void 0 ? void 0 : nextElement.shadowRoot) {
153
- const focusTarget = nextElement.shadowRoot.querySelector("[tabindex]");
154
- focusTarget === null || focusTarget === void 0 ? void 0 : focusTarget.focus();
155
- }
156
- return;
157
- }
158
- case ARROW_UP: {
159
- event.preventDefault();
160
- event.stopPropagation();
161
- const prevSiblingChildren = (_a = target.previousElementSibling) === null || _a === void 0 ? void 0 : _a._childElements;
162
- const lastChild = prevSiblingChildren ? prevSiblingChildren[(prevSiblingChildren === null || prevSiblingChildren === void 0 ? void 0 : prevSiblingChildren.length) - 1] : null;
163
- const isChildHidden = lastChild === null || lastChild === void 0 ? void 0 : lastChild._hidden;
164
- const childElement = !isChildHidden ? lastChild : null;
165
- const prevElement = childElement || target.previousElementSibling || target.parentElement;
166
- if (prevElement === null || prevElement === void 0 ? void 0 : prevElement.shadowRoot) {
167
- const focusTarget = prevElement.shadowRoot.querySelector("[tabindex]");
168
- focusTarget === null || focusTarget === void 0 ? void 0 : focusTarget.focus();
169
- }
170
- return;
171
- }
172
- case ARROW_LEFT: {
173
- event.preventDefault();
174
- event.stopPropagation();
175
- if (this._sidebarActiveGroup === this) {
176
- // when drawer is open, close it
177
- if (this._showDrawer)
178
- this._handleClick();
179
- }
180
- else {
181
- // check if we are on the drawer, if so move back to parent
182
- const childLevel = target._childLevel;
183
- if (childLevel >= 1 && ((_b = this._sidebarActiveGroup) === null || _b === void 0 ? void 0 : _b.shadowRoot)) {
184
- const focusTarget = this._sidebarActiveGroup.shadowRoot.querySelector("[tabindex]");
185
- focusTarget === null || focusTarget === void 0 ? void 0 : focusTarget.focus();
186
- }
187
- }
188
- return;
189
- }
190
- case ARROW_RIGHT: {
191
- event.preventDefault();
192
- event.stopPropagation();
193
- if (this._sidebarActiveGroup === this) {
194
- if ((_c = this._drawerItems) === null || _c === void 0 ? void 0 : _c.length) {
195
- if (this._showDrawer) {
196
- const drawerItem = this._drawerItems[0];
197
- if (drawerItem === null || drawerItem === void 0 ? void 0 : drawerItem.shadowRoot) {
198
- const focusTarget = drawerItem.shadowRoot.querySelector("[tabindex]");
199
- focusTarget === null || focusTarget === void 0 ? void 0 : focusTarget.focus();
200
- }
201
- }
202
- else {
203
- this._handleClick();
204
- }
205
- }
206
- }
207
- else {
208
- if (this._childLevel === 0 && this._childElements.length > 0) {
209
- // when there is nested, we trigger click to show drawer
210
- this._handleClick();
211
- }
212
- }
213
- return;
214
- }
215
- }
216
- }
217
- /**
218
- * Calculates the nesting level by counting parent sgds-sidebar-group ancestors.
219
- * Level 0 = top-level element, Level 1+ = nested within another group.
220
- * Updates the _childLevel state property.
221
- * @internal
222
- * @returns {void}
223
- */
224
- getChildLevel() {
225
- let currentEle = this.parentElement;
226
- let level = 0;
227
- while (currentEle.tagName.toLowerCase() === "sgds-sidebar-group") {
228
- level += 1;
229
- currentEle = currentEle.parentElement;
230
- }
231
- const isInDrawer = currentEle.classList.contains("sidebar-nested-overlay");
232
- this._childLevel = isInDrawer ? level + 1 : level;
233
- }
234
- }
235
- SidebarElement.styles = DropdownElement.styles;
236
- __decorate([
237
- property({ type: String, reflect: true })
238
- ], SidebarElement.prototype, "title", void 0);
239
- __decorate([
240
- property({ type: String, reflect: true })
241
- ], SidebarElement.prototype, "name", void 0);
242
- __decorate([
243
- consume({ context: SidebarCollapsed, subscribe: true }),
244
- state()
245
- ], SidebarElement.prototype, "_sidebarCollapsed", void 0);
246
- __decorate([
247
- consume({ context: SidebarActiveItem, subscribe: true }),
248
- state()
249
- ], SidebarElement.prototype, "_sidebarActiveItem", void 0);
250
- __decorate([
251
- consume({ context: SidebarActiveGroup, subscribe: true }),
252
- state()
253
- ], SidebarElement.prototype, "_sidebarActiveGroup", void 0);
254
- __decorate([
255
- consume({ context: SidebarDrawerItems, subscribe: true }),
256
- state()
257
- ], SidebarElement.prototype, "_drawerItems", void 0);
258
- __decorate([
259
- consume({ context: SidebarDrawerOpen, subscribe: true }),
260
- state()
261
- ], SidebarElement.prototype, "_showDrawer", void 0);
262
- __decorate([
263
- state()
264
- ], SidebarElement.prototype, "_childLevel", void 0);
265
- __decorate([
266
- state()
267
- ], SidebarElement.prototype, "_selected", void 0);
268
- __decorate([
269
- state()
270
- ], SidebarElement.prototype, "_hidden", void 0);
271
- __decorate([
272
- state()
273
- ], SidebarElement.prototype, "_childElements", void 0);
274
- __decorate([
275
- state()
276
- ], SidebarElement.prototype, "_childActive", void 0);
277
- __decorate([
278
- queryAssignedElements({ flatten: true })
279
- ], SidebarElement.prototype, "_defaultNodes", void 0);
280
-
281
- export { SidebarElement };
282
- //# sourceMappingURL=sidebar-element.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sidebar-element.js","sources":["../../../src/base/sidebar-element.ts"],"sourcesContent":["import { property, queryAssignedElements, state } from \"lit/decorators.js\";\nimport { DropdownElement } from \"./dropdown-element\";\nimport { PropertyValueMap } from \"lit\";\nimport SgdsElement from \"./sgds-element\";\nimport { consume } from \"@lit/context\";\nimport {\n SidebarActiveGroup,\n SidebarActiveItem,\n SidebarCollapsed,\n SidebarDrawerItems,\n SidebarDrawerOpen\n} from \"../components/Sidebar/sidebar-context\";\n\nconst ARROW_DOWN = \"ArrowDown\";\nconst ARROW_UP = \"ArrowUp\";\nconst ARROW_LEFT = \"ArrowLeft\";\nconst ARROW_RIGHT = \"ArrowRight\";\nconst ENTER = \"Enter\";\n\n/**\n * @summary Base class for sidebar navigation components.\n * Provides core functionality for sidebar items and groups including keyboard navigation,\n * selection state management, and nesting support. This class manages hierarchical navigation,\n * active state tracking, and drawer overlay coordination through context providers.\n *\n * Features:\n * - Multi-level keyboard navigation (Arrow keys, Enter)\n * - Active state management via Lit context subscription\n * - Support for nested hierarchies up to 3 levels deep\n * - Focus management and full ARIA attribute support\n * - Event emission for sidebar coordination (i-sgds-click)\n * - Automatic child element tracking and nesting level detection\n *\n * Keyboard Navigation:\n * - Arrow Up/Down: Navigate between siblings in the same level\n * - Arrow Left/Right: Navigate hierarchically (collapse/expand or move in drawer)\n * - Enter: Activate focused item or toggle group\n *\n * Context Management:\n * - Consumes: SidebarCollapsed, SidebarActiveItem, SidebarActiveGroup, SidebarDrawerItems\n * - Updates state based on context changes for responsive UI updates\n *\n * @internal\n */\nexport class SidebarElement extends SgdsElement {\n static styles = DropdownElement.styles;\n\n /**\n * The display title/label for the sidebar element.\n * Shown in the UI and used for accessibility labels (aria-label).\n * @attribute title\n * @type {string}\n * @default \"\"\n */\n @property({ type: String, reflect: true }) title = \"\";\n\n /**\n * The unique name identifier for the sidebar element.\n * Used to identify selections in sgds-select events and manage active states.\n * Should be unique among siblings in the same navigation level.\n * @attribute name\n * @type {string}\n * @default \"\"\n */\n @property({ type: String, reflect: true }) name = \"\";\n\n /** @internal */\n @consume({ context: SidebarCollapsed, subscribe: true })\n @state()\n _sidebarCollapsed = false;\n\n /** @internal */\n @consume({ context: SidebarActiveItem, subscribe: true })\n @state()\n _sidebarActiveItem: SidebarElement | null = null;\n\n /** @internal */\n @consume({ context: SidebarActiveGroup, subscribe: true })\n @state()\n _sidebarActiveGroup: SidebarElement | null = null;\n\n /** @internal */\n @consume({ context: SidebarDrawerItems, subscribe: true })\n @state()\n _drawerItems: SidebarElement[] | null = null;\n\n /** @internal Tracks whether a drawer overlay is currently open */\n @consume({ context: SidebarDrawerOpen, subscribe: true })\n @state()\n _showDrawer = false;\n\n /** @internal */\n @state() _childLevel = 0;\n\n /**\n * Indicates whether this element is currently selected/active.\n * @internal\n */\n @state() _selected = false;\n\n /**\n * Indicates whether this element should be hidden based on nesting context.\n * @internal\n */\n @state() _hidden = false;\n\n /**\n * List of child elements assigned to this component.\n * @internal\n */\n @state()\n _childElements: SidebarElement[] = [];\n\n /** @internal */\n @state() _childActive = false;\n\n /** @internal */\n @queryAssignedElements({ flatten: true })\n private _defaultNodes!: SidebarElement[];\n\n connectedCallback() {\n super.connectedCallback();\n this.getChildLevel();\n this.setAttribute(\"role\", \"option\");\n this.setAttribute(\"aria-label\", this.title || this.name);\n this.addEventListener(\"keydown\", this._handleKeyDown);\n }\n\n disconnectedCallback() {\n super.disconnectedCallback();\n this.removeEventListener(\"keydown\", this._handleKeyDown);\n }\n\n firstUpdated(changedProperties: PropertyValueMap<this>) {\n super.firstUpdated(changedProperties);\n this.getChildLevel();\n }\n\n updated() {\n if (this._childLevel === 1) {\n this._hidden = !this.closest(\".sidebar-nested-overlay\");\n }\n }\n\n /**\n * Handles slot change events and updates child elements list.\n * @internal\n * @returns {void}\n */\n _handleSlotChange() {\n this._childElements = this._defaultNodes;\n }\n\n /**\n * Handles click/activation events on the sidebar element.\n * Emits internal click event for parent sidebar to handle selection.\n * @internal\n * @param {SidebarElement} [element] - Optional element parameter (for keyboard compatibility)\n * @returns {void}\n */\n _handleClick() {\n this.emit(\"i-sgds-click\", { detail: { element: this, level: this._childLevel } });\n }\n\n /**\n * Handles keyboard navigation events for sidebar elements.\n * Supports Arrow Up/Down for navigation and Arrow Left/Right for drawer management.\n * @internal\n * @param {KeyboardEvent} event - The keyboard event object\n * @returns {void}\n */\n private _handleKeyDown(event: KeyboardEvent) {\n const target = event.target as HTMLElement;\n\n switch (event.key) {\n case ENTER: {\n event.preventDefault();\n event.stopPropagation();\n if (event.target === this) this._handleClick();\n return;\n }\n case ARROW_DOWN: {\n event.preventDefault();\n event.stopPropagation();\n\n const child = (target as SidebarElement)._childElements[0];\n\n const isChildHidden = child?._hidden;\n const childElement = !isChildHidden ? child : null;\n const nextElement = childElement || target.nextElementSibling || target.parentElement.nextElementSibling;\n\n if (nextElement?.shadowRoot) {\n const focusTarget = nextElement.shadowRoot.querySelector(\"[tabindex]\") as HTMLElement | null;\n focusTarget?.focus();\n }\n\n return;\n }\n case ARROW_UP: {\n event.preventDefault();\n event.stopPropagation();\n\n const prevSiblingChildren = (target.previousElementSibling as SidebarElement)?._childElements;\n const lastChild = prevSiblingChildren ? prevSiblingChildren[prevSiblingChildren?.length - 1] : null;\n const isChildHidden = lastChild?._hidden;\n\n const childElement = !isChildHidden ? lastChild : null;\n const prevElement = childElement || target.previousElementSibling || target.parentElement;\n\n if (prevElement?.shadowRoot) {\n const focusTarget = prevElement.shadowRoot.querySelector(\"[tabindex]\") as HTMLElement | null;\n focusTarget?.focus();\n }\n return;\n }\n case ARROW_LEFT: {\n event.preventDefault();\n event.stopPropagation();\n\n if (this._sidebarActiveGroup === this) {\n // when drawer is open, close it\n if (this._showDrawer) this._handleClick();\n } else {\n // check if we are on the drawer, if so move back to parent\n const childLevel = (target as SidebarElement)._childLevel;\n if (childLevel >= 1 && this._sidebarActiveGroup?.shadowRoot) {\n const focusTarget = this._sidebarActiveGroup.shadowRoot.querySelector(\"[tabindex]\") as HTMLElement | null;\n focusTarget?.focus();\n }\n }\n\n return;\n }\n case ARROW_RIGHT: {\n event.preventDefault();\n event.stopPropagation();\n\n if (this._sidebarActiveGroup === this) {\n if (this._drawerItems?.length) {\n if (this._showDrawer) {\n const drawerItem = this._drawerItems[0];\n if (drawerItem?.shadowRoot) {\n const focusTarget = drawerItem.shadowRoot.querySelector(\"[tabindex]\") as HTMLElement | null;\n focusTarget?.focus();\n }\n } else {\n this._handleClick();\n }\n }\n } else {\n if (this._childLevel === 0 && this._childElements.length > 0) {\n // when there is nested, we trigger click to show drawer\n this._handleClick();\n }\n }\n\n return;\n }\n }\n }\n\n /**\n * Calculates the nesting level by counting parent sgds-sidebar-group ancestors.\n * Level 0 = top-level element, Level 1+ = nested within another group.\n * Updates the _childLevel state property.\n * @internal\n * @returns {void}\n */\n private getChildLevel() {\n let currentEle = this.parentElement;\n let level = 0;\n\n while (currentEle.tagName.toLowerCase() === \"sgds-sidebar-group\") {\n level += 1;\n currentEle = currentEle.parentElement;\n }\n\n const isInDrawer = currentEle.classList.contains(\"sidebar-nested-overlay\");\n this._childLevel = isInDrawer ? level + 1 : level;\n }\n}\n"],"names":[],"mappings":";;;;;;;;AAaA,MAAM,UAAU,GAAG,WAAW,CAAC;AAC/B,MAAM,QAAQ,GAAG,SAAS,CAAC;AAC3B,MAAM,UAAU,GAAG,WAAW,CAAC;AAC/B,MAAM,WAAW,GAAG,YAAY,CAAC;AACjC,MAAM,KAAK,GAAG,OAAO,CAAC;AAEtB;;;;;;;;;;;;;;;;;;;;;;;;AAwBG;AACG,MAAO,cAAe,SAAQ,WAAW,CAAA;AAA/C,IAAA,WAAA,GAAA;;AAGE;;;;;;AAMG;QACwC,IAAK,CAAA,KAAA,GAAG,EAAE,CAAC;AAEtD;;;;;;;AAOG;QACwC,IAAI,CAAA,IAAA,GAAG,EAAE,CAAC;;QAKrD,IAAiB,CAAA,iBAAA,GAAG,KAAK,CAAC;;QAK1B,IAAkB,CAAA,kBAAA,GAA0B,IAAI,CAAC;;QAKjD,IAAmB,CAAA,mBAAA,GAA0B,IAAI,CAAC;;QAKlD,IAAY,CAAA,YAAA,GAA4B,IAAI,CAAC;;QAK7C,IAAW,CAAA,WAAA,GAAG,KAAK,CAAC;;QAGX,IAAW,CAAA,WAAA,GAAG,CAAC,CAAC;AAEzB;;;AAGG;QACM,IAAS,CAAA,SAAA,GAAG,KAAK,CAAC;AAE3B;;;AAGG;QACM,IAAO,CAAA,OAAA,GAAG,KAAK,CAAC;AAEzB;;;AAGG;QAEH,IAAc,CAAA,cAAA,GAAqB,EAAE,CAAC;;QAG7B,IAAY,CAAA,YAAA,GAAG,KAAK,CAAC;KAsK/B;IAhKC,iBAAiB,GAAA;QACf,KAAK,CAAC,iBAAiB,EAAE,CAAC;QAC1B,IAAI,CAAC,aAAa,EAAE,CAAC;AACrB,QAAA,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;AACpC,QAAA,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC;QACzD,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;KACvD;IAED,oBAAoB,GAAA;QAClB,KAAK,CAAC,oBAAoB,EAAE,CAAC;QAC7B,IAAI,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;KAC1D;AAED,IAAA,YAAY,CAAC,iBAAyC,EAAA;AACpD,QAAA,KAAK,CAAC,YAAY,CAAC,iBAAiB,CAAC,CAAC;QACtC,IAAI,CAAC,aAAa,EAAE,CAAC;KACtB;IAED,OAAO,GAAA;AACL,QAAA,IAAI,IAAI,CAAC,WAAW,KAAK,CAAC,EAAE;YAC1B,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,yBAAyB,CAAC,CAAC;SACzD;KACF;AAED;;;;AAIG;IACH,iBAAiB,GAAA;AACf,QAAA,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,aAAa,CAAC;KAC1C;AAED;;;;;;AAMG;IACH,YAAY,GAAA;QACV,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,MAAM,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;KACnF;AAED;;;;;;AAMG;AACK,IAAA,cAAc,CAAC,KAAoB,EAAA;;AACzC,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,MAAqB,CAAC;AAE3C,QAAA,QAAQ,KAAK,CAAC,GAAG;YACf,KAAK,KAAK,EAAE;gBACV,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,KAAK,CAAC,eAAe,EAAE,CAAC;AACxB,gBAAA,IAAI,KAAK,CAAC,MAAM,KAAK,IAAI;oBAAE,IAAI,CAAC,YAAY,EAAE,CAAC;gBAC/C,OAAO;aACR;YACD,KAAK,UAAU,EAAE;gBACf,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,KAAK,CAAC,eAAe,EAAE,CAAC;gBAExB,MAAM,KAAK,GAAI,MAAyB,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;gBAE3D,MAAM,aAAa,GAAG,KAAK,KAAA,IAAA,IAAL,KAAK,KAAL,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,KAAK,CAAE,OAAO,CAAC;AACrC,gBAAA,MAAM,YAAY,GAAG,CAAC,aAAa,GAAG,KAAK,GAAG,IAAI,CAAC;AACnD,gBAAA,MAAM,WAAW,GAAG,YAAY,IAAI,MAAM,CAAC,kBAAkB,IAAI,MAAM,CAAC,aAAa,CAAC,kBAAkB,CAAC;gBAEzG,IAAI,WAAW,aAAX,WAAW,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAX,WAAW,CAAE,UAAU,EAAE;oBAC3B,MAAM,WAAW,GAAG,WAAW,CAAC,UAAU,CAAC,aAAa,CAAC,YAAY,CAAuB,CAAC;AAC7F,oBAAA,WAAW,aAAX,WAAW,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAX,WAAW,CAAE,KAAK,EAAE,CAAC;iBACtB;gBAED,OAAO;aACR;YACD,KAAK,QAAQ,EAAE;gBACb,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,KAAK,CAAC,eAAe,EAAE,CAAC;gBAExB,MAAM,mBAAmB,GAAG,CAAC,EAAA,GAAA,MAAM,CAAC,sBAAyC,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAE,cAAc,CAAC;gBAC9F,MAAM,SAAS,GAAG,mBAAmB,GAAG,mBAAmB,CAAC,CAAA,mBAAmB,KAAA,IAAA,IAAnB,mBAAmB,KAAnB,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,mBAAmB,CAAE,MAAM,IAAG,CAAC,CAAC,GAAG,IAAI,CAAC;gBACpG,MAAM,aAAa,GAAG,SAAS,KAAA,IAAA,IAAT,SAAS,KAAT,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,SAAS,CAAE,OAAO,CAAC;AAEzC,gBAAA,MAAM,YAAY,GAAG,CAAC,aAAa,GAAG,SAAS,GAAG,IAAI,CAAC;gBACvD,MAAM,WAAW,GAAG,YAAY,IAAI,MAAM,CAAC,sBAAsB,IAAI,MAAM,CAAC,aAAa,CAAC;gBAE1F,IAAI,WAAW,aAAX,WAAW,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAX,WAAW,CAAE,UAAU,EAAE;oBAC3B,MAAM,WAAW,GAAG,WAAW,CAAC,UAAU,CAAC,aAAa,CAAC,YAAY,CAAuB,CAAC;AAC7F,oBAAA,WAAW,aAAX,WAAW,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAX,WAAW,CAAE,KAAK,EAAE,CAAC;iBACtB;gBACD,OAAO;aACR;YACD,KAAK,UAAU,EAAE;gBACf,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,KAAK,CAAC,eAAe,EAAE,CAAC;AAExB,gBAAA,IAAI,IAAI,CAAC,mBAAmB,KAAK,IAAI,EAAE;;oBAErC,IAAI,IAAI,CAAC,WAAW;wBAAE,IAAI,CAAC,YAAY,EAAE,CAAC;iBAC3C;qBAAM;;AAEL,oBAAA,MAAM,UAAU,GAAI,MAAyB,CAAC,WAAW,CAAC;AAC1D,oBAAA,IAAI,UAAU,IAAI,CAAC,KAAI,CAAA,EAAA,GAAA,IAAI,CAAC,mBAAmB,MAAE,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,UAAU,CAAA,EAAE;AAC3D,wBAAA,MAAM,WAAW,GAAG,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,aAAa,CAAC,YAAY,CAAuB,CAAC;AAC1G,wBAAA,WAAW,aAAX,WAAW,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAX,WAAW,CAAE,KAAK,EAAE,CAAC;qBACtB;iBACF;gBAED,OAAO;aACR;YACD,KAAK,WAAW,EAAE;gBAChB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,KAAK,CAAC,eAAe,EAAE,CAAC;AAExB,gBAAA,IAAI,IAAI,CAAC,mBAAmB,KAAK,IAAI,EAAE;AACrC,oBAAA,IAAI,MAAA,IAAI,CAAC,YAAY,MAAE,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,MAAM,EAAE;AAC7B,wBAAA,IAAI,IAAI,CAAC,WAAW,EAAE;4BACpB,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;4BACxC,IAAI,UAAU,aAAV,UAAU,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAV,UAAU,CAAE,UAAU,EAAE;gCAC1B,MAAM,WAAW,GAAG,UAAU,CAAC,UAAU,CAAC,aAAa,CAAC,YAAY,CAAuB,CAAC;AAC5F,gCAAA,WAAW,aAAX,WAAW,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAX,WAAW,CAAE,KAAK,EAAE,CAAC;6BACtB;yBACF;6BAAM;4BACL,IAAI,CAAC,YAAY,EAAE,CAAC;yBACrB;qBACF;iBACF;qBAAM;AACL,oBAAA,IAAI,IAAI,CAAC,WAAW,KAAK,CAAC,IAAI,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE;;wBAE5D,IAAI,CAAC,YAAY,EAAE,CAAC;qBACrB;iBACF;gBAED,OAAO;aACR;SACF;KACF;AAED;;;;;;AAMG;IACK,aAAa,GAAA;AACnB,QAAA,IAAI,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC;QACpC,IAAI,KAAK,GAAG,CAAC,CAAC;QAEd,OAAO,UAAU,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,oBAAoB,EAAE;YAChE,KAAK,IAAI,CAAC,CAAC;AACX,YAAA,UAAU,GAAG,UAAU,CAAC,aAAa,CAAC;SACvC;QAED,MAAM,UAAU,GAAG,UAAU,CAAC,SAAS,CAAC,QAAQ,CAAC,wBAAwB,CAAC,CAAC;AAC3E,QAAA,IAAI,CAAC,WAAW,GAAG,UAAU,GAAG,KAAK,GAAG,CAAC,GAAG,KAAK,CAAC;KACnD;;AA1OM,cAAA,CAAA,MAAM,GAAG,eAAe,CAAC,MAAM,CAAC;AASI,UAAA,CAAA;IAA1C,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;AAAY,CAAA,EAAA,cAAA,CAAA,SAAA,EAAA,OAAA,EAAA,KAAA,CAAA,CAAA,CAAA;AAUX,UAAA,CAAA;IAA1C,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;AAAW,CAAA,EAAA,cAAA,CAAA,SAAA,EAAA,MAAA,EAAA,KAAA,CAAA,CAAA,CAAA;AAKrD,UAAA,CAAA;IAFC,OAAO,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;AACvD,IAAA,KAAK,EAAE;AACkB,CAAA,EAAA,cAAA,CAAA,SAAA,EAAA,mBAAA,EAAA,KAAA,CAAA,CAAA,CAAA;AAK1B,UAAA,CAAA;IAFC,OAAO,CAAC,EAAE,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;AACxD,IAAA,KAAK,EAAE;AACyC,CAAA,EAAA,cAAA,CAAA,SAAA,EAAA,oBAAA,EAAA,KAAA,CAAA,CAAA,CAAA;AAKjD,UAAA,CAAA;IAFC,OAAO,CAAC,EAAE,OAAO,EAAE,kBAAkB,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;AACzD,IAAA,KAAK,EAAE;AAC0C,CAAA,EAAA,cAAA,CAAA,SAAA,EAAA,qBAAA,EAAA,KAAA,CAAA,CAAA,CAAA;AAKlD,UAAA,CAAA;IAFC,OAAO,CAAC,EAAE,OAAO,EAAE,kBAAkB,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;AACzD,IAAA,KAAK,EAAE;AACqC,CAAA,EAAA,cAAA,CAAA,SAAA,EAAA,cAAA,EAAA,KAAA,CAAA,CAAA,CAAA;AAK7C,UAAA,CAAA;IAFC,OAAO,CAAC,EAAE,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;AACxD,IAAA,KAAK,EAAE;AACY,CAAA,EAAA,cAAA,CAAA,SAAA,EAAA,aAAA,EAAA,KAAA,CAAA,CAAA,CAAA;AAGX,UAAA,CAAA;AAAR,IAAA,KAAK,EAAE;AAAiB,CAAA,EAAA,cAAA,CAAA,SAAA,EAAA,aAAA,EAAA,KAAA,CAAA,CAAA,CAAA;AAMhB,UAAA,CAAA;AAAR,IAAA,KAAK,EAAE;AAAmB,CAAA,EAAA,cAAA,CAAA,SAAA,EAAA,WAAA,EAAA,KAAA,CAAA,CAAA,CAAA;AAMlB,UAAA,CAAA;AAAR,IAAA,KAAK,EAAE;AAAiB,CAAA,EAAA,cAAA,CAAA,SAAA,EAAA,SAAA,EAAA,KAAA,CAAA,CAAA,CAAA;AAOzB,UAAA,CAAA;AADC,IAAA,KAAK,EAAE;AAC8B,CAAA,EAAA,cAAA,CAAA,SAAA,EAAA,gBAAA,EAAA,KAAA,CAAA,CAAA,CAAA;AAG7B,UAAA,CAAA;AAAR,IAAA,KAAK,EAAE;AAAsB,CAAA,EAAA,cAAA,CAAA,SAAA,EAAA,cAAA,EAAA,KAAA,CAAA,CAAA,CAAA;AAItB,UAAA,CAAA;AADP,IAAA,qBAAqB,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;AACA,CAAA,EAAA,cAAA,CAAA,SAAA,EAAA,eAAA,EAAA,KAAA,CAAA,CAAA;;;;"}