@govtechsg/sgds-web-component 3.11.0 → 3.12.0-rc.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (163) hide show
  1. package/base/sidebar-element.d.ts +112 -0
  2. package/base/sidebar-element.js +281 -0
  3. package/base/sidebar-element.js.map +1 -0
  4. package/components/Checkbox/index.umd.min.js +6 -6
  5. package/components/Checkbox/index.umd.min.js.map +1 -1
  6. package/components/ComboBox/index.umd.min.js +240 -240
  7. package/components/ComboBox/index.umd.min.js.map +1 -1
  8. package/components/Datepicker/index.umd.min.js +22 -22
  9. package/components/Datepicker/index.umd.min.js.map +1 -1
  10. package/components/FileUpload/index.umd.min.js +8 -8
  11. package/components/FileUpload/index.umd.min.js.map +1 -1
  12. package/components/Input/index.umd.min.js +14 -14
  13. package/components/Input/index.umd.min.js.map +1 -1
  14. package/components/Input/sgds-input.d.ts +1 -0
  15. package/components/Input/sgds-input.js +1 -4
  16. package/components/Input/sgds-input.js.map +1 -1
  17. package/components/Modal/index.umd.min.js.map +1 -1
  18. package/components/Modal/sgds-modal.d.ts +1 -1
  19. package/components/Modal/sgds-modal.js +1 -1
  20. package/components/Modal/sgds-modal.js.map +1 -1
  21. package/components/QuantityToggle/index.umd.min.js +2 -2
  22. package/components/QuantityToggle/index.umd.min.js.map +1 -1
  23. package/components/Radio/index.umd.min.js +9 -9
  24. package/components/Radio/index.umd.min.js.map +1 -1
  25. package/components/Select/index.umd.min.js +11 -11
  26. package/components/Select/index.umd.min.js.map +1 -1
  27. package/components/Sidebar/index.d.ts +16 -0
  28. package/components/Sidebar/index.js +10 -0
  29. package/components/Sidebar/index.js.map +1 -0
  30. package/components/Sidebar/index.umd.min.js +2428 -0
  31. package/components/Sidebar/index.umd.min.js.map +1 -0
  32. package/components/Sidebar/sgds-sidebar-group.d.ts +51 -0
  33. package/components/Sidebar/sgds-sidebar-group.js +124 -0
  34. package/components/Sidebar/sgds-sidebar-group.js.map +1 -0
  35. package/components/Sidebar/sgds-sidebar-item.d.ts +25 -0
  36. package/components/Sidebar/sgds-sidebar-item.js +73 -0
  37. package/components/Sidebar/sgds-sidebar-item.js.map +1 -0
  38. package/components/Sidebar/sgds-sidebar-section.d.ts +55 -0
  39. package/components/Sidebar/sgds-sidebar-section.js +122 -0
  40. package/components/Sidebar/sgds-sidebar-section.js.map +1 -0
  41. package/components/Sidebar/sgds-sidebar.d.ts +85 -0
  42. package/components/Sidebar/sgds-sidebar.js +319 -0
  43. package/components/Sidebar/sgds-sidebar.js.map +1 -0
  44. package/components/Sidebar/sidebar-context.d.ts +51 -0
  45. package/components/Sidebar/sidebar-context.js +45 -0
  46. package/components/Sidebar/sidebar-context.js.map +1 -0
  47. package/components/Sidebar/sidebar-item.js +6 -0
  48. package/components/Sidebar/sidebar-item.js.map +1 -0
  49. package/components/Sidebar/sidebar-section.js +6 -0
  50. package/components/Sidebar/sidebar-section.js.map +1 -0
  51. package/components/Sidebar/sidebar.js +6 -0
  52. package/components/Sidebar/sidebar.js.map +1 -0
  53. package/components/Tab/index.umd.min.js.map +1 -1
  54. package/components/Tab/sgds-tab-group.d.ts +2 -2
  55. package/components/Tab/sgds-tab-group.js +2 -2
  56. package/components/Tab/sgds-tab-group.js.map +1 -1
  57. package/components/Textarea/index.umd.min.js +6 -6
  58. package/components/Textarea/index.umd.min.js.map +1 -1
  59. package/components/Textarea/sgds-textarea.d.ts +2 -0
  60. package/components/Textarea/sgds-textarea.js +14 -2
  61. package/components/Textarea/sgds-textarea.js.map +1 -1
  62. package/components/index.d.ts +1 -0
  63. package/components/index.js +1 -0
  64. package/components/index.js.map +1 -1
  65. package/components/index.umd.min.js +84 -49
  66. package/components/index.umd.min.js.map +1 -1
  67. package/css/fouc.css +6 -2
  68. package/css/utility.css +21 -1
  69. package/index.d.ts +1 -0
  70. package/index.js +1 -0
  71. package/index.js.map +1 -1
  72. package/index.umd.min.js +173 -62
  73. package/index.umd.min.js.map +1 -1
  74. package/package.json +1 -1
  75. package/react/base/sidebar-element.cjs.js +286 -0
  76. package/react/base/sidebar-element.cjs.js.map +1 -0
  77. package/react/base/sidebar-element.js +282 -0
  78. package/react/base/sidebar-element.js.map +1 -0
  79. package/react/components/Input/sgds-input.cjs.js +1 -4
  80. package/react/components/Input/sgds-input.cjs.js.map +1 -1
  81. package/react/components/Input/sgds-input.js +1 -4
  82. package/react/components/Input/sgds-input.js.map +1 -1
  83. package/react/components/Modal/sgds-modal.cjs.js +1 -1
  84. package/react/components/Modal/sgds-modal.cjs.js.map +1 -1
  85. package/react/components/Modal/sgds-modal.js +1 -1
  86. package/react/components/Modal/sgds-modal.js.map +1 -1
  87. package/react/components/Sidebar/sgds-sidebar-group.cjs.js +130 -0
  88. package/react/components/Sidebar/sgds-sidebar-group.cjs.js.map +1 -0
  89. package/react/components/Sidebar/sgds-sidebar-group.js +125 -0
  90. package/react/components/Sidebar/sgds-sidebar-group.js.map +1 -0
  91. package/react/components/Sidebar/sgds-sidebar-item.cjs.js +79 -0
  92. package/react/components/Sidebar/sgds-sidebar-item.cjs.js.map +1 -0
  93. package/react/components/Sidebar/sgds-sidebar-item.js +74 -0
  94. package/react/components/Sidebar/sgds-sidebar-item.js.map +1 -0
  95. package/react/components/Sidebar/sgds-sidebar-section.cjs.js +128 -0
  96. package/react/components/Sidebar/sgds-sidebar-section.cjs.js.map +1 -0
  97. package/react/components/Sidebar/sgds-sidebar-section.js +123 -0
  98. package/react/components/Sidebar/sgds-sidebar-section.js.map +1 -0
  99. package/react/components/Sidebar/sgds-sidebar.cjs.js +325 -0
  100. package/react/components/Sidebar/sgds-sidebar.cjs.js.map +1 -0
  101. package/react/components/Sidebar/sgds-sidebar.js +320 -0
  102. package/react/components/Sidebar/sgds-sidebar.js.map +1 -0
  103. package/react/components/Sidebar/sidebar-context.cjs.js +54 -0
  104. package/react/components/Sidebar/sidebar-context.cjs.js.map +1 -0
  105. package/react/components/Sidebar/sidebar-context.js +46 -0
  106. package/react/components/Sidebar/sidebar-context.js.map +1 -0
  107. package/react/components/Sidebar/sidebar-item.cjs.js +11 -0
  108. package/react/components/Sidebar/sidebar-item.cjs.js.map +1 -0
  109. package/react/components/Sidebar/sidebar-item.js +7 -0
  110. package/react/components/Sidebar/sidebar-item.js.map +1 -0
  111. package/react/components/Sidebar/sidebar-section.cjs.js +11 -0
  112. package/react/components/Sidebar/sidebar-section.cjs.js.map +1 -0
  113. package/react/components/Sidebar/sidebar-section.js +7 -0
  114. package/react/components/Sidebar/sidebar-section.js.map +1 -0
  115. package/react/components/Sidebar/sidebar.cjs.js +11 -0
  116. package/react/components/Sidebar/sidebar.cjs.js.map +1 -0
  117. package/react/components/Sidebar/sidebar.js +7 -0
  118. package/react/components/Sidebar/sidebar.js.map +1 -0
  119. package/react/components/Tab/sgds-tab-group.cjs.js +2 -2
  120. package/react/components/Tab/sgds-tab-group.cjs.js.map +1 -1
  121. package/react/components/Tab/sgds-tab-group.js +2 -2
  122. package/react/components/Tab/sgds-tab-group.js.map +1 -1
  123. package/react/components/Textarea/sgds-textarea.cjs.js +14 -2
  124. package/react/components/Textarea/sgds-textarea.cjs.js.map +1 -1
  125. package/react/components/Textarea/sgds-textarea.js +14 -2
  126. package/react/components/Textarea/sgds-textarea.js.map +1 -1
  127. package/react/index.cjs.js +68 -60
  128. package/react/index.cjs.js.map +1 -1
  129. package/react/index.d.ts +6 -2
  130. package/react/index.js +6 -2
  131. package/react/index.js.map +1 -1
  132. package/react/sidebar/index.cjs.js +40 -0
  133. package/react/sidebar/index.cjs.js.map +1 -0
  134. package/react/sidebar/index.d.ts +2 -0
  135. package/react/sidebar/index.js +16 -0
  136. package/react/sidebar/index.js.map +1 -0
  137. package/react/sidebar-group/index.cjs.js +40 -0
  138. package/react/sidebar-group/index.cjs.js.map +1 -0
  139. package/react/sidebar-group/index.d.ts +2 -0
  140. package/react/sidebar-group/index.js +16 -0
  141. package/react/sidebar-group/index.js.map +1 -0
  142. package/react/sidebar-item/index.cjs.js +40 -0
  143. package/react/sidebar-item/index.cjs.js.map +1 -0
  144. package/react/sidebar-item/index.d.ts +2 -0
  145. package/react/sidebar-item/index.js +16 -0
  146. package/react/sidebar-item/index.js.map +1 -0
  147. package/react/sidebar-section/index.cjs.js +40 -0
  148. package/react/sidebar-section/index.cjs.js.map +1 -0
  149. package/react/sidebar-section/index.d.ts +2 -0
  150. package/react/sidebar-section/index.js +16 -0
  151. package/react/sidebar-section/index.js.map +1 -0
  152. package/react/utils/inputValidationController.cjs.js +2 -1
  153. package/react/utils/inputValidationController.cjs.js.map +1 -1
  154. package/react/utils/inputValidationController.js +2 -1
  155. package/react/utils/inputValidationController.js.map +1 -1
  156. package/react/utils/validatorMixin.cjs.js +24 -6
  157. package/react/utils/validatorMixin.cjs.js.map +1 -1
  158. package/react/utils/validatorMixin.js +24 -6
  159. package/react/utils/validatorMixin.js.map +1 -1
  160. package/utils/inputValidationController.js +2 -1
  161. package/utils/inputValidationController.js.map +1 -1
  162. package/utils/validatorMixin.js +24 -6
  163. package/utils/validatorMixin.js.map +1 -1
@@ -0,0 +1,112 @@
1
+ import { PropertyValueMap } from "lit";
2
+ import SgdsElement from "./sgds-element";
3
+ /**
4
+ * @summary Base class for sidebar navigation components.
5
+ * Provides core functionality for sidebar items and groups including keyboard navigation,
6
+ * selection state management, and nesting support. This class manages hierarchical navigation,
7
+ * active state tracking, and drawer overlay coordination through context providers.
8
+ *
9
+ * Features:
10
+ * - Multi-level keyboard navigation (Arrow keys, Enter)
11
+ * - Active state management via Lit context subscription
12
+ * - Support for nested hierarchies up to 3 levels deep
13
+ * - Focus management and full ARIA attribute support
14
+ * - Event emission for sidebar coordination (i-sgds-click)
15
+ * - Automatic child element tracking and nesting level detection
16
+ *
17
+ * Keyboard Navigation:
18
+ * - Arrow Up/Down: Navigate between siblings in the same level
19
+ * - Arrow Left/Right: Navigate hierarchically (collapse/expand or move in drawer)
20
+ * - Enter: Activate focused item or toggle group
21
+ *
22
+ * Context Management:
23
+ * - Consumes: SidebarCollapsed, SidebarActiveItem, SidebarActiveGroup, SidebarDrawerItems
24
+ * - Updates state based on context changes for responsive UI updates
25
+ *
26
+ * @internal
27
+ */
28
+ export declare class SidebarElement extends SgdsElement {
29
+ static styles: import("lit").CSSResult[];
30
+ /**
31
+ * The display title/label for the sidebar element.
32
+ * Shown in the UI and used for accessibility labels (aria-label).
33
+ * @attribute title
34
+ * @type {string}
35
+ * @default ""
36
+ */
37
+ title: string;
38
+ /**
39
+ * The unique name identifier for the sidebar element.
40
+ * Used to identify selections in sgds-select events and manage active states.
41
+ * Should be unique among siblings in the same navigation level.
42
+ * @attribute name
43
+ * @type {string}
44
+ * @default ""
45
+ */
46
+ name: string;
47
+ /** @internal */
48
+ _sidebarCollapsed: boolean;
49
+ /** @internal */
50
+ _sidebarActiveItem: SidebarElement | null;
51
+ /** @internal */
52
+ _sidebarActiveGroup: SidebarElement | null;
53
+ /** @internal */
54
+ _drawerItems: SidebarElement[] | null;
55
+ /** @internal Tracks whether a drawer overlay is currently open */
56
+ _showDrawer: boolean;
57
+ /** @internal */
58
+ _childLevel: number;
59
+ /**
60
+ * Indicates whether this element is currently selected/active.
61
+ * @internal
62
+ */
63
+ _selected: boolean;
64
+ /**
65
+ * Indicates whether this element should be hidden based on nesting context.
66
+ * @internal
67
+ */
68
+ _hidden: boolean;
69
+ /**
70
+ * List of child elements assigned to this component.
71
+ * @internal
72
+ */
73
+ _childElements: SidebarElement[];
74
+ /** @internal */
75
+ _childActive: boolean;
76
+ /** @internal */
77
+ private _defaultNodes;
78
+ connectedCallback(): void;
79
+ disconnectedCallback(): void;
80
+ firstUpdated(changedProperties: PropertyValueMap<this>): void;
81
+ updated(): void;
82
+ /**
83
+ * Handles slot change events and updates child elements list.
84
+ * @internal
85
+ * @returns {void}
86
+ */
87
+ _handleSlotChange(): void;
88
+ /**
89
+ * Handles click/activation events on the sidebar element.
90
+ * Emits internal click event for parent sidebar to handle selection.
91
+ * @internal
92
+ * @param {SidebarElement} [element] - Optional element parameter (for keyboard compatibility)
93
+ * @returns {void}
94
+ */
95
+ _handleClick(): void;
96
+ /**
97
+ * Handles keyboard navigation events for sidebar elements.
98
+ * Supports Arrow Up/Down for navigation and Arrow Left/Right for drawer management.
99
+ * @internal
100
+ * @param {KeyboardEvent} event - The keyboard event object
101
+ * @returns {void}
102
+ */
103
+ private _handleKeyDown;
104
+ /**
105
+ * Calculates the nesting level by counting parent sgds-sidebar-group ancestors.
106
+ * Level 0 = top-level element, Level 1+ = nested within another group.
107
+ * Updates the _childLevel state property.
108
+ * @internal
109
+ * @returns {void}
110
+ */
111
+ private getChildLevel;
112
+ }
@@ -0,0 +1,281 @@
1
+ import { __decorate } from 'tslib';
2
+ import { property, state, queryAssignedElements } from 'lit/decorators.js';
3
+ import { DropdownElement } from './dropdown-element.js';
4
+ import SgdsElement from './sgds-element.js';
5
+ import { consume } from '@lit/context';
6
+ import { SidebarCollapsed, SidebarActiveItem, SidebarActiveGroup, SidebarDrawerItems, SidebarDrawerOpen } from '../components/Sidebar/sidebar-context.js';
7
+
8
+ const ARROW_DOWN = "ArrowDown";
9
+ const ARROW_UP = "ArrowUp";
10
+ const ARROW_LEFT = "ArrowLeft";
11
+ const ARROW_RIGHT = "ArrowRight";
12
+ const ENTER = "Enter";
13
+ /**
14
+ * @summary Base class for sidebar navigation components.
15
+ * Provides core functionality for sidebar items and groups including keyboard navigation,
16
+ * selection state management, and nesting support. This class manages hierarchical navigation,
17
+ * active state tracking, and drawer overlay coordination through context providers.
18
+ *
19
+ * Features:
20
+ * - Multi-level keyboard navigation (Arrow keys, Enter)
21
+ * - Active state management via Lit context subscription
22
+ * - Support for nested hierarchies up to 3 levels deep
23
+ * - Focus management and full ARIA attribute support
24
+ * - Event emission for sidebar coordination (i-sgds-click)
25
+ * - Automatic child element tracking and nesting level detection
26
+ *
27
+ * Keyboard Navigation:
28
+ * - Arrow Up/Down: Navigate between siblings in the same level
29
+ * - Arrow Left/Right: Navigate hierarchically (collapse/expand or move in drawer)
30
+ * - Enter: Activate focused item or toggle group
31
+ *
32
+ * Context Management:
33
+ * - Consumes: SidebarCollapsed, SidebarActiveItem, SidebarActiveGroup, SidebarDrawerItems
34
+ * - Updates state based on context changes for responsive UI updates
35
+ *
36
+ * @internal
37
+ */
38
+ class SidebarElement extends SgdsElement {
39
+ constructor() {
40
+ super(...arguments);
41
+ /**
42
+ * The display title/label for the sidebar element.
43
+ * Shown in the UI and used for accessibility labels (aria-label).
44
+ * @attribute title
45
+ * @type {string}
46
+ * @default ""
47
+ */
48
+ this.title = "";
49
+ /**
50
+ * The unique name identifier for the sidebar element.
51
+ * Used to identify selections in sgds-select events and manage active states.
52
+ * Should be unique among siblings in the same navigation level.
53
+ * @attribute name
54
+ * @type {string}
55
+ * @default ""
56
+ */
57
+ this.name = "";
58
+ /** @internal */
59
+ this._sidebarCollapsed = false;
60
+ /** @internal */
61
+ this._sidebarActiveItem = null;
62
+ /** @internal */
63
+ this._sidebarActiveGroup = null;
64
+ /** @internal */
65
+ this._drawerItems = null;
66
+ /** @internal Tracks whether a drawer overlay is currently open */
67
+ this._showDrawer = false;
68
+ /** @internal */
69
+ this._childLevel = 0;
70
+ /**
71
+ * Indicates whether this element is currently selected/active.
72
+ * @internal
73
+ */
74
+ this._selected = false;
75
+ /**
76
+ * Indicates whether this element should be hidden based on nesting context.
77
+ * @internal
78
+ */
79
+ this._hidden = false;
80
+ /**
81
+ * List of child elements assigned to this component.
82
+ * @internal
83
+ */
84
+ this._childElements = [];
85
+ /** @internal */
86
+ this._childActive = false;
87
+ }
88
+ connectedCallback() {
89
+ super.connectedCallback();
90
+ this.getChildLevel();
91
+ this.setAttribute("role", "option");
92
+ this.setAttribute("aria-label", this.title || this.name);
93
+ this.addEventListener("keydown", this._handleKeyDown);
94
+ }
95
+ disconnectedCallback() {
96
+ super.disconnectedCallback();
97
+ this.removeEventListener("keydown", this._handleKeyDown);
98
+ }
99
+ firstUpdated(changedProperties) {
100
+ super.firstUpdated(changedProperties);
101
+ this.getChildLevel();
102
+ }
103
+ updated() {
104
+ if (this._childLevel === 1) {
105
+ this._hidden = !this.closest(".sidebar-nested-overlay");
106
+ }
107
+ }
108
+ /**
109
+ * Handles slot change events and updates child elements list.
110
+ * @internal
111
+ * @returns {void}
112
+ */
113
+ _handleSlotChange() {
114
+ this._childElements = this._defaultNodes;
115
+ }
116
+ /**
117
+ * Handles click/activation events on the sidebar element.
118
+ * Emits internal click event for parent sidebar to handle selection.
119
+ * @internal
120
+ * @param {SidebarElement} [element] - Optional element parameter (for keyboard compatibility)
121
+ * @returns {void}
122
+ */
123
+ _handleClick() {
124
+ this.emit("i-sgds-click", { detail: { element: this, level: this._childLevel } });
125
+ }
126
+ /**
127
+ * Handles keyboard navigation events for sidebar elements.
128
+ * Supports Arrow Up/Down for navigation and Arrow Left/Right for drawer management.
129
+ * @internal
130
+ * @param {KeyboardEvent} event - The keyboard event object
131
+ * @returns {void}
132
+ */
133
+ _handleKeyDown(event) {
134
+ var _a, _b, _c;
135
+ const target = event.target;
136
+ switch (event.key) {
137
+ case ENTER: {
138
+ event.preventDefault();
139
+ event.stopPropagation();
140
+ if (event.target === this)
141
+ this._handleClick();
142
+ return;
143
+ }
144
+ case ARROW_DOWN: {
145
+ event.preventDefault();
146
+ event.stopPropagation();
147
+ const child = target._childElements[0];
148
+ const isChildHidden = child === null || child === void 0 ? void 0 : child._hidden;
149
+ const childElement = !isChildHidden ? child : null;
150
+ const nextElement = childElement || target.nextElementSibling || target.parentElement.nextElementSibling;
151
+ if (nextElement === null || nextElement === void 0 ? void 0 : nextElement.shadowRoot) {
152
+ const focusTarget = nextElement.shadowRoot.querySelector("[tabindex]");
153
+ focusTarget === null || focusTarget === void 0 ? void 0 : focusTarget.focus();
154
+ }
155
+ return;
156
+ }
157
+ case ARROW_UP: {
158
+ event.preventDefault();
159
+ event.stopPropagation();
160
+ const prevSiblingChildren = (_a = target.previousElementSibling) === null || _a === void 0 ? void 0 : _a._childElements;
161
+ const lastChild = prevSiblingChildren ? prevSiblingChildren[(prevSiblingChildren === null || prevSiblingChildren === void 0 ? void 0 : prevSiblingChildren.length) - 1] : null;
162
+ const isChildHidden = lastChild === null || lastChild === void 0 ? void 0 : lastChild._hidden;
163
+ const childElement = !isChildHidden ? lastChild : null;
164
+ const prevElement = childElement || target.previousElementSibling || target.parentElement;
165
+ if (prevElement === null || prevElement === void 0 ? void 0 : prevElement.shadowRoot) {
166
+ const focusTarget = prevElement.shadowRoot.querySelector("[tabindex]");
167
+ focusTarget === null || focusTarget === void 0 ? void 0 : focusTarget.focus();
168
+ }
169
+ return;
170
+ }
171
+ case ARROW_LEFT: {
172
+ event.preventDefault();
173
+ event.stopPropagation();
174
+ if (this._sidebarActiveGroup === this) {
175
+ // when drawer is open, close it
176
+ if (this._showDrawer)
177
+ this._handleClick();
178
+ }
179
+ else {
180
+ // check if we are on the drawer, if so move back to parent
181
+ const childLevel = target._childLevel;
182
+ if (childLevel >= 1 && ((_b = this._sidebarActiveGroup) === null || _b === void 0 ? void 0 : _b.shadowRoot)) {
183
+ const focusTarget = this._sidebarActiveGroup.shadowRoot.querySelector("[tabindex]");
184
+ focusTarget === null || focusTarget === void 0 ? void 0 : focusTarget.focus();
185
+ }
186
+ }
187
+ return;
188
+ }
189
+ case ARROW_RIGHT: {
190
+ event.preventDefault();
191
+ event.stopPropagation();
192
+ if (this._sidebarActiveGroup === this) {
193
+ if ((_c = this._drawerItems) === null || _c === void 0 ? void 0 : _c.length) {
194
+ if (this._showDrawer) {
195
+ const drawerItem = this._drawerItems[0];
196
+ if (drawerItem === null || drawerItem === void 0 ? void 0 : drawerItem.shadowRoot) {
197
+ const focusTarget = drawerItem.shadowRoot.querySelector("[tabindex]");
198
+ focusTarget === null || focusTarget === void 0 ? void 0 : focusTarget.focus();
199
+ }
200
+ }
201
+ else {
202
+ this._handleClick();
203
+ }
204
+ }
205
+ }
206
+ else {
207
+ if (this._childLevel === 0 && this._childElements.length > 0) {
208
+ // when there is nested, we trigger click to show drawer
209
+ this._handleClick();
210
+ }
211
+ }
212
+ return;
213
+ }
214
+ }
215
+ }
216
+ /**
217
+ * Calculates the nesting level by counting parent sgds-sidebar-group ancestors.
218
+ * Level 0 = top-level element, Level 1+ = nested within another group.
219
+ * Updates the _childLevel state property.
220
+ * @internal
221
+ * @returns {void}
222
+ */
223
+ getChildLevel() {
224
+ let currentEle = this.parentElement;
225
+ let level = 0;
226
+ while (currentEle.tagName.toLowerCase() === "sgds-sidebar-group") {
227
+ level += 1;
228
+ currentEle = currentEle.parentElement;
229
+ }
230
+ const isInDrawer = currentEle.classList.contains("sidebar-nested-overlay");
231
+ this._childLevel = isInDrawer ? level + 1 : level;
232
+ }
233
+ }
234
+ SidebarElement.styles = DropdownElement.styles;
235
+ __decorate([
236
+ property({ type: String, reflect: true })
237
+ ], SidebarElement.prototype, "title", void 0);
238
+ __decorate([
239
+ property({ type: String, reflect: true })
240
+ ], SidebarElement.prototype, "name", void 0);
241
+ __decorate([
242
+ consume({ context: SidebarCollapsed, subscribe: true }),
243
+ state()
244
+ ], SidebarElement.prototype, "_sidebarCollapsed", void 0);
245
+ __decorate([
246
+ consume({ context: SidebarActiveItem, subscribe: true }),
247
+ state()
248
+ ], SidebarElement.prototype, "_sidebarActiveItem", void 0);
249
+ __decorate([
250
+ consume({ context: SidebarActiveGroup, subscribe: true }),
251
+ state()
252
+ ], SidebarElement.prototype, "_sidebarActiveGroup", void 0);
253
+ __decorate([
254
+ consume({ context: SidebarDrawerItems, subscribe: true }),
255
+ state()
256
+ ], SidebarElement.prototype, "_drawerItems", void 0);
257
+ __decorate([
258
+ consume({ context: SidebarDrawerOpen, subscribe: true }),
259
+ state()
260
+ ], SidebarElement.prototype, "_showDrawer", void 0);
261
+ __decorate([
262
+ state()
263
+ ], SidebarElement.prototype, "_childLevel", void 0);
264
+ __decorate([
265
+ state()
266
+ ], SidebarElement.prototype, "_selected", void 0);
267
+ __decorate([
268
+ state()
269
+ ], SidebarElement.prototype, "_hidden", void 0);
270
+ __decorate([
271
+ state()
272
+ ], SidebarElement.prototype, "_childElements", void 0);
273
+ __decorate([
274
+ state()
275
+ ], SidebarElement.prototype, "_childActive", void 0);
276
+ __decorate([
277
+ queryAssignedElements({ flatten: true })
278
+ ], SidebarElement.prototype, "_defaultNodes", void 0);
279
+
280
+ export { SidebarElement };
281
+ //# sourceMappingURL=sidebar-element.js.map
@@ -0,0 +1 @@
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":"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"}