Research
Security News
Malicious PyPI Package ‘pycord-self’ Targets Discord Developers with Token Theft and Backdoor Exploit
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
@wordpress/dom
Advanced tools
@wordpress/dom is a utility package for manipulating and interacting with the DOM (Document Object Model) in WordPress projects. It provides a set of functions to handle common DOM operations, making it easier to work with elements, attributes, and events in a WordPress environment.
Focus Management
This feature allows developers to manage focus within the DOM, such as focusing the first tabbable element within a container. This is particularly useful for accessibility and ensuring a smooth user experience.
const { focus } = require('@wordpress/dom');
// Example: Focus the first tabbable element within a container
focus.focusTabbable(containerElement);
Element Manipulation
Provides utility functions to manipulate DOM elements, such as removing an element from the DOM. This simplifies common tasks that would otherwise require more verbose native DOM methods.
const { remove } = require('@wordpress/dom');
// Example: Remove an element from the DOM
remove(elementToRemove);
Attribute Management
Allows for easy management of element attributes, such as toggling an attribute's presence or value. This is useful for dynamically updating the DOM based on user interactions or application state.
const { toggleAttribute } = require('@wordpress/dom');
// Example: Toggle an attribute on an element
toggleAttribute(element, 'aria-hidden', true);
jQuery is a fast, small, and feature-rich JavaScript library. It makes things like HTML document traversal and manipulation, event handling, and animation much simpler with an easy-to-use API that works across a multitude of browsers. Compared to @wordpress/dom, jQuery is more general-purpose and widely used outside of WordPress-specific projects.
dom-helpers is a tiny modular DOM library that provides a set of utilities for DOM manipulation. It is similar to @wordpress/dom in that it offers functions for common DOM tasks, but it is not specifically tailored for WordPress environments.
Vanilla JS DOM is a collection of utility functions for DOM manipulation using vanilla JavaScript. It provides similar functionalities to @wordpress/dom but is designed to be a lightweight alternative without any dependencies, suitable for projects that do not require the full WordPress ecosystem.
DOM utilities module for WordPress.
Install the module
npm install @wordpress/dom --save
Get the rectangle for the selection in a container.
Parameters
Window
: The window of the selection.Returns
DOMRect | null
: The rectangle.Check whether the current document has a selection. This includes focus in input fields, textareas, and general rich-text selection.
Parameters
Document
: The document to check.Returns
boolean
: True if there is selection, false if not.Check whether the current document has selected text. This applies to ranges
of text in the document, and not selection inside <input>
and <textarea>
elements.
See: https://developer.mozilla.org/en-US/docs/Web/API/Window/getSelection#Related_objects.
Parameters
Document
: The document to check.Returns
boolean
: True if there is selection, false if not.Check whether the current document has any sort of (uncollapsed) selection.
This includes ranges of text across elements and any selection inside
textual <input>
and <textarea>
elements.
Parameters
Document
: The document to check.Returns
boolean
: Whether there is any recognizable text selection in the document.Object grouping focusable
and tabbable
utils
under the keys with the same name.
Gets all files from a DataTransfer object.
Parameters
DataTransfer
: DataTransfer object to inspect.Returns
File[]
: An array containing all files.Returns the closest positioned element, or null under any of the conditions of the offsetParent specification. Unlike offsetParent, this function is not limited to HTMLElement and accepts any Node (e.g. Node.TEXT_NODE).
Related
Parameters
Node
: Node from which to find offset parent.Returns
Node | null
: Offset parent.Get schema of possible paths for phrasing content.
Related
Parameters
[string]
: Set to "paste" to exclude invisible elements and sensitive data.Returns
Partial<ContentSchema>
: Schema.Get the rectangle of a given Range. Returns null
if no suitable rectangle
can be found.
Parameters
Range
: The range.Returns
DOMRect?
: The rectangle.Given a DOM node, finds the closest scrollable container node.
Parameters
Element | null
: Node from which to start.Returns
Element | undefined
: Scrollable container node, if found.Given two DOM nodes, inserts the former in the DOM as the next sibling of the latter.
Parameters
Node
: Node to be inserted.Node
: Node after which to perform the insertion.Returns
void
:Recursively checks if an element is empty. An element is not empty if it contains text or contains elements with attributes such as images.
Parameters
Element
: The element to check.Returns
boolean
: Whether or not the element is empty.Check whether the contents of the element have been entirely selected. Returns true if there is no possibility of selection.
Parameters
HTMLElement
: The element to check.Returns
boolean
: True if entirely selected, false if not.Detects if element is a form element.
Parameters
Element
: The element to check.Returns
boolean
: True if form element and false otherwise.Check whether the selection is horizontally at the edge of the container.
Parameters
Element
: Focusable element.boolean
: Set to true to check left, false for right.Returns
boolean
: True if at the horizontal edge, false if not.Check whether the given element is an input field of type number.
Parameters
Node
: The HTML node.Returns
node is HTMLInputElement
: True if the node is number input.Find out whether or not the given node is phrasing content.
Related
Parameters
Node
: The node to test.Returns
boolean
: True if phrasing content, false if not.Whether the element's text direction is right-to-left.
Parameters
Element
: The element to check.Returns
boolean
: True if rtl, false if ltr.Parameters
Node
:Returns
boolean
: Node is text contentCheck whether the given element is a text field, where text field is defined by the ability to select within the input, or that it is contenteditable.
See: https://html.spec.whatwg.org/#textFieldSelection
Parameters
Node
: The HTML element.Returns
node is HTMLElement
: True if the element is an text field, false if not.Check whether the selection is vertically at the edge of the container.
Parameters
Element
: Focusable element.boolean
: Set to true to check top, false for bottom.Returns
boolean
: True if at the vertical edge, false if not.Places the caret at start or end of a given element.
Parameters
HTMLElement
: Focusable element.boolean
: True for end, false for start.Places the caret at the top or bottom of a given element.
Parameters
HTMLElement
: Focusable element.boolean
: True for bottom, false for top.[DOMRect]
: The rectangle to position the caret with.Given a DOM node, removes it from the DOM.
Parameters
Node
: Node to be removed.Returns
void
:Given a schema, unwraps or removes nodes, attributes and classes on HTML.
Parameters
string
: The HTML to clean up.import('./clean-node-list').Schema
: Schema for the HTML.boolean
: Whether to clean for inline mode.Returns
string
: The cleaned up HTML.Given two DOM nodes, replaces the former with the latter in the DOM.
Parameters
Element
: Node to be removed.Element
: Node to be inserted in its place.Returns
void
:Replaces the given node with a new node with the given tag name.
Parameters
Element
: The node to replacestring
: The new tag name.Returns
Element
: The new node.Strips scripts and on* attributes from HTML.
Parameters
string
: HTML to sanitize.Returns
string
: The sanitized HTML.Unwrap the given node. This means any child nodes are moved to the parent.
Parameters
Node
: The node to unwrap.Returns
void
:Wraps the given node with a new node with the given tag name.
Parameters
Element
: The node to insert.Element
: The node to wrap.This is an individual package that's part of the Gutenberg project. The project is organized as a monorepo. It's made up of multiple self-contained software packages, each with a specific purpose. The packages in this monorepo are published to npm and used by WordPress as well as other software projects.
To find out more about contributing to this package or Gutenberg as a whole, please read the project's main contributor guide.
FAQs
DOM utilities module for WordPress.
The npm package @wordpress/dom receives a total of 99,598 weekly downloads. As such, @wordpress/dom popularity was classified as popular.
We found that @wordpress/dom demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.