2.1.1 • Published 1 year ago
@solid-primitives/active-element v2.1.1
@solid-primitives/active-element
Non-reactive primitives:
makeActiveElementListener- Listen for changes to thedocument.activeElement.makeFocusListener- Attaches "blur" and "focus" event listeners to the element.
Reactive primitives:
createActiveElement- Provides reactive signal ofdocument.activeElement.createFocusSignal- Provides a signal representing element's focus state.
Directives:
focus- A directive that notifies you when the element becomes active or inactive.
Installation
npm install @solid-primitives/active-element
# or
yarn add @solid-primitives/active-elementmakeActiveElementListener
Added id @2.0.0
Attaches event listeners to window, listening for the changes of the document.activeElement.
import { makeActiveElementListener } from "@solid-primitives/active-element";
const [activeElement, setActiveElement] = createSignal(null);
const clear = makeActiveElementListener(el => setActiveElement(el));
// remove listeners (happens also on cleanup)
clear();Definition
function makeActiveElementListener(callback: (element: Element | null) => void): VoidFunction;makeFocusListener
Added id @2.0.0
Attaches "blur" and "focus" event listeners to the element.
import { makeFocusListener } from "@solid-primitives/active-element";
const [isFocused, setIsFocused] = createSignal(false);
const clear = makeFocusListener(focused => setIsFocused(focused));
// remove listeners (happens also on cleanup)
clear();Definition
function makeFocusListener(
target: Element,
callback: (isActive: boolean) => void,
useCapture?: boolean,
): VoidFunction;createActiveElement
Provides reactive signal of document.activeElement. Check which element is currently focused.
How to use it
import { createActiveElement } from "@solid-primitives/active-element";
const activeEl = createActiveElement();
createEffect(() => {
console.log(activeEl()); // T: Element | null
});Definition
function createActiveElement(): Accessor<Element | null>;createFocusSignal
Provides a signal representing element's focus state.
How to use it
import { createFocusSignal } from "@solid-primitives/active-element";
const isFocused = createFocusSignal(el);
isFocused(); // T: boolean
// you can also use signals for ref
const [ref, setRef] = createSignal<Element>(el);
const isFocused = createFocusSignal(ref);
// this way if the element changes,
// the "isFocused" will start checking the new element
// is targeting a ref from jsx, pass it as a function
// or wrap primitive in onMount, so that it is accessed once mounted
let ref;
createFocusSignal(() => ref);
<div ref={ref} />;Definition
function createFocusSignal(target: MaybeAccessor<Element>): Accessor<boolean>;focus
A directive that notifies you when the element becomes active or inactive.
const [active, setActive] = createSignal(false)
<input use:focus={setActive} />Definition
Directive<(isActive: boolean) => void>;Demo
Changelog
See CHANGELOG.md
2.1.1
1 year ago
2.1.0
1 year ago
2.0.20
2 years ago
2.0.19
2 years ago
2.0.18
2 years ago
2.0.16
3 years ago
2.0.17
3 years ago
2.0.15
3 years ago
2.0.13
3 years ago
2.0.14
3 years ago
2.0.11
3 years ago
2.0.12
3 years ago
2.0.9
3 years ago
2.0.10
3 years ago
2.0.8
3 years ago
2.0.10-beta.0
3 years ago
2.0.7
3 years ago
2.0.6
3 years ago
2.0.3
4 years ago
2.0.5
4 years ago
2.0.4
4 years ago
2.0.2
4 years ago
2.0.1
4 years ago
1.1.0
4 years ago
2.0.0
4 years ago
1.0.2
4 years ago
1.0.1
5 years ago
1.0.0
5 years ago

