@angular-architects/ngrx-toolkit 18.0.0-rc.2.0 → 18.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -104,4 +104,4 @@ export function withUndoRedo(options = {}) {
104
104
  },
105
105
  }));
106
106
  }
107
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-undo-redo.js","sourceRoot":"","sources":["../../../../../libs/ngrx-toolkit/src/lib/with-undo-redo.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  SignalStoreFeature,\n  patchState,\n  signalStoreFeature,\n  withComputed,\n  withHooks,\n  withMethods,\n} from '@ngrx/signals';\nimport { EntityId, EntityMap, EntityState } from '@ngrx/signals/entities';\nimport { Signal, effect, signal, untracked, isSignal } from '@angular/core';\nimport { Entity, capitalize } from './with-data-service';\nimport {\n  EntityComputed,\n  NamedEntityComputed,\n} from './shared/signal-store-models';\n\nexport type StackItem = Record<string, unknown>;\n\nexport type NormalizedUndoRedoOptions = {\n  maxStackSize: number;\n  collections?: string[];\n};\n\nconst defaultOptions: NormalizedUndoRedoOptions = {\n  maxStackSize: 100,\n};\n\nexport type NamedUndoRedoState<Collection extends string> = {\n  [K in Collection as `${K}EntityMap`]: EntityMap<Entity>;\n} & {\n  [K in Collection as `${K}Ids`]: EntityId[];\n};\n\nexport type NamedUndoRedoSignals<Collection extends string> = {\n  [K in Collection as `${K}Entities`]: Signal<Entity[]>;\n};\n\nexport function getUndoRedoKeys(collections?: string[]): string[] {\n  if (collections) {\n    return collections.flatMap((c) => [\n      `${c}EntityMap`,\n      `${c}Ids`,\n      `selected${capitalize(c)}Ids`,\n      `${c}Filter`,\n    ]);\n  }\n  return ['entityMap', 'ids', 'selectedIds', 'filter'];\n}\n\nexport function withUndoRedo<Collection extends string>(options?: {\n  maxStackSize?: number;\n  collections: Collection[];\n}): SignalStoreFeature<\n  {\n    state: {};\n    // This alternative breaks type inference:\n    // state: NamedEntityState<Entity, Collection>\n    computed: NamedEntityComputed<Entity, Collection>;\n    methods: {};\n  },\n  {\n    state: {};\n    computed: {\n      canUndo: Signal<boolean>;\n      canRedo: Signal<boolean>;\n    };\n    methods: {\n      undo: () => void;\n      redo: () => void;\n    };\n  }\n>;\n\nexport function withUndoRedo(options?: {\n  maxStackSize?: number;\n}): SignalStoreFeature<\n  {\n    state: EntityState<Entity>;\n    computed: EntityComputed<Entity>;\n    methods: {};\n  },\n  {\n    state: {};\n    computed: {\n      canUndo: Signal<boolean>;\n      canRedo: Signal<boolean>;\n    };\n    methods: {\n      undo: () => void;\n      redo: () => void;\n    };\n  }\n>;\n\nexport function withUndoRedo<Collection extends string>(\n  options: {\n    maxStackSize?: number;\n    collections?: Collection[];\n  } = {}\n): // eslint-disable-next-line @typescript-eslint/no-explicit-any\nSignalStoreFeature<any, any> {\n  let previous: StackItem | null = null;\n  let skipOnce = false;\n\n  const normalized = {\n    ...defaultOptions,\n    ...options,\n  };\n\n  //\n  // Design Decision: This feature has its own\n  // internal state.\n  //\n\n  const undoStack: StackItem[] = [];\n  const redoStack: StackItem[] = [];\n\n  const canUndo = signal(false);\n  const canRedo = signal(false);\n\n  const updateInternal = () => {\n    canUndo.set(undoStack.length !== 0);\n    canRedo.set(redoStack.length !== 0);\n  };\n\n  const keys = getUndoRedoKeys(normalized?.collections);\n\n  return signalStoreFeature(\n    withComputed(() => ({\n      canUndo: canUndo.asReadonly(),\n      canRedo: canRedo.asReadonly(),\n    })),\n    withMethods((store) => ({\n      undo(): void {\n        const item = undoStack.pop();\n\n        if (item && previous) {\n          redoStack.push(previous);\n        }\n\n        if (item) {\n          skipOnce = true;\n          patchState(store, item);\n          previous = item;\n        }\n\n        updateInternal();\n      },\n      redo(): void {\n        const item = redoStack.pop();\n\n        if (item && previous) {\n          undoStack.push(previous);\n        }\n\n        if (item) {\n          skipOnce = true;\n          patchState(store, item);\n          previous = item;\n        }\n\n        updateInternal();\n      },\n    })),\n    withHooks({\n      onInit(store: Record<string, unknown>) {\n        effect(() => {\n          const cand = keys.reduce((acc, key) => {\n            const s = store[key];\n            if (s && isSignal(s)) {\n              return {\n                ...acc,\n                [key]: s(),\n              };\n            }\n            return acc;\n          }, {});\n\n          if (skipOnce) {\n            skipOnce = false;\n            return;\n          }\n\n          //\n          // Deep Comparison to prevent duplicated entries\n          // on the stack. This can e.g. happen after an undo\n          // if the component sends back the undone filter\n          // to the store.\n          //\n          if (JSON.stringify(cand) === JSON.stringify(previous)) {\n            return;\n          }\n\n          // Clear redoStack after recorded action\n          redoStack.splice(0);\n\n          if (previous) {\n            undoStack.push(previous);\n          }\n\n          if (redoStack.length > normalized.maxStackSize) {\n            undoStack.unshift();\n          }\n\n          previous = cand;\n\n          // Don't propogate current reactive context\n          untracked(() => updateInternal());\n        });\n      },\n    })\n  );\n}\n"]}
107
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-undo-redo.js","sourceRoot":"","sources":["../../../../../libs/ngrx-toolkit/src/lib/with-undo-redo.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  SignalStoreFeature,\n  patchState,\n  signalStoreFeature,\n  withComputed,\n  withHooks,\n  withMethods,\n  EmptyFeatureResult,\n} from '@ngrx/signals';\nimport { EntityId, EntityMap, EntityState } from '@ngrx/signals/entities';\nimport { Signal, effect, signal, untracked, isSignal } from '@angular/core';\nimport { Entity, capitalize } from './with-data-service';\nimport {\n  EntityComputed,\n  NamedEntityComputed,\n} from './shared/signal-store-models';\n\nexport type StackItem = Record<string, unknown>;\n\nexport type NormalizedUndoRedoOptions = {\n  maxStackSize: number;\n  collections?: string[];\n};\n\nconst defaultOptions: NormalizedUndoRedoOptions = {\n  maxStackSize: 100,\n};\n\nexport function getUndoRedoKeys(collections?: string[]): string[] {\n  if (collections) {\n    return collections.flatMap((c) => [\n      `${c}EntityMap`,\n      `${c}Ids`,\n      `selected${capitalize(c)}Ids`,\n      `${c}Filter`,\n    ]);\n  }\n  return ['entityMap', 'ids', 'selectedIds', 'filter'];\n}\n\nexport function withUndoRedo<Collection extends string>(options?: {\n  maxStackSize?: number;\n  collections: Collection[];\n}): SignalStoreFeature<\n  EmptyFeatureResult & {\n    computed: NamedEntityComputed<Entity, Collection>;\n  },\n  EmptyFeatureResult & {\n    computed: {\n      canUndo: Signal<boolean>;\n      canRedo: Signal<boolean>;\n    };\n    methods: {\n      undo: () => void;\n      redo: () => void;\n    };\n  }\n>;\n\nexport function withUndoRedo(options?: {\n  maxStackSize?: number;\n}): SignalStoreFeature<\n  EmptyFeatureResult & {\n    state: EntityState<Entity>;\n    computed: EntityComputed<Entity>;\n  },\n  EmptyFeatureResult & {\n    computed: {\n      canUndo: Signal<boolean>;\n      canRedo: Signal<boolean>;\n    };\n    methods: {\n      undo: () => void;\n      redo: () => void;\n    };\n  }\n>;\n\nexport function withUndoRedo<Collection extends string>(\n  options: {\n    maxStackSize?: number;\n    collections?: Collection[];\n  } = {}\n): // eslint-disable-next-line @typescript-eslint/no-explicit-any\nSignalStoreFeature<any, any> {\n  let previous: StackItem | null = null;\n  let skipOnce = false;\n\n  const normalized = {\n    ...defaultOptions,\n    ...options,\n  };\n\n  //\n  // Design Decision: This feature has its own\n  // internal state.\n  //\n\n  const undoStack: StackItem[] = [];\n  const redoStack: StackItem[] = [];\n\n  const canUndo = signal(false);\n  const canRedo = signal(false);\n\n  const updateInternal = () => {\n    canUndo.set(undoStack.length !== 0);\n    canRedo.set(redoStack.length !== 0);\n  };\n\n  const keys = getUndoRedoKeys(normalized?.collections);\n\n  return signalStoreFeature(\n    withComputed(() => ({\n      canUndo: canUndo.asReadonly(),\n      canRedo: canRedo.asReadonly(),\n    })),\n    withMethods((store) => ({\n      undo(): void {\n        const item = undoStack.pop();\n\n        if (item && previous) {\n          redoStack.push(previous);\n        }\n\n        if (item) {\n          skipOnce = true;\n          patchState(store, item);\n          previous = item;\n        }\n\n        updateInternal();\n      },\n      redo(): void {\n        const item = redoStack.pop();\n\n        if (item && previous) {\n          undoStack.push(previous);\n        }\n\n        if (item) {\n          skipOnce = true;\n          patchState(store, item);\n          previous = item;\n        }\n\n        updateInternal();\n      },\n    })),\n    withHooks({\n      onInit(store: Record<string, unknown>) {\n        effect(() => {\n          const cand = keys.reduce((acc, key) => {\n            const s = store[key];\n            if (s && isSignal(s)) {\n              return {\n                ...acc,\n                [key]: s(),\n              };\n            }\n            return acc;\n          }, {});\n\n          if (skipOnce) {\n            skipOnce = false;\n            return;\n          }\n\n          //\n          // Deep Comparison to prevent duplicated entries\n          // on the stack. This can e.g. happen after an undo\n          // if the component sends back the undone filter\n          // to the store.\n          //\n          if (JSON.stringify(cand) === JSON.stringify(previous)) {\n            return;\n          }\n\n          // Clear redoStack after recorded action\n          redoStack.splice(0);\n\n          if (previous) {\n            undoStack.push(previous);\n          }\n\n          if (redoStack.length > normalized.maxStackSize) {\n            undoStack.unshift();\n          }\n\n          previous = cand;\n\n          // Don't propogate current reactive context\n          untracked(() => updateInternal());\n        });\n      },\n    })\n  );\n}\n"]}
@@ -86,13 +86,13 @@ const patchState = (state, action, ...rest) => {
86
86
  /**
87
87
  * Wrapper of `patchState` for DevTools integration. Next to updating the state,
88
88
  * it also sends the action to the DevTools.
89
- * @param state state of Signal Store
89
+ * @param stateSource state of Signal Store
90
90
  * @param action name of action how it will show in DevTools
91
91
  * @param updaters updater functions or objects
92
92
  */
93
- function updateState(state, action, ...updaters) {
93
+ function updateState(stateSource, action, ...updaters) {
94
94
  currentActionNames.add(action);
95
- return patchState$1(state, ...updaters);
95
+ return patchState$1(stateSource, ...updaters);
96
96
  }
97
97
 
98
98
  function assertActionFnSpecs(obj) {
@@ -237,7 +237,7 @@ function setLoaded(prop) {
237
237
  }
238
238
  }
239
239
  function setError(error, prop) {
240
- let errorMessage = '';
240
+ let errorMessage;
241
241
  if (!error) {
242
242
  errorMessage = '';
243
243
  }
@@ -612,114 +612,6 @@ function withStorageSync(configOrKey) {
612
612
  }));
613
613
  }
614
614
 
615
- function isUnsubscribable(fn) {
616
- return !!fn?.unsubscribe;
617
- }
618
- function capitalize(str) {
619
- return str ? str[0].toUpperCase() + str.substring(1) : str;
620
- }
621
- function isActionCreator(action) {
622
- return (typeof action === 'function' &&
623
- action &&
624
- action.type &&
625
- typeof action.type === 'string');
626
- }
627
-
628
- class SignalReduxStore {
629
- constructor() {
630
- this.mapperDict = {};
631
- this.dispatch = rxMethod(pipe(tap((action) => {
632
- const callbacks = this.mapperDict[action.type];
633
- if (callbacks?.storeMethod) {
634
- if (isUnsubscribable(callbacks.storeMethod) &&
635
- callbacks.resultMethod) {
636
- return callbacks.storeMethod(action, (a) => {
637
- const resultAction = callbacks.resultMethod?.(a);
638
- this.dispatch(resultAction);
639
- });
640
- }
641
- return callbacks?.storeMethod(action);
642
- }
643
- return;
644
- })));
645
- }
646
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
647
- connectFeatureStore(mappers) {
648
- mappers.forEach(mapper => mapper.types.forEach(action => this.mapperDict[action] = {
649
- storeMethod: mapper.storeMethod,
650
- resultMethod: mapper.resultMethod
651
- }));
652
- }
653
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.7", ngImport: i0, type: SignalReduxStore, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
654
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.7", ngImport: i0, type: SignalReduxStore, providedIn: 'root' }); }
655
- }
656
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.7", ngImport: i0, type: SignalReduxStore, decorators: [{
657
- type: Injectable,
658
- args: [{
659
- providedIn: 'root'
660
- }]
661
- }] });
662
- function injectReduxDispatch() {
663
- return inject(SignalReduxStore).dispatch;
664
- }
665
-
666
- function mapAction(...args) {
667
- let resultMethod = args.pop();
668
- let storeMethod = args.pop();
669
- if (isActionCreator(storeMethod)) {
670
- args.push(storeMethod);
671
- storeMethod = resultMethod || storeMethod;
672
- resultMethod = undefined;
673
- }
674
- const types = args.map((creator) => creator.type);
675
- return {
676
- types,
677
- storeMethod,
678
- resultMethod
679
- };
680
- }
681
- function withActionMappers(...mappers) {
682
- return mappers;
683
- }
684
- function createReduxState(storeName, signalStore, withActionMappers) {
685
- const isRootProvider = signalStore?.ɵprov?.providedIn === 'root';
686
- return {
687
- [`provide${capitalize(storeName)}Store`]: (connectReduxDevtools = false) => makeEnvironmentProviders([
688
- isRootProvider ? [] : signalStore,
689
- {
690
- provide: ENVIRONMENT_INITIALIZER,
691
- multi: true,
692
- useFactory: (signalReduxStore = inject(SignalReduxStore), store = inject(signalStore)) => () => {
693
- if (connectReduxDevtools) {
694
- // addStoreToReduxDevtools(store, storeName, false);
695
- }
696
- signalReduxStore.connectFeatureStore(withActionMappers(store));
697
- }
698
- }
699
- ]),
700
- [`inject${capitalize(storeName)}Store`]: () => Object.assign(inject(signalStore), { dispatch: injectReduxDispatch() })
701
- };
702
- }
703
-
704
- function reduxMethod(generator, resultMethodOrConfig, config) {
705
- const injector = inject(Injector);
706
- if (typeof resultMethodOrConfig === 'function') {
707
- let unsubscribable;
708
- const inputResultFn = ((input, resultMethod = resultMethodOrConfig) => {
709
- const rxMethodWithResult = rxMethod(pipe(generator, map(resultMethod)), {
710
- ...(config || {}),
711
- injector: config?.injector || injector
712
- });
713
- const rxWithInput = rxMethodWithResult(input);
714
- unsubscribable = { unsubscribe: rxWithInput.unsubscribe.bind(rxWithInput) };
715
- return rxWithInput;
716
- });
717
- inputResultFn.unsubscribe = () => unsubscribable?.unsubscribe();
718
- return inputResultFn;
719
- }
720
- return rxMethod(generator, resultMethodOrConfig);
721
- }
722
-
723
615
  /** With pagination comes in two flavors the first one is local pagination or in memory pagination. For example we have 2000 items which we want
724
616
  * to display in a table and the response payload is small enough to be stored in the memory. But we can not display all 2000 items at once
725
617
  * so we need to paginate the data. The second flavor is server side pagination where the response payload is too large to be stored in the memory
@@ -926,6 +818,114 @@ function createPageArray(currentPage, itemsPerPage, totalItems, paginationRange)
926
818
  return pages;
927
819
  }
928
820
 
821
+ function isUnsubscribable(fn) {
822
+ return !!fn?.unsubscribe;
823
+ }
824
+ function capitalize(str) {
825
+ return str ? str[0].toUpperCase() + str.substring(1) : str;
826
+ }
827
+ function isActionCreator(action) {
828
+ return (typeof action === 'function' &&
829
+ action &&
830
+ action.type &&
831
+ typeof action.type === 'string');
832
+ }
833
+
834
+ class SignalReduxStore {
835
+ constructor() {
836
+ this.mapperDict = {};
837
+ this.dispatch = rxMethod(pipe(tap((action) => {
838
+ const callbacks = this.mapperDict[action.type];
839
+ if (callbacks?.storeMethod) {
840
+ if (isUnsubscribable(callbacks.storeMethod) &&
841
+ callbacks.resultMethod) {
842
+ return callbacks.storeMethod(action, (a) => {
843
+ const resultAction = callbacks.resultMethod?.(a);
844
+ this.dispatch(resultAction);
845
+ });
846
+ }
847
+ return callbacks?.storeMethod(action);
848
+ }
849
+ return;
850
+ })));
851
+ }
852
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
853
+ connectFeatureStore(mappers) {
854
+ mappers.forEach(mapper => mapper.types.forEach(action => this.mapperDict[action] = {
855
+ storeMethod: mapper.storeMethod,
856
+ resultMethod: mapper.resultMethod
857
+ }));
858
+ }
859
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: SignalReduxStore, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
860
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: SignalReduxStore, providedIn: 'root' }); }
861
+ }
862
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: SignalReduxStore, decorators: [{
863
+ type: Injectable,
864
+ args: [{
865
+ providedIn: 'root'
866
+ }]
867
+ }] });
868
+ function injectReduxDispatch() {
869
+ return inject(SignalReduxStore).dispatch;
870
+ }
871
+
872
+ function mapAction(...args) {
873
+ let resultMethod = args.pop();
874
+ let storeMethod = args.pop();
875
+ if (isActionCreator(storeMethod)) {
876
+ args.push(storeMethod);
877
+ storeMethod = resultMethod || storeMethod;
878
+ resultMethod = undefined;
879
+ }
880
+ const types = args.map((creator) => creator.type);
881
+ return {
882
+ types,
883
+ storeMethod,
884
+ resultMethod
885
+ };
886
+ }
887
+ function withActionMappers(...mappers) {
888
+ return mappers;
889
+ }
890
+ function createReduxState(storeName, signalStore, withActionMappers) {
891
+ const isRootProvider = signalStore?.ɵprov?.providedIn === 'root';
892
+ return {
893
+ [`provide${capitalize(storeName)}Store`]: (connectReduxDevtools = false) => makeEnvironmentProviders([
894
+ isRootProvider ? [] : signalStore,
895
+ {
896
+ provide: ENVIRONMENT_INITIALIZER,
897
+ multi: true,
898
+ useFactory: (signalReduxStore = inject(SignalReduxStore), store = inject(signalStore)) => () => {
899
+ if (connectReduxDevtools) {
900
+ // addStoreToReduxDevtools(store, storeName, false);
901
+ }
902
+ signalReduxStore.connectFeatureStore(withActionMappers(store));
903
+ }
904
+ }
905
+ ]),
906
+ [`inject${capitalize(storeName)}Store`]: () => Object.assign(inject(signalStore), { dispatch: injectReduxDispatch() })
907
+ };
908
+ }
909
+
910
+ function reduxMethod(generator, resultMethodOrConfig, config) {
911
+ const injector = inject(Injector);
912
+ if (typeof resultMethodOrConfig === 'function') {
913
+ let unsubscribable;
914
+ const inputResultFn = ((input, resultMethod = resultMethodOrConfig) => {
915
+ const rxMethodWithResult = rxMethod(pipe(generator, map(resultMethod)), {
916
+ ...(config || {}),
917
+ injector: config?.injector || injector
918
+ });
919
+ const rxWithInput = rxMethodWithResult(input);
920
+ unsubscribable = { unsubscribe: rxWithInput.unsubscribe.bind(rxWithInput) };
921
+ return rxWithInput;
922
+ });
923
+ inputResultFn.unsubscribe = () => unsubscribable?.unsubscribe();
924
+ return inputResultFn;
925
+ }
926
+ return rxMethod(generator, resultMethodOrConfig);
927
+ }
928
+
929
929
  /**
930
930
  * Generated bundle index. Do not edit.
931
931
  */