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

100% Statements 18/18
100% Branches 2/2
100% Functions 3/3
100% Lines 17/17

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 28 29 30 31 32 33 34 351x 1x 1x 1x 1x   1x 1x 1x 1x       1x   2x 2x     2x 2x       2x 2x       2x          
import stringify from "safe-stable-stringify"
import { Injectable } from "@angular/core"
import { State, Store } from "@ngrx/store"
import { createEffect } from "@ngrx/effects"
import { map, pairwise, withLatestFrom } from "rxjs"
 
import { visibleFileStatesSelector } from "../../selectors/visibleFileStates/visibleFileStates.selector"
import { codeMapNodesSelector } from "../../selectors/accumulatedData/codeMapNodes.selector"
import { setAmountOfTopLabels } from "../../store/appSettings/amountOfTopLabels/amountOfTopLabels.actions"
import { getNumberOfTopLabels } from "./getNumberOfTopLabels"
import { CcState } from "../../../codeCharta.model"
 
@Injectable()
export class UpdateVisibleTopLabelsEffect {
    constructor(
        private store: Store<CcState>,
        private state: State<CcState>
    ) {}
 
    updateVisibleTopLabels$ = createEffect(() =>
        this.store.select(visibleFileStatesSelector).pipe(
            pairwise(),
            withLatestFrom(this.store.select(codeMapNodesSelector)),
            map(([[previousVisibleFileStates, currentVisibleFileStates], codeMapNodes]) => {
                const isUnchanged = stringify(previousVisibleFileStates) === stringify(currentVisibleFileStates)
                const amountOfTopLabels = isUnchanged
                    ? this.state.getValue().appSettings.amountOfTopLabels
                    : getNumberOfTopLabels(codeMapNodes)
 
                return setAmountOfTopLabels({ value: amountOfTopLabels })
            })
        )
    )
}