@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.
- package/base/sidebar-element.d.ts +112 -0
- package/base/sidebar-element.js +281 -0
- package/base/sidebar-element.js.map +1 -0
- package/components/Checkbox/index.umd.min.js +6 -6
- package/components/Checkbox/index.umd.min.js.map +1 -1
- package/components/ComboBox/index.umd.min.js +240 -240
- package/components/ComboBox/index.umd.min.js.map +1 -1
- package/components/Datepicker/index.umd.min.js +22 -22
- package/components/Datepicker/index.umd.min.js.map +1 -1
- package/components/FileUpload/index.umd.min.js +8 -8
- package/components/FileUpload/index.umd.min.js.map +1 -1
- package/components/Input/index.umd.min.js +14 -14
- package/components/Input/index.umd.min.js.map +1 -1
- package/components/Input/sgds-input.d.ts +1 -0
- package/components/Input/sgds-input.js +1 -4
- package/components/Input/sgds-input.js.map +1 -1
- package/components/Modal/index.umd.min.js.map +1 -1
- package/components/Modal/sgds-modal.d.ts +1 -1
- package/components/Modal/sgds-modal.js +1 -1
- package/components/Modal/sgds-modal.js.map +1 -1
- package/components/QuantityToggle/index.umd.min.js +2 -2
- package/components/QuantityToggle/index.umd.min.js.map +1 -1
- package/components/Radio/index.umd.min.js +9 -9
- package/components/Radio/index.umd.min.js.map +1 -1
- package/components/Select/index.umd.min.js +11 -11
- package/components/Select/index.umd.min.js.map +1 -1
- package/components/Sidebar/index.d.ts +16 -0
- package/components/Sidebar/index.js +10 -0
- package/components/Sidebar/index.js.map +1 -0
- package/components/Sidebar/index.umd.min.js +2428 -0
- package/components/Sidebar/index.umd.min.js.map +1 -0
- package/components/Sidebar/sgds-sidebar-group.d.ts +51 -0
- package/components/Sidebar/sgds-sidebar-group.js +124 -0
- package/components/Sidebar/sgds-sidebar-group.js.map +1 -0
- package/components/Sidebar/sgds-sidebar-item.d.ts +25 -0
- package/components/Sidebar/sgds-sidebar-item.js +73 -0
- package/components/Sidebar/sgds-sidebar-item.js.map +1 -0
- package/components/Sidebar/sgds-sidebar-section.d.ts +55 -0
- package/components/Sidebar/sgds-sidebar-section.js +122 -0
- package/components/Sidebar/sgds-sidebar-section.js.map +1 -0
- package/components/Sidebar/sgds-sidebar.d.ts +85 -0
- package/components/Sidebar/sgds-sidebar.js +319 -0
- package/components/Sidebar/sgds-sidebar.js.map +1 -0
- package/components/Sidebar/sidebar-context.d.ts +51 -0
- package/components/Sidebar/sidebar-context.js +45 -0
- package/components/Sidebar/sidebar-context.js.map +1 -0
- package/components/Sidebar/sidebar-item.js +6 -0
- package/components/Sidebar/sidebar-item.js.map +1 -0
- package/components/Sidebar/sidebar-section.js +6 -0
- package/components/Sidebar/sidebar-section.js.map +1 -0
- package/components/Sidebar/sidebar.js +6 -0
- package/components/Sidebar/sidebar.js.map +1 -0
- package/components/Tab/index.umd.min.js.map +1 -1
- package/components/Tab/sgds-tab-group.d.ts +2 -2
- package/components/Tab/sgds-tab-group.js +2 -2
- package/components/Tab/sgds-tab-group.js.map +1 -1
- package/components/Textarea/index.umd.min.js +6 -6
- package/components/Textarea/index.umd.min.js.map +1 -1
- package/components/Textarea/sgds-textarea.d.ts +2 -0
- package/components/Textarea/sgds-textarea.js +14 -2
- package/components/Textarea/sgds-textarea.js.map +1 -1
- package/components/index.d.ts +1 -0
- package/components/index.js +1 -0
- package/components/index.js.map +1 -1
- package/components/index.umd.min.js +84 -49
- package/components/index.umd.min.js.map +1 -1
- package/css/fouc.css +6 -2
- package/css/utility.css +21 -1
- package/index.d.ts +1 -0
- package/index.js +1 -0
- package/index.js.map +1 -1
- package/index.umd.min.js +173 -62
- package/index.umd.min.js.map +1 -1
- package/package.json +1 -1
- package/react/base/sidebar-element.cjs.js +286 -0
- package/react/base/sidebar-element.cjs.js.map +1 -0
- package/react/base/sidebar-element.js +282 -0
- package/react/base/sidebar-element.js.map +1 -0
- package/react/components/Input/sgds-input.cjs.js +1 -4
- package/react/components/Input/sgds-input.cjs.js.map +1 -1
- package/react/components/Input/sgds-input.js +1 -4
- package/react/components/Input/sgds-input.js.map +1 -1
- package/react/components/Modal/sgds-modal.cjs.js +1 -1
- package/react/components/Modal/sgds-modal.cjs.js.map +1 -1
- package/react/components/Modal/sgds-modal.js +1 -1
- package/react/components/Modal/sgds-modal.js.map +1 -1
- package/react/components/Sidebar/sgds-sidebar-group.cjs.js +130 -0
- package/react/components/Sidebar/sgds-sidebar-group.cjs.js.map +1 -0
- package/react/components/Sidebar/sgds-sidebar-group.js +125 -0
- package/react/components/Sidebar/sgds-sidebar-group.js.map +1 -0
- package/react/components/Sidebar/sgds-sidebar-item.cjs.js +79 -0
- package/react/components/Sidebar/sgds-sidebar-item.cjs.js.map +1 -0
- package/react/components/Sidebar/sgds-sidebar-item.js +74 -0
- package/react/components/Sidebar/sgds-sidebar-item.js.map +1 -0
- package/react/components/Sidebar/sgds-sidebar-section.cjs.js +128 -0
- package/react/components/Sidebar/sgds-sidebar-section.cjs.js.map +1 -0
- package/react/components/Sidebar/sgds-sidebar-section.js +123 -0
- package/react/components/Sidebar/sgds-sidebar-section.js.map +1 -0
- package/react/components/Sidebar/sgds-sidebar.cjs.js +325 -0
- package/react/components/Sidebar/sgds-sidebar.cjs.js.map +1 -0
- package/react/components/Sidebar/sgds-sidebar.js +320 -0
- package/react/components/Sidebar/sgds-sidebar.js.map +1 -0
- package/react/components/Sidebar/sidebar-context.cjs.js +54 -0
- package/react/components/Sidebar/sidebar-context.cjs.js.map +1 -0
- package/react/components/Sidebar/sidebar-context.js +46 -0
- package/react/components/Sidebar/sidebar-context.js.map +1 -0
- package/react/components/Sidebar/sidebar-item.cjs.js +11 -0
- package/react/components/Sidebar/sidebar-item.cjs.js.map +1 -0
- package/react/components/Sidebar/sidebar-item.js +7 -0
- package/react/components/Sidebar/sidebar-item.js.map +1 -0
- package/react/components/Sidebar/sidebar-section.cjs.js +11 -0
- package/react/components/Sidebar/sidebar-section.cjs.js.map +1 -0
- package/react/components/Sidebar/sidebar-section.js +7 -0
- package/react/components/Sidebar/sidebar-section.js.map +1 -0
- package/react/components/Sidebar/sidebar.cjs.js +11 -0
- package/react/components/Sidebar/sidebar.cjs.js.map +1 -0
- package/react/components/Sidebar/sidebar.js +7 -0
- package/react/components/Sidebar/sidebar.js.map +1 -0
- package/react/components/Tab/sgds-tab-group.cjs.js +2 -2
- package/react/components/Tab/sgds-tab-group.cjs.js.map +1 -1
- package/react/components/Tab/sgds-tab-group.js +2 -2
- package/react/components/Tab/sgds-tab-group.js.map +1 -1
- package/react/components/Textarea/sgds-textarea.cjs.js +14 -2
- package/react/components/Textarea/sgds-textarea.cjs.js.map +1 -1
- package/react/components/Textarea/sgds-textarea.js +14 -2
- package/react/components/Textarea/sgds-textarea.js.map +1 -1
- package/react/index.cjs.js +68 -60
- package/react/index.cjs.js.map +1 -1
- package/react/index.d.ts +6 -2
- package/react/index.js +6 -2
- package/react/index.js.map +1 -1
- package/react/sidebar/index.cjs.js +40 -0
- package/react/sidebar/index.cjs.js.map +1 -0
- package/react/sidebar/index.d.ts +2 -0
- package/react/sidebar/index.js +16 -0
- package/react/sidebar/index.js.map +1 -0
- package/react/sidebar-group/index.cjs.js +40 -0
- package/react/sidebar-group/index.cjs.js.map +1 -0
- package/react/sidebar-group/index.d.ts +2 -0
- package/react/sidebar-group/index.js +16 -0
- package/react/sidebar-group/index.js.map +1 -0
- package/react/sidebar-item/index.cjs.js +40 -0
- package/react/sidebar-item/index.cjs.js.map +1 -0
- package/react/sidebar-item/index.d.ts +2 -0
- package/react/sidebar-item/index.js +16 -0
- package/react/sidebar-item/index.js.map +1 -0
- package/react/sidebar-section/index.cjs.js +40 -0
- package/react/sidebar-section/index.cjs.js.map +1 -0
- package/react/sidebar-section/index.d.ts +2 -0
- package/react/sidebar-section/index.js +16 -0
- package/react/sidebar-section/index.js.map +1 -0
- package/react/utils/inputValidationController.cjs.js +2 -1
- package/react/utils/inputValidationController.cjs.js.map +1 -1
- package/react/utils/inputValidationController.js +2 -1
- package/react/utils/inputValidationController.js.map +1 -1
- package/react/utils/validatorMixin.cjs.js +24 -6
- package/react/utils/validatorMixin.cjs.js.map +1 -1
- package/react/utils/validatorMixin.js +24 -6
- package/react/utils/validatorMixin.js.map +1 -1
- package/utils/inputValidationController.js +2 -1
- package/utils/inputValidationController.js.map +1 -1
- package/utils/validatorMixin.js +24 -6
- 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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"}
|