J'ai un fournisseur qui doit toujours être en hausse lorsque l'application est en cours d'exécution pour surveiller l'état de la connexion réseau.Instance globale de fournisseur dans Ionic 3
Ainsi, selon que je tutorial ai ajouté la classe à mon dossier app.module.ts
pour en faire une instance globale . Donc, autant que je le comprends, le service devrait être en hausse quand l'application initialise son composant racine (donc app.module.ts
).
Problème: Le fournisseur n'est pas appelé jusqu'à ce qu'une page spécifique de l'application l'importe et l'utilise.
Dans le tutoriel mentionné le provider
est importé comme ça:
ionicBootstrap(MyApp, [TestProvider]);
Malheureusement cela ne fonctionne pas pour moi. Ce post dit que ce tout nouveau tutoriel est obsolète.
Question: Comment pourrais-je utiliser dans providers
Ionic 3
qu'ils sont disponibles une instance après le lancement de l'application?
Mes app.module.ts:
import { NetworkConnectionProvider } from '../providers/networkconnection/networkconnection';
// (...)
@NgModule({
declarations: [
MyApp,
// (...)
],
imports: [
BrowserModule,
HttpModule,
IonicModule.forRoot(MyApp),
ionicGalleryModal.GalleryModalModule,
],
bootstrap: [
IonicApp
],
entryComponents: [
MyApp,
// (...)
],
providers: [
// (...)
NetworkConnectionProvider
]
})
export class AppModule {}
Mon fournisseur:
import { Injectable } from '@angular/core';
import { Http } from '@angular/http';
import 'rxjs/add/operator/map';
import { Network } from '@ionic-native/network';
@Injectable()
export class NetworkConnectionProvider {
private TAG = "NetworkConnectionProvider ";
private isConnectedToInternet: Boolean;
constructor(
public http: Http,
public network: Network
) {
this.isConnectedToInternet = true;
let disconnectSubscription = this.network.onDisconnect().subscribe(() => {
console.log(this.TAG + 'network was disconnected.');
this.isConnectedToInternet = false;
});
// watch network for a connection
let connectSubscription = this.network.onConnect().subscribe(() => {
console.log('network connected!');
this.isConnectedToInternet = true;
// We just got a connection but we need to wait briefly
// before we determine the connection type. Might need to wait.
// prior to doing any api requests as well.
setTimeout(() => {
if (this.network.type === 'wifi') {
console.log(this.TAG + 'wifi connection available');
}
}, 3000);
});
console.log('Hello NetworkConnectionProvider');
}
public subscribeOnConnect() {
return this.network.onConnect();
}
public isConnected(): Boolean{
return this.isConnectedToInternet;
}
public getConnectionType(): string {
return this.network.type;
}
}