All files / app/codeCharta/state/effects/setLoadingIndicator setLoadingIndicator.effect.ts

0% Statements 0/18
100% Branches 0/0
0% Functions 0/5
0% Lines 0/15

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27                                                     
import { Injectable } from "@angular/core"
import { Actions, createEffect, ofType } from "@ngrx/effects"
import { map } from "rxjs"
import { setIsLoadingFile } from "../../store/appSettings/isLoadingFile/isLoadingFile.actions"
import { actionsRequiringRerender } from "../renderCodeMapEffect/actionsRequiringRerender"
import { setIsLoadingMap } from "../../store/appSettings/isLoadingMap/isLoadingMap.actions"
import { CcState } from "../../../codeCharta.model"
import { Store } from "@ngrx/store"
import { visibleFileStatesSelector } from "../../selectors/visibleFileStates/visibleFileStates.selector"
 
@Injectable()
export class SetLoadingIndicatorEffect {
    constructor(
        private actions$: Actions,
        private store: Store<CcState>
    ) {}
 
    setIsLoadingFile$ = createEffect(() => this.store.select(visibleFileStatesSelector).pipe(map(() => setIsLoadingFile({ value: true }))))
 
    setIsLoadingMap$ = createEffect(() =>
        this.actions$.pipe(
            ofType(...actionsRequiringRerender),
            map(() => setIsLoadingMap({ value: true }))
        )
    )
}