Security News
The Risks of Misguided Research in Supply Chain Security
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
@lwc/wire-service
Advanced tools
This is the implementation of Lightning Web Component's wire service. It enables declarative binding of services to a LWC component using the @wire
decorator. It fulfills the goals of the data service proposal.
The @wire
decorator provides LWC components with a declarative mechanism to express their data requirements. Imperative access (eg for DML) is not part of the wire service. A summary of the wire service follows:
@wire([adapterId], [adapterConfig])
[adapterId]
refers to the identity of a wire adapter.[adapterConfig]
is an optional parameter, of type object, that defines wire adapter-specific configuration.[adapterConfig]
may contain static values or reactive references.$
prefix. The remainder of the string identifies a class property. A change to a referenced class property causes new data to be requested from the wire adapter.wire adapters
to source, manage, and provision data. The wire service sits between wire adapters and LWC components.@wire
Consider a component that wants to display the details of a todo item. It uses @wire
to declare its data requirements.
import { LightningElement, api, wire } from 'lwc';
// the wire adapter identifier
import { getTodo } from 'todo-api';
export default class TodoViewer extends LightningElement {
@api id;
// declare the need for data. $id creates a reactive property tied to this.id.
// data is provisioned into this.todo.
@wire(getTodo, { id: '$id' })
todo
}
<template>
<template if:true={todo}>
<input type="checkbox" checked={todo.completed}> {todo.title}
</template>
</template>
The following is a summary of the wire adapter RFC.
A wire adapter
provisions data to a wired property or method using an Event Target. A factory function is registered for declarative @wire
use by a component.
// The identifier for the wire adapter
type WireAdapterId = Function|Symbol;
// The factory function invoked for each @wire in a component. The WireEventTarget
// allows the wire adapter instance to receive configuration data and provision
// new values.
type WireAdapterFactory = (eventTarget: WireEventTarget) => void;
// Event the wire adapter dispatches to provision values to the wired property or method
interface ValueChangedEvent {
value: any;
new(value: any) : ValueChangedEvent;
}
// Event types the wire adapter may listen for
type EventType = 'config' | 'connect' | 'disconnect';
// Event listener callback
type Listener = (config?: { [key: string]: any ) => void;
// Target of the @wire
interface WireEventTarget extends EventTarget {
dispatchEvent(event: ValueChangedEvent): boolean;
addEventListener(type: EventType, listener: Listener): void;
removeEventListener(type: EventType, listener: Listener): void;
}
In the component's wiring
lifecycle, the wire service invokes the wireAdapterFactory
function to configure an instance of the wire adapter for each @wire
instance (which is per component instance).
eventTarget
is an implementation of Event Target that supports listeners for the following events:
config
is delivered when the resolved configuration changes. A singular argument is provided: the resolved configuration.connect
is delivered when the component is connected.disconnect
is delivered when the component is disconnected.The wire service remains responsible for resolving the configuration object. eventTarget
delivers a config
event when the resolved configuration changes. The value of the configuration is specific to the wire adapter. The wire adapter must treat the object as immutable.
The wire adapter is responsible for provisioning values by dispatching a ValueChangedEvent
to the event target. ValueChangedEvent
's constructor accepts a single argument: the value to provision. There is no limitation to the shape or contents of the value to provision. The event target handles property assignment or method invocation based on the target of the @wire
.
The wire adapter is responsible for maintaining any context it requires. For example, tracking the values it provisions and the originating resolved configuration is shown in the basic example below.
A wire adapter must be registered with the wire service. The wire-service
module provides a registration function.
register(adapterId: WireAdapterId, wireAdapterFactory: WireAdapterFactory);
import { register, ValueChangedEvent } from 'wire-service';
// Imperative access.
export function getTodo(config) {
return getObservable(config)
.map(makeReadOnlyMembrane)
.toPromise();
}
// Declarative access: register a wire adapter factory for @wire(getTodo).
register(getTodo, function getTodoWireAdapterFactory(eventTarget) {
let subscription;
let config;
// Invoked when config is updated.
eventTarget.addListener('config', (newConfig) => {
// Capture config for use during subscription.
config = newConfig;
});
// Invoked when component connected.
eventTarget.addListener('connected', () => {
// Subscribe to stream.
subscription = getObservable(config)
.map(makeReadOnlyMembrane)
.subscribe({
next: (data) => wiredEventTarget.dispatchEvent(new ValueChangedEvent({ data, error: undefined })),
error: (error) => wiredEventTarget.dispatchEvent(new ValueChangedEvent({ data: undefined, error }))
});
})
// Invoked when component disconnected.
eventTarget.addListener('disconnected', () => {
// Release all resources.
subscription.unsubscribe();
});
});
A playground of LWC components using @wire is included. They're served from a basic node server and accessible in your browser.
yarn start
Load the examples in a browser:
open http://localhost:3000/
FAQs
@wire service
The npm package @lwc/wire-service receives a total of 71,404 weekly downloads. As such, @lwc/wire-service popularity was classified as popular.
We found that @lwc/wire-service demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 15 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.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.