MOBILE-3833 core: Fix initialization

main
Noel De Martin 2021-08-31 17:40:12 +02:00
parent 5542b15ed9
commit 8a2309522c
5 changed files with 18 additions and 13 deletions

View File

@ -24,4 +24,9 @@ export class CoreApplicationInitStatus extends ApplicationInitStatus {
super(injector.get(APP_INITIALIZER, []));
}
whenDone(callback: () => unknown): void {
// eslint-disable-next-line promise/catch-or-return, promise/no-callback-in-promise
this.donePromise.then(callback);
}
}

View File

@ -102,17 +102,15 @@ export class CoreFilepoolProvider {
/**
* Initialize queue.
*/
async initialize(): Promise<void> {
// Waiting for the app to be ready to start processing the queue.
await ApplicationInit.donePromise;
initialize(): void {
// Start processing the queue once the app is ready.
ApplicationInit.whenDone(() => {
this.checkQueueProcessing();
this.checkQueueProcessing();
// Start queue when device goes online.
Network.onConnect().subscribe(() => {
// Execute the callback in the Angular zone, so change detection doesn't stop working.
NgZone.run(() => {
this.checkQueueProcessing();
// Start queue when device goes online.
Network.onConnect().subscribe(() => {
// Execute the callback in the Angular zone, so change detection doesn't stop working.
NgZone.run(() => this.checkQueueProcessing());
});
});
}

View File

@ -50,7 +50,7 @@ export class CoreLangProvider {
document.documentElement.setAttribute('dir', dir);
});
await this.initializeCurrentLanguage();
this.initializeCurrentLanguage();
}
/**

View File

@ -57,6 +57,8 @@ import { Zip as ZipService } from '@ionic-native/zip/ngx';
import { TranslateService } from '@ngx-translate/core';
import { CoreApplicationInitStatus } from '@classes/application-init-status';
/**
* Injector instance used to resolve singletons.
*/
@ -198,7 +200,7 @@ export const ModalController = makeSingleton(ModalControllerService);
export const PopoverController = makeSingleton(PopoverControllerService);
export const ToastController = makeSingleton(ToastControllerService);
export const GestureController = makeSingleton(GestureControllerService);
export const ApplicationInit = makeSingleton(ApplicationInitStatus);
export const ApplicationInit = makeSingleton<CoreApplicationInitStatus>(ApplicationInitStatus);
export const Application = makeSingleton(ApplicationRef);
export const NavController = makeSingleton(NavControllerService);
export const Router = makeSingleton(RouterService);

View File

@ -44,7 +44,7 @@ export class CoreSubscriptions {
// Unsubscribe using a timeout because we can receive a value immediately.
setTimeout(() => subscription.unsubscribe(), 0);
onError?.call(error);
onError && onError(error);
},
);
}