Ionic v4 Login page incorrectly extends base class with super injector call undefined

General Tech Bugs & Fixes 2 years ago

0 1 0 0 0 tuteeHUB earn credit +10 pts

5 Star Rating 1 Rating

Posted on 16 Aug 2022, this text provides information on Bugs & Fixes related to General Tech. Please note that while accuracy is prioritized, the data presented might not be entirely correct or up-to-date. This information is offered for general knowledge and informational purposes only, and should not be considered as a substitute for professional advice.

Take Quiz To Earn Credits!

Turn Your Knowledge into Earnings.

tuteehub_quiz

Answers (1)

Post Answer
profilepic.png
manpreet Tuteehub forum best answer Best Answer 2 years ago

 

I am trying to use a base class with ionic v4 to add all services I am using all around the app, using the following scripts:

for the base class:

import { Injectable } from '@angular/core';

@Injectable()
export abstract class BaseClass {
  constructor(private gateway: GatewayService){
  }
}

And in the login page, I used the super injector:

export class LoginPage extends BaseClass implements OnInit {
  loginForm: FormGroup;
  message: string="";
  constructor(private gateway: GatewayService) { 
      super(gateway);
    }
...
}

The 2 problems I am having are:

  1. An error on LoginPage class saying:

Class 'LoginPage' incorrectly extends base class 'BaseClass'. Types have separate declarations of a private property 'gateway'

  1. I can't use this.gateway.call() as it was in previous versions of ionic.

What I tried in the base class, is like the following:

constructor(private injectorObj: Injector, private gateway: GatewayService){
    this.gateway = this.injectorObj.get(GatewayService);
}

No matter what stage you're at in your education or career, TuteeHub will help you reach the next level that you're aiming for. Simply,Choose a subject/topic and get started in self-paced practice sessions to improve your knowledge and scores.