Solution
import { ReplaySubject, fromEvent } from 'rxjs';
import { map, scan } from 'rxjs/operators';
/**
* Create a new ReplaySubject and specify the generic type
* `number`.
*/
const replaySubject = new ReplaySubject<number>();
/**
* Using the `fromEvent()` creation operator we add an event
* listener to both the `add` and `sub` buttons.
* For each click we `map()` to either a positive 1 or a negative
* 1 appropriately.
* Finally, we subscribe to the click event Observable and set
* the `replaySubject` as the Observer.
*/
const add = document.getElementById('add') as HTMLButtonElement;
const sub = document.getElementById('sub') as HTMLButtonElement;
fromEvent(add, 'click')
.pipe(map(() => 1))
.subscribe(replaySubject);
fromEvent(sub, 'click')
.pipe(map(() => -1))
.subscribe(replaySubject);
/**
* Again, using the `fromEvent()` creation operator we add an event
* listener to the `calc` button.
* When the user clicks the calc button we want to begin calculating
* the sum of each click on the `add` or `sub` buttons.
* The `replaySubject` will replay all previous next notification values
* and we will continue to calculate the sum for future next notifications.
*/
const sum = document.getElementById('sum') as HTMLInputElement;
const calc = document.getElementById('calc') as HTMLButtonElement;
calc.addEventListener('click', () => {
replaySubject
.pipe(scan<number, number>((prev, value) => prev + value, 0))
.subscribe((total) => (sum.value = total.toString()));
});
Let's review the solution code above:
- First, we Create a new ReplaySubject and specify the generic type
number
. - Using the
fromEvent()
creation operator we add an event listener to both theadd
andsub
buttons. For each click wemap()
to either1
or-1
appropriately. Then, we subscribe to the click event Observable and set thereplaySubject
as the Observer. - Again, using the
fromEvent()
creation operator we add an event listener to thecalc
button. When the user clicks the calc button we want to begin calculating the sum of each click on theadd
orsub
buttons. ThereplaySubject
will replay all previous next notification values, and we will continue to calculate the sum for future next notifications.