приложения за счет этой регистрации:
{
provide: APP_INITIALIZER,
useFactory: initializeTaxpayers,
deps: [TaxpayerService, TaxpayerStore, SecurityStore],
multi: true
}
вот как выглядит функция:
export const initializeTaxpayers = (taxpayerService: TaxpayerService, taxpayerStore: TaxpayerStore, securityStore: SecurityStore): () => Observable<any> =>
() => securityStore.signIn$
.pipe(
take(1),
switchMap(signIn => !signIn ? of(null) : taxpayerService.getTaxpayers()
.pipe(
tap(taxpayers => taxpayerStore.set(taxpayers))
)
)
);
суть проблемы тут заключается в take(1)
я его написал потому, что почему-то после этого белый экран
наверное потому, что поток не завершенный, из-за этого чтоли.
но из-за take(1) тем самым перестает работать другой кейс:
1. пользователь выходит из аккаунта
2. пользователь заходит в другой аккаунт
3. он по прежнему видит старые taxpayer, потому что не прогрузились новые из за take(1)
Народ, подскажите как быть пожалуйста?
А без take(1), но с отпиской пробовали? takeUntil и все дела
не пробовал думаете поможет?
Ну так у Вас отписки, вообще, нет?
но у меня и подписки, как вы видите, нигде нет)
Ну как тут получается в итоге, только вместо того, чтобы провайдить APP_INI.... можно сделать токен в рут с этой фабрикой.
что еще за токен в рут....зачем.... покажите что вы имеете ввиду
new InjectionToken('some-token', { provideIn: 'root', factory: ... deps: ... })
и зачем это? чтобы заинжектить функцию чтоли?
Тут тоже самое, что я описал с токеном, только токен тут готовый APP_IN... и ангуляр его сам обрабатывает.
да эт я понял правда не сразу)))
Проблема в taxpayerStore.set(taxpayers), не надо так делать, предоставляйте динамические данные через Observable. Вместо этого вы синхронно их куда-то складываете
Обсуждают сегодня