How can we dynamically retrieve configuration in Ionic 4 for IOS using Socket.io?

I am currently working on an application built with Ionic and socket IO. In the app.module.ts file, the socket import requires a configuration for the URL and options. The issue is that this configuration is hardcoded, and I would prefer to have it dynamically fetched from a form or stored data. I want to avoid having to redeploy the application every time there is a change in the IP address or server port, and I also do not want to rely on a DNS link. Can anyone provide guidance on how to achieve this?

My current setup includes Ionic 5.4.5, Cordova 9.0.0, and deployment on IOS 12.4.

Below is a snippet of my app.module.ts file:

import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { RouteReuseStrategy } from '@angular/router';
import { ErrorHandler } from '@angular/core';
import { IonicModule, IonicRouteStrategy } from '@ionic/angular';
import { SplashScreen } from '@ionic-native/splash-screen/ngx';
import { StatusBar } from '@ionic-native/status-bar/ngx';

import { AppRoutingModule } from './app-routing.module';
import { AppComponent } from './app.component';
import { HttpClientModule } from '@angular/common/http';

import { SocketIoModule, SocketIoConfig } from 'ng-socket-io';
const config: SocketIoConfig = { url: 'http://192.168.0.17:3001', options: {} };


@NgModule({
  declarations: [AppComponent],
  entryComponents: [],
  imports: [
    BrowserModule,
    IonicModule.forRoot(),
    AppRoutingModule,
    HttpClientModule,
    SocketIoModule.forRoot(config),
  ],
  providers: [
    StatusBar,
    SplashScreen,
    { provide: RouteReuseStrategy, useClass: IonicRouteStrategy }
  ],
  bootstrap: [AppComponent]
})
export class AppModule { }

Any insights or responses would be greatly appreciated. Thank you.

Answer №1

When it comes to optimizing the loading time of your core application module (app.module.ts) in order to ensure a smooth user experience, it is important to avoid adding heavy business logic that could potentially slow down the load time, especially when fetching dynamic configurations for Socket.io.

A better approach would be to separate the initialization and configuration of Socket.io into another module that can be loaded later in the start-up process of your app.

In a similar scenario, I tackled this issue by:

- opting for a different socket.io client library that does not require initialization through a module: https://github.com/socketio/socket.io-client

- creating a service and incorporating this alternative library:

import { Injectable } from "@angular/core";
import io from "socket.io-client";

export class FoundationProvider {
    public sockets;
}

- implementing a method that handles the initialization process after retrieving the necessary socket config details:

initSocketsIO() {
    if (this.data.userID && this.state.appIsOnline) {
      this.sockets = io(
        this.config.apiBaseUrl + "?_id=" + this.data.userID,
        {
          reconnectionAttempts: 3,
          reconnectionDelay: 10000,
          transports: ['websocket']
        }
      )
      this.sockets.on("snippets", event => {
        this.handleIncomingNotification(event.message);
      })
      this.sockets.on("tasks", event => {
        this.handleIncomingNotification(event.message);
      })
      this.sockets.on("payments", event => {
        this.handleIncomingNotification(event.message);
      })
    };
  };

If you still require the use of your current library, consider relocating it to a more suitable module that loads later in the app's start life cycle, where global configurations and variables are readily available throughout the application. This adjustment should contribute to enhancing the overall performance of your app. Hope this guidance proves beneficial.

Similar questions

If you have not found the answer to your question or you are interested in this topic, then look at other similar questions below or use the search

TypeScript encountering issues when creating objects within the realm of Jest

I'm in the process of testing my React application using Jest. When I initiate the command to run the tests, jest, an error is thrown stating: Debug Failure. False expression: Output generation failed 1 | import * as TestData from 'TestMo ...

Solutions for resolving the issue of not being able to load images when using merged-images in JavaScript

I have a base64 image here and it has already been converted.  ...

In Angular 4, I encountered an issue where adjusting the height of the navigation bar caused the toggle button to no longer expand the menu in Bootstrap

In the process of developing an angular application, I encountered a situation where I needed to adjust the height of the nav bar using style properties. After making the necessary changes, everything was working fine. However, a problem arose when I mini ...

Transforming data from AFNetworking into JSON format

Utilizing AFNetworking to fetch JSON from a URL, parsing the JSON, and trying to convert it into an NSData format to populate an array. But unfortunately, it doesn't seem to be working as expected. It used to work before, so I'm puzzled by what c ...

Unexpected error: Angular 4 TypeScript validation issue - An object literal can only define recognized properties

excellent customer service import {Account} from '../models/Account'; export class AccountingService { domain: string = "http://localhost:3000/api"; constructor(private http: HttpClient) { } getAccounts(){ return this.http.get&l ...

I would appreciate it if someone could provide guidance on the process of asynchronously downloading a file from Parse using PFFile

I've been struggling with this issue for quite some time now. Despite reading numerous threads, I have not come across a solution that fits my specific problem. I've attempted various approaches but none seem to yield the desired results. The cha ...

What causes an interface to lose its characteristics when a property is defined using index signatures?

Here's the code snippet I'm having trouble with, which involves tRPC and Zod. import { initTRPC, inferRouterOutputs } from '@trpc/server'; import { z } from "zod"; const t = initTRPC.create(); const { router, procedure } = t; ...

Using the HTTP Post method to retrieve a file object: a step-by-step guide

Is there a way to utilize a http POST request in order to retrieve a file object? Though the uploading of files to the server using the POST request seems successful and flawless, attempting to fetch the file results in an unusual response: console output ...

"Sorry, unable to reach website" - Connection Error with Socket.IO

My attempt to establish a connection with 54.255.140.142:3000 using Socket.IO has been unsuccessful. I used the command iptables -A INPUT -p tcp --dport 3000 -j ACCEPT to try and open the port. However, I am encountering an error that states "Site cannot ...

Show JSON information in an angular-data-table

I am trying to showcase the following JSON dataset within an angular-data-table {"_links":{"self":[{"href":"http://uni/api/v1/cycle1"},{"href":"http://uni/api/v1/cycle2"},{"href":"http://uni/api/v1/cycle3"}]}} This is what I have written so far in my cod ...

Is it possible for the Milkmangames Easypush ANE to detect a canceled click by the operating system?

I make a call EasyPush.oneSignal.registerForNotifications(); At the appropriate moment in my program to trigger the iOS push message subscription dialog. If the user clicks OK, I receive an event confirming acceptance and providing me with the token. H ...

The transparent background should be visible in the pushed view

When transitioning from one view to another, I typically make the pushed view transparent using the following code snippet. However, with the latest versions of iOS and Xcode, this no longer works as expected. If anyone has a solution for this issue, pleas ...

When a selection is made in React MUI Virtualized Autocomplete, the autocomplete menu scrolls back to the top

I am currently using reactMUI autocomplete with virtualization because the listbox is expected to contain thousands of items. The virtualization feature works fine, but when I add an onchange function, the listbox automatically scrolls back to the top wh ...

What is preventing me from being able to spyOn() specific functions within an injected service?

Currently, I am in the process of testing a component that involves calling multiple services. To simulate fake function calls, I have been injecting services and utilizing spyOn(). However, I encountered an issue where calling a specific function on one ...

What is the best way to customize the tooltip in VS Code for TypeScript type aliases?

Here is an issue with the code snippet below: type char = 'a' | 'b' | 'c' | 'd' | 'e' | 'f'; const s: string = 'foo'; const [c]: char = s; // [ERROR]: Type 'string' is not assi ...

The function threw an error: "TypeError: this.registeredUserArray.some is not a function"

I have been attempting to store a registered user object inside localstorage. However, when I try to retrieve or set those values from localstorage in an array and parse it back to an object, I encounter an error stating that ".push" or ".some" is not a ...

Encountering crashes on iOS 13 when navigating to ABPersonViewController

Everything was working fine till iOS 12, but now the code below is causing the application to crash on iOS 13. NOTE: I prefer not to upgrade to Contacts framework at this moment. Here is the code I'm using: ABPersonViewController *vc = [[ABPersonVi ...

The parameter 'prevState: Stock[]' does not match the expected type 'SetStateAction<Stock[] | []>'

I'm currently diving into TypeScript and I encountered the following error message that has me stumped. Interestingly, the code runs smoothly without TypeScript. Can anyone provide guidance on how to resolve this issue? Error details: Argument of typ ...

What is the process for setting the value of a TextField based on a Dropdown Selection?

I have a question regarding the code snippet below. I am wondering how to set the value of a specific TextField based on the selected item in a Dropdown component named ChildComponent. import * as React from "react"; import ChildComponent from './Ope ...

Using typescript with create-react-app - organizing types in a separate file

I'm currently developing a project using Create React App with TypeScript (create-react-app myapp --typescript) In my App.tsx file, I have written some TypeScript code that I want to move to an external file. I have tried creating App.d.ts, index.d.t ...