angularfire icon indicating copy to clipboard operation
angularfire copied to clipboard

Providers and Injections should be by name or at least by Map<string,type> and not by a simple Array<type>

Open todosybuenrollo opened this issue 2 years ago • 2 comments

Version info

Angular: 14.2

Firebase: 9.9.3

AngularFire: 7.4.1

Other (e.g. Ionic/Cordova, Node, browser, operating system): Irrelevant

Expected behavior

Provide / Injection by name or Map<string,type> where the string is the name to find easy and clean your angular firebase components or have a function to findByName(name: string).

I'm not talking only about Auth, I'm talking regarding all your types but I use Auth for the examples

@NgModule({
    imports: [
        provideFirebaseApp(() => initializeApp(config)), // default app
        provideFirebaseApp(() => initializeApp(config2, 'app2')),
        provideFirebaseApp(() => initializeApp(config3, 'app3')),
        provideAuth(() => getAuth()), // from default app
        provideAuth(() => getAuth(getApp('app2'))),
        provideAuth(() => getAuth(getApp('app3'))),
    ],
})

One of the next options should be there to be use it easy:

Option 1 - Could be work with your actual Array<Type> but I think that search this search byName in this array is dirty and I recommend to not reinvent the wheel and use a Map<string,type>

constructor(
    private authApp: Auth,
    private authApp2: AuthInstances.getByName('app2'),
    private authApp3: AuthInstances.getByName('app3'),
) { }

Option 2 - Could be work with your actual Array<Type> but again I recommend to not reinvent the wheel and use a Map<string,type>

constructor(private authInstances: AuthInstances) { }

doWithAuth(name: string) {
    const auth = this.authInstances.getByName(name)   
    // the things that you want to do with your auth
}

Other options - Any idea that let you select your angular fire element more easy and clean that now.

Actual behavior

Provide / Injection is a simple Array and does not have any method to select by name.

@NgModule({
    imports: [
        provideFirebaseApp(() => initializeApp(config)), // default app
        provideFirebaseApp(() => initializeApp(config2, 'app2')),
        provideFirebaseApp(() => initializeApp(config3, 'app3')),
        provideAuth(() => getAuth()), // from default app
        provideAuth(() => getAuth(getApp('app2'))),
        provideAuth(() => getAuth(getApp('app3'))),
    ],
})
private authMap: Map<string,Auth>;
constructor(private authInstances: AuthInstances) {
    this.authInstances.forEach(auth => {
        this.authMap.set(auth.name,auth);
    });
}

Feedback

I think that your Provide / Injection should work with maps or with something that can be select the future injection by name.

Another important thing, is that you must declare a default app, if not the AuthInstaces fail because default app is not initializate and then to find this default app is so ugly name: "[DEFAULT]"

To finish, you cannot import only one auth if your auth is not default, because you have a way to import default and to import an array with default and another auths. Is there a way to inject auth: Auth by name and avoid import all the array?

Issue post from discussion: Originally posted by @todosybuenrollo in https://github.com/angular/angularfire/discussions/1026#discussioncomment-3613308

todosybuenrollo avatar Sep 10 '22 07:09 todosybuenrollo

This issue does not seem to follow the issue template. Make sure you provide all the required information.

google-oss-bot avatar Sep 10 '22 07:09 google-oss-bot

Sorry I create the issue from a post and I do not see the template, but this issue is not an issue with the code, is more a suggestion about how the code should work. I do not found how to post it directly as a suggestion in discussions, I can only answer to an open discussions

todosybuenrollo avatar Sep 10 '22 07:09 todosybuenrollo