Constructor
new (require("theme_boost/drawers"))()
- Source:
Examples
// The module just needs to be included to add drawer support.
import 'theme_boost/drawers';
import Drawers from 'theme_boost/drawers';
const myDrawer = Drawers.getDrawerInstanceForNode(document.querySelector('.myDrawerNode');
myDrawer.closeDrawer();
import Drawers from 'theme_boost/drawers';
document.addEventListener(Drawers.eventTypes.drawerShow, e => {
// The drawer which will be shown.
window.console.log(e.target);
// The instance of the Drawers class for this drawer.
window.console.log(e.detail.drawerInstance);
// Prevent this drawer from being shown.
e.preventDefault();
});
document.addEventListener(Drawers.eventTypes.drawerShown, e => {
// The drawer which was shown.
window.console.log(e.target);
// The instance of the Drawers class for this drawer.
window.console.log(e.detail.drawerInstance);
});
Members
closeOnResize
- Description:
Whether the drawer should close when the window is resized
- Source:
Whether the drawer should close when the window is resized
drawerNode
- Description:
The underlying HTMLElement which is controlled.
- Source:
The underlying HTMLElement which is controlled.
eventTypes
- Description:
The list of event types.
- Source:
Properties:
Name | Type | Description |
---|---|---|
drawerShow |
String | |
drawerShown |
String | |
drawerHide |
String | |
drawerHidden |
String |
The list of event types.
isOpen
- Description:
Whether the drawer is open.
- Source:
Whether the drawer is open.
(inner, constant) THRESHOLD :Number
- Description:
Pixel thresshold to auto-hide drawers.
- Source:
Pixel thresshold to auto-hide drawers.
Type:
- Number
(inner) boundingRect :DOMRect
- Description:
The drawer page bounding box dimensions.
- Source:
The drawer page bounding box dimensions.
Type:
- DOMRect
Methods
closeDrawer(args)
- Description:
Close the drawer.
- Source:
Parameters:
Name | Type | Description | |||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
args |
object |
Properties
|
displace(scrollPosition)
- Description:
Displaces the drawer outsite the page.
- Source:
Parameters:
Name | Type | Description |
---|---|---|
scrollPosition |
Number | the page current scroll position |
openDrawer(args)
- Description:
Open the drawer.
By default, openDrawer sets the page focus to the close drawer button. However, when a drawer is open at page load, this represents an accessibility problem as the initial focus changes without any user interaction. The focusOnCloseButton parameter can be set to false to prevent this behaviour.
- Source:
Parameters:
Name | Type | Description | ||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
args |
object |
Properties
|
preventOverlap(currentFocus)
- Description:
Prevent drawer from overlapping an element.
- Source:
Parameters:
Name | Type | Description |
---|---|---|
currentFocus |
HTMLElement |
toggleVisibility()
- Description:
Toggle visibility of the drawer.
- Source:
(static) closeAllDrawers()
- Description:
Close all drawers.
- Source:
(static) closeOtherDrawers(comparisonInstance)
- Description:
Close all drawers except for the specified drawer.
- Source:
Parameters:
Name | Type | Description |
---|---|---|
comparisonInstance |
module:theme_boost/drawers |
(static) displaceDrawers(displace)
- Description:
Prevent drawer from covering the content when the page content covers the full page.
- Source:
Parameters:
Name | Type | Description |
---|---|---|
displace |
Number |
(static) getDrawerInstanceForNode(drawerNode) → {module:theme_boost/drawers}
- Description:
Get the drawer instance for the specified node
- Source:
Parameters:
Name | Type | Description |
---|---|---|
drawerNode |
HTMLElement |
Returns:
(static) preventCoveringFocusedElement()
- Description:
Prevent drawers from covering the focused element.
- Source:
(inner) focusLastUsedToggle(target)
- Description:
Set the focus to the last used button to open this drawer.
- Source:
Parameters:
Name | Type | Description |
---|---|---|
target |
string | The drawer target. |
(inner) setLastUsedToggle(toggleButton)
- Description:
Set the last used attribute for the last used toggle button for a drawer.
- Source:
Parameters:
Name | Type | Description |
---|---|---|
toggleButton |
object | The clicked button. |
Events
theme_boost/drawers:hidden
- Description:
An event triggered after a drawer is hidden.
- Source:
Properties:
Name | Type | Description |
---|---|---|
target |
HTMLElement | The drawer that was be hidden. |
Type:
- CustomEvent
theme_boost/drawers:hide
- Description:
An event triggered before a drawer is hidden.
- Source:
Properties:
Name | Type | Description |
---|---|---|
target |
HTMLElement | The drawer that will be hidden. |
Type:
- CustomEvent
theme_boost/drawers:show
- Description:
An event triggered before a drawer is shown.
- Source:
Properties:
Name | Type | Description |
---|---|---|
target |
HTMLElement | The drawer that will be opened. |
Type:
- CustomEvent
theme_boost/drawers:shown
- Description:
An event triggered after a drawer is shown.
- Source:
Properties:
Name | Type | Description |
---|---|---|
target |
HTMLElement | The drawer that was be opened. |
Type:
- CustomEvent