Merge pull request #2927 from NoelDeMartin/MOBILE-3833

MOBILE-3833: Fix initialization & Update node version
main
Dani Palou 2021-09-01 08:25:10 +02:00 committed by GitHub
commit 76e4fa8678
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
10 changed files with 24 additions and 19 deletions

View File

@ -12,7 +12,7 @@ jobs:
- name: Use Node.js
uses: actions/setup-node@v1
with:
node-version: '12.x'
node-version: '14.x'
- run: npm ci
- run: result=$(find src -type f -iname '*.html' -exec sh -c 'cat {} | tr "\n" " " | grep -Eo "class=\"[^\"]+\"[^>]+class=\"" ' \; | wc -l); test $result -eq 0
- run: npm install -D @ionic/v4-migration-tslint

View File

@ -12,7 +12,7 @@ jobs:
- name: Use Node.js
uses: actions/setup-node@v1
with:
node-version: '12'
node-version: '14'
- name: Install npm packages
run: |
npm install -g npm@7

2
.nvmrc
View File

@ -1 +1 @@
12
v14.15.0

View File

@ -1,6 +1,6 @@
os: linux
dist: trusty
node_js: 12
node_js: 14
git:
depth: 3
@ -18,7 +18,7 @@ cache:
- $HOME/.android/build-cache
before_install:
- nvm install 12
- nvm use
- node --version
- npm --version
- nvm --version

View File

@ -173,7 +173,7 @@
"typescript": "^3.9.9"
},
"engines": {
"node": ">=12.x"
"node": ">=14.15.0 <15"
},
"cordova": {
"platforms": [

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);
},
);
}