element-resolution
NPM 1.0.1
Description
An ElementResolutionController
keeps an active reference to another element in the same DOM tree. Supply the controller with a selector to query and it will manage observing the DOM tree to ensure that the reference it holds is always the first matched element or null
.
Usage
yarn add @spectrum-web-components/reactive-controllers
Import the ElementResolutionController
and/or elementResolverUpdatedSymbol
via:
import { ElementResolutionController, elementResolverUpdatedSymbol } from '@spectrum-web-components/reactive-controllers/ElementResolution.js';
Example
An ElementResolutionController
can be applied to a host element like the following.
import { html, LitElement } from 'lit'; import { ElementResolutionController } from '@spectrum-web-components/reactive-controllers/ElementResolution.js'; class RootEl extends LitElement { resolvedElement = new ElementResolutionController(this); costructor() { super(); this.resolvedElement.selector = '.other-element'; } } customElements.define('root-el', RootEl);
In this example, the selector '.other-element'
is supplied to the resolver, which mean in the following example, this.resolvedElement.element
will maintain a reference to the sibling <div>
element:
<root-el></root-el> <div class="other-element"></div>
The resolved reference will always be the first element matching the selector applied, so in the following example the element with content "First!" will be the reference:
<root-el></root-el> <div class="other-element">First!</div> <div class="other-element">Last.</div>
A MutationObserver
Updates
Changes to the resolved element reference are reported to the host element via a call to the requestUpdate()
method. This will be provided the elementResolverUpdatedSymbol
as the changed key. If your element leverages this value against the changes map, it can react directly to changes in the resolved element:
import { html, LitElement } from 'lit'; import { ElementResolutionController, elementResolverUpdatedSymbol, } from '@spectrum-web-components/reactive-controllers/ElementResolution.js'; class RootEl extends LitElement { resolvedElement = new ElementResolutionController(this); costructor() { super(); this.resolvedElement.selector = '.other-element'; } protected override willUpdate(changes: PropertyValues): void { if (changes.has(elementResolverUpdatedSymbol)) { // work to be done only when the element reference has been updated } } }