3

I am creating an Ionic app. I have 3 providers - database provider, portfolio provider and user provider. All 3 are Injectable. I have created it this way because several other pages need to use their function calls (i.e. they should not share the same data, they all should create new instances)

Both the portfolio and user provider import the database provider, as the need to make the same database calls to retrieve data.

I have 1 page - ViewPortfolio. The ViewPortfolio page imports the user provider (to know who the user is) and portfolio provider (to get the users portfolio data). For some reason, these 2 providers seem to be sharing the same instance for database provider. This is how I use them:

PORTFOLIO PROVIDER

import { DatabaseProvider } from '../providers/database-provider';

@Injectable()
@Component({
  providers: [DatabaseProvider]
})
export class PortfolioProvider {
    public portfolio_list: any = new BehaviorSubject<Array<string>>([]);

    constructor(private dbProvider: DatabaseProvider) {
        this.dbProvider.enableDataListener(this.protfolio_path); // set path
        this.dbProvider.db_listener.subscribe(value => {  // subscribe to data in the path
            // do stuff
        });
    }
}

The user portfolio is the same, the only difference is the path its listening to is different.

However, when I change data in the portfolio path, the subscribe call is also triggered in the user path (and vice versa). Thus, even though I added DatabaseProvider in the components providers, its not creating unique instances. Why is this?

I figured it might be because I am importing them both on the same page but I am not convinced that's why it is not working. How do I make the 2 providers use unique instances on databaseprovider, while calling them both on the same page?

This is what my app.moudle.ts file looks like (please note that DatabaseProvider is not included in my app.module.ts file)

// ... more imports
import { PortfolioProvider } from '../providers/portfolio-provider';
import { UserProvider } from '../providers/user-provider';
@NgModule({
  declarations: [
    MyApp,
    // ... more
  ],
  imports: [
    // ... more
    IonicModule.forRoot(MyApp, {
        backButtonText: '',
        tabsPlacement: 'bottom'
    }),
    IonicStorageModule.forRoot()
  ],
  bootstrap: [IonicApp],
  entryComponents: [
    MyApp,
    // ... more
  ],
  providers: [
    // ... more
    PortfolioProvider,
    UserProvider
  ]
})
export class AppModule {}

Thanks,

2
  • Please show us your app.module.ts Commented Dec 1, 2017 at 17:48
  • @JoeriShoeby I have added my app.module.ts code reflecting the most important parts. Any idea? Thanks Commented Dec 1, 2017 at 19:42

1 Answer 1

0

Did you remove the provider from app.module.ts (root AppModule)?

From the Angular Documentation:

Scenario: service isolation
While you could provide VillainsService in the root AppModule (that's where you'll find the HeroesService), that would make the VillainsService available everywhere in the application, including the Hero workflows.

If you generated the provider using ionic-cli, it'll automatically add it to the root AppModule.

Sign up to request clarification or add additional context in comments.

2 Comments

Hi thanks for helping. I just tried that and now i am getting the following error: Error: No provider for DatabaseProvider! I removed it from the AppModule and added it via the @Component providers but its saying there is no provider. Any idea why?
I believe you have to implement Lazy Loading for your providers. Take a look at this: angular.io/guide/ngmodule#lazy-loaded-ngmodule-providers

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.