windowToggle<T, O>(openings: Observable<O>, closingSelector: (openValue: O) => Observable<any>): OperatorFunction<T, Observable<T>>
| openings | Un observable de notificaciones para abrir nuevas ventanas. |
| closingSelector | Una función que recibe el valor emitido por el Observable openings y retorna un Observable que, cuando emite (ya sea una notificación next o complete), señala que la ventana asociado debe cerrarse. |
OperatorFunction<T, Observable<T>>: Un Observable de ventanas, que son Observables de valores.
Es como bufferToggle, pero emite un Observable anidado en lugar de un array.
Retorna un Observable que emite ventanas de elementos que recoge del Observable fuente. El Observable resultante emite ventanas que contienen estos elementos emitidos por el Observable fuente durante el periodo entre la emisión del Observable openings y la emisión del Observable retornado por la función closingSelector.
Abrir una nueva ventana cada vez que se pulse una tecla numérica, cuya duración esté determinada por el valor de la tecla que se pulse.
Ejemplo: Si se pulsa la tecla 6, la duración de la ventana será de 6 segundos.
import { fromEvent, interval } from "rxjs";
import { windowToggle, mergeAll, map, filter, tap } from "rxjs/operators";
const number$ = interval(1000);
// Emitirá cuando se presione una tecla numérica (0, 1, 2, 3, 4, 5, 6, 7, 8 o 9)
const numericKey$ = fromEvent<KeyboardEvent>(document, "keydown").pipe(
map(({ key }) => +key),
filter((key) => !isNaN(key))
);
number$
.pipe(
windowToggle(numericKey$, (n) => interval(n * 1000)),
tap((_) => console.log("Nueva ventana")),
mergeAll()
)
.subscribe(console.log);
// Salida: (pulsar 5) Nueva ventana, 0, 1, 2, 3, 4 (pulsar 2) Nueva ventana, 5, 6
Cada 2 segundos, emitir los eventos clicks de los siguientes 500ms
import { fromEvent, interval, EMPTY } from "rxjs";
import { windowToggle, mergeAll } from "rxjs/operators";
const clicks = fromEvent(document, "click");
const openings = interval(1000);
const result = clicks.pipe(
windowToggle(openings, (i) => (i % 2 ? interval(500) : EMPTY)),
mergeAll()
);
result.subscribe((x) => console.log(x));
Documentación oficial en inglés