| 19 | `, |
| 20 | }) |
| 21 | export class CounterComponent { |
| 22 | readonly increment = new Subject<void>(); |
| 23 | readonly decrement = new Subject<void>(); |
| 24 | |
| 25 | private readonly state = rxState<{ count: number }>(({ connect, set }) => { |
| 26 | set({ count: 0 }); |
| 27 | connect( |
| 28 | 'count', |
| 29 | merge( |
| 30 | this.increment.pipe(map(() => 1)), |
| 31 | this.decrement.pipe(map(() => -1)) |
| 32 | ), |
| 33 | ({ count }, slice) => count + slice |
| 34 | ); |
| 35 | }); |
| 36 | |
| 37 | readonly count$ = this.state.select('count'); |
| 38 | } |
| 39 | |
| 40 | describe('CounterComponent', () => { |
| 41 | let fixture: ComponentFixture<CounterComponent>; |