UNPKG

@rx-signals/angular-provider

Version:
105 lines 14.6 kB
import { makeEnvironmentProviders, NgModule } from '@angular/core'; import { Store } from '@rx-signals/store'; import * as i0 from "@angular/core"; // The root store is a singleton that should live as long as the whole application // In case other lifecycles are required (e.g. restricted to the lifecycle of // a certain module), corresponding child-stores should be derived from the // root store const rootStore = new Store(); export class RxSignalsStoreModule { /** * Use withRootStore, if you want the root store (the store that shares the lifecycle of the whole application). * If your module is a lazy-loaded feature module, it will still receive the same root-store instance, if you use withRootStore. * This should be the standard case. * Pass as many setup functions as you like. * * @param {SetupWithStore[]} setups - 0 to n optional setup functions (that will be called with the store instance) * @returns {ModuleWithProviders<RxSignalsStoreModule>} the module providing the root-store */ static withRootStore(...setups) { let doSetup = true; return { ngModule: RxSignalsStoreModule, providers: [{ provide: Store, useFactory: () => { // It's necessary to use a factory instead of useValue, because otherwise the doSetup block would not run in ngZone if (doSetup) { doSetup = false; setups.forEach(setup => setup(rootStore)); } return rootStore; } }], }; } /** * Use withChildStore, if you need a child store that is derived from the root-store. * See store.createChildStore() for further documentation on child stores. * * @param {SetupWithStore[]} setups - 0 to n optional setup functions (that will be called with the child-store instance) * @returns {ModuleWithProviders<RxSignalsStoreModule>} the module providing the child-store */ static withChildStore(...setups) { let doSetup = true; const childStore = rootStore.createChildStore(); return { ngModule: RxSignalsStoreModule, providers: [{ provide: Store, useFactory: () => { if (doSetup) { doSetup = false; setups.forEach(setup => setup(childStore)); } return childStore; } }], }; } } RxSignalsStoreModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.5", ngImport: i0, type: RxSignalsStoreModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); RxSignalsStoreModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.5", ngImport: i0, type: RxSignalsStoreModule }); RxSignalsStoreModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.5", ngImport: i0, type: RxSignalsStoreModule, providers: [{ provide: Store, useValue: rootStore }] // default to rootStore, if none of the static providers is used }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.5", ngImport: i0, type: RxSignalsStoreModule, decorators: [{ type: NgModule, args: [{ providers: [{ provide: Store, useValue: rootStore }] // default to rootStore, if none of the static providers is used }] }] }); /** * Use provideStore, in bootstrapApplication to provide the rx-signals root-store (the store that shares the lifecycle of the whole application). * Pass as many setup functions as you like. * * @param {SetupWithStore[]} setups - 0 to n optional setup functions (that will be called with the store instance) */ export const provideStore = (...setups) => { let doSetup = true; return makeEnvironmentProviders([ { provide: Store, useFactory: () => { // It's necessary to use a factory instead of useValue, because otherwise the doSetup block would not run in ngZone if (doSetup) { doSetup = false; setups.forEach(setup => setup(rootStore)); } return rootStore; } } ]); }; /** * Use provideChildStore, in Route.providers to provide a rx-signals child-store to the route. * See store.createChildStore() for further documentation on child stores. * Pass as many setup functions as you like. * * @param {SetupWithStore[]} setups - 0 to n optional setup functions (that will be called with the child-store instance) */ export const provideChildStore = (...setups) => { let doSetup = true; const childStore = rootStore.createChildStore(); return makeEnvironmentProviders([ { provide: Store, useFactory: () => { // It's necessary to use a factory instead of useValue, because otherwise the doSetup block would not run in ngZone if (doSetup) { doSetup = false; setups.forEach(setup => setup(childStore)); } return childStore; } } ]); }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rx-signals-store.module.js","sourceRoot":"","sources":["../../../../../projects/rx-signals/angular-provider/src/lib/rx-signals-store.module.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  EnvironmentProviders,\r\n  makeEnvironmentProviders,\r\n  ModuleWithProviders,\r\n  NgModule\r\n} from '@angular/core';\r\nimport { Store } from '@rx-signals/store';\r\n\r\n/**\r\n * The argument type for store providers\r\n */\r\nexport type SetupWithStore = (store: Store) => void;\r\n\r\n// The root store is a singleton that should live as long as the whole application\r\n// In case other lifecycles are required (e.g. restricted to the lifecycle of\r\n// a certain module), corresponding child-stores should be derived from the\r\n// root store\r\nconst rootStore = new Store();\r\n\r\n@NgModule({\r\n  providers: [{ provide: Store, useValue: rootStore }] // default to rootStore, if none of the static providers is used\r\n})\r\nexport class RxSignalsStoreModule {\r\n  \r\n  /**\r\n   * Use withRootStore, if you want the root store (the store that shares the lifecycle of the whole application).\r\n   * If your module is a lazy-loaded feature module, it will still receive the same root-store instance, if you use withRootStore.\r\n   * This should be the standard case.\r\n   * Pass as many setup functions as you like.\r\n   *\r\n   * @param {SetupWithStore[]} setups - 0 to n optional setup functions (that will be called with the store instance)\r\n   * @returns {ModuleWithProviders<RxSignalsStoreModule>} the module providing the root-store\r\n   */\r\n  static withRootStore(...setups: SetupWithStore[]): ModuleWithProviders<RxSignalsStoreModule> {\r\n    let doSetup = true;\r\n    return {\r\n      ngModule: RxSignalsStoreModule,\r\n      providers: [{ provide: Store, useFactory: () => {\r\n        // It's necessary to use a factory instead of useValue, because otherwise the doSetup block would not run in ngZone\r\n        if (doSetup) {\r\n          doSetup = false;\r\n          setups.forEach(setup => setup(rootStore));\r\n        }\r\n        return rootStore;\r\n      }}],\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Use withChildStore, if you need a child store that is derived from the root-store.\r\n   * See store.createChildStore() for further documentation on child stores.\r\n   *\r\n   * @param {SetupWithStore[]} setups - 0 to n optional setup functions (that will be called with the child-store instance)\r\n   * @returns {ModuleWithProviders<RxSignalsStoreModule>} the module providing the child-store\r\n   */\r\n  static withChildStore(...setups: SetupWithStore[]): ModuleWithProviders<RxSignalsStoreModule> {\r\n    let doSetup = true;\r\n    const childStore = rootStore.createChildStore();\r\n    return {\r\n      ngModule: RxSignalsStoreModule,\r\n      providers: [{ provide: Store, useFactory: () => {\r\n        if (doSetup) {\r\n          doSetup = false;\r\n          setups.forEach(setup => setup(childStore));\r\n        }\r\n        return childStore;\r\n      }}],\r\n    };\r\n  }\r\n}\r\n\r\n/**\r\n * Use provideStore, in bootstrapApplication to provide the rx-signals root-store (the store that shares the lifecycle of the whole application).\r\n * Pass as many setup functions as you like.\r\n *\r\n * @param {SetupWithStore[]} setups - 0 to n optional setup functions (that will be called with the store instance)\r\n */\r\nexport const provideStore = (...setups: SetupWithStore[]): EnvironmentProviders => {\r\n  let doSetup = true;\r\n  return makeEnvironmentProviders([\r\n    { provide: Store, useFactory: () => {\r\n      // It's necessary to use a factory instead of useValue, because otherwise the doSetup block would not run in ngZone\r\n      if (doSetup) {\r\n        doSetup = false;\r\n        setups.forEach(setup => setup(rootStore));\r\n      }\r\n      return rootStore;\r\n    }}\r\n  ]);\r\n};\r\n\r\n/**\r\n * Use provideChildStore, in Route.providers to provide a rx-signals child-store to the route.\r\n * See store.createChildStore() for further documentation on child stores.\r\n * Pass as many setup functions as you like.\r\n *\r\n * @param {SetupWithStore[]} setups - 0 to n optional setup functions (that will be called with the child-store instance)\r\n */\r\nexport const provideChildStore = (...setups: SetupWithStore[]): EnvironmentProviders => {\r\n  let doSetup = true;\r\n  const childStore = rootStore.createChildStore();\r\n  return makeEnvironmentProviders([\r\n    { provide: Store, useFactory: () => {\r\n        // It's necessary to use a factory instead of useValue, because otherwise the doSetup block would not run in ngZone\r\n        if (doSetup) {\r\n          doSetup = false;\r\n          setups.forEach(setup => setup(childStore));\r\n        }\r\n        return childStore;\r\n      }}\r\n  ]);\r\n};\r\n"]}