@outbuild/supa-store 0.0.23 → 0.0.24
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.
- package/esm2022/lib/common/features/post-auth-loader.feature.mjs +12 -7
- package/esm2022/lib/common/features/supa-store-core.feature.mjs +5 -7
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/outbuild-supa-store.mjs +14 -11
- package/fesm2022/outbuild-supa-store.mjs.map +1 -1
- package/lib/common/features/post-auth-loader.feature.d.ts +2 -2
- package/lib/common/features/supa-store-core.feature.d.ts +1 -1
- package/lib/supa-store.store.d.ts +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { filter, firstValueFrom } from 'rxjs';
|
|
2
|
-
import { toObservable } from "@angular/core/rxjs-interop";
|
|
3
|
-
import { patchState, signalStoreFeature, type, withMethods } from '@ngrx/signals';
|
|
4
1
|
import { inject } from '@angular/core';
|
|
2
|
+
import { toObservable } from "@angular/core/rxjs-interop";
|
|
5
3
|
import { SUPA_STORE_OPTIONS } from '../token/supabase-credentials.token';
|
|
6
|
-
|
|
7
|
-
|
|
4
|
+
import { filter, firstValueFrom } from 'rxjs';
|
|
5
|
+
import { patchState, signalStoreFeature, type, withHooks, withMethods } from '@ngrx/signals';
|
|
6
|
+
export const withPostAuthOptions = () => signalStoreFeature({ state: type() }, withMethods((store, { postAuthOptions } = inject(SUPA_STORE_OPTIONS)) => ({
|
|
7
|
+
loader: async () => {
|
|
8
8
|
const { useLoader: { table, rpc } } = postAuthOptions;
|
|
9
9
|
if (table || rpc) {
|
|
10
10
|
const { user } = await firstValueFrom(toObservable(store.auth.session).pipe(filter(res => res !== undefined)));
|
|
@@ -23,5 +23,10 @@ export const withPostAuthLoader = () => signalStoreFeature({ state: type() }, wi
|
|
|
23
23
|
}
|
|
24
24
|
}
|
|
25
25
|
},
|
|
26
|
-
}))
|
|
27
|
-
|
|
26
|
+
})), withHooks({
|
|
27
|
+
onInit(store) {
|
|
28
|
+
/* Auto Load Additional User Auth Data */
|
|
29
|
+
store.loader();
|
|
30
|
+
}
|
|
31
|
+
}));
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9zdC1hdXRoLWxvYWRlci5mZWF0dXJlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb2Itc3VwYS1zdG9yZS9zcmMvbGliL2NvbW1vbi9mZWF0dXJlcy9wb3N0LWF1dGgtbG9hZGVyLmZlYXR1cmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUV0QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNEJBQTRCLENBQUE7QUFFekQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0scUNBQXFDLENBQUE7QUFDeEUsT0FBTyxFQUFFLE1BQU0sRUFBRSxjQUFjLEVBQWMsTUFBTSxNQUFNLENBQUE7QUFDekQsT0FBTyxFQUFFLFVBQVUsRUFBRSxrQkFBa0IsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUU1RixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxHQUFHLEVBQUUsQ0FBQyxrQkFBa0IsQ0FFekQsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFrQixFQUFFLEVBRWpDLFdBQVcsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLGVBQWUsRUFBRSxHQUFHLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBRXhFLE1BQU0sRUFBRSxLQUFLLElBQUksRUFBRTtRQUVqQixNQUFNLEVBQUUsU0FBUyxFQUFFLEVBQUUsS0FBSyxFQUFFLEdBQUcsRUFBRSxFQUFDLEdBQUcsZUFBZSxDQUFBO1FBRXBELElBQUksS0FBSyxJQUFJLEdBQUcsRUFBRSxDQUFDO1lBRWpCLE1BQU0sRUFBRSxJQUFJLEVBQUUsR0FBRyxNQUFNLGNBQWMsQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxLQUFLLFNBQVMsQ0FBQyxDQUF3QixDQUFDLENBQUE7WUFDckksSUFBSSxDQUFDLElBQUk7Z0JBQUUsT0FBTTtZQUVqQixJQUFJLEtBQUssRUFBRSxDQUFDO2dCQUNWLE1BQU0sRUFBRSxJQUFJLEVBQUUsR0FBRyxNQUFNLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFBO2dCQUN6RixVQUFVLENBQUMsS0FBSyxFQUFHLEVBQUUsSUFBSSxFQUFFLEVBQUUsR0FBRyxLQUFLLENBQUMsSUFBSSxFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxFQUFDLENBQUMsQ0FBQTtZQUNsRSxDQUFDO2lCQUFNLElBQUksR0FBRyxFQUFFLENBQUM7Z0JBQ2YsTUFBTSxFQUFFLElBQUksRUFBRSxHQUFHLE1BQU0sS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsRUFBRSxLQUFLLEVBQUUsRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxFQUFDLENBQUMsQ0FBQTtnQkFDL0UsVUFBVSxDQUFDLEtBQUssRUFBRSxFQUFFLElBQUksRUFBRSxFQUFFLEdBQUcsS0FBSyxDQUFDLElBQUksRUFBRSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsRUFBQyxDQUFDLENBQUE7WUFDakUsQ0FBQztpQkFBTSxDQUFDO2dCQUNOLFVBQVUsQ0FBQyxLQUFLLEVBQUUsRUFBRSxJQUFJLEVBQUUsRUFBRSxHQUFHLEtBQUssQ0FBQyxJQUFJLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFDLEVBQUMsQ0FBQyxDQUFBO1lBQ2hFLENBQUM7UUFFSCxDQUFDO0lBQ0gsQ0FBQztDQUVGLENBQUMsQ0FBQyxFQUVILFNBQVMsQ0FBQztJQUVSLE1BQU0sQ0FBQyxLQUFLO1FBRVYseUNBQXlDO1FBQ3pDLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQTtJQUVoQixDQUFDO0NBRUYsQ0FBQyxDQUVILENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xyXG5pbXBvcnQgeyBTZXNzaW9uIH0gZnJvbSAnQHN1cGFiYXNlL3N1cGFiYXNlLWpzJ1xyXG5pbXBvcnQgeyB0b09ic2VydmFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3BcIlxyXG5pbXBvcnQgeyBTdXBhU3RvcmVTdGF0ZSB9IGZyb20gJy4uL3R5cGUvc3VwYS1zdG9yZS50eXBlcydcclxuaW1wb3J0IHsgU1VQQV9TVE9SRV9PUFRJT05TIH0gZnJvbSAnLi4vdG9rZW4vc3VwYWJhc2UtY3JlZGVudGlhbHMudG9rZW4nXHJcbmltcG9ydCB7IGZpbHRlciwgZmlyc3RWYWx1ZUZyb20sIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJ1xyXG5pbXBvcnQgeyBwYXRjaFN0YXRlLCBzaWduYWxTdG9yZUZlYXR1cmUsIHR5cGUsIHdpdGhIb29rcywgd2l0aE1ldGhvZHMgfSBmcm9tICdAbmdyeC9zaWduYWxzJ1xyXG5cclxuZXhwb3J0IGNvbnN0IHdpdGhQb3N0QXV0aE9wdGlvbnMgPSAoKSA9PiBzaWduYWxTdG9yZUZlYXR1cmUoXHJcblxyXG4gIHsgc3RhdGU6IHR5cGU8U3VwYVN0b3JlU3RhdGU+KCkgfSxcclxuXHJcbiAgd2l0aE1ldGhvZHMoKHN0b3JlLCB7IHBvc3RBdXRoT3B0aW9ucyB9ID0gaW5qZWN0KFNVUEFfU1RPUkVfT1BUSU9OUykpID0+ICh7XHJcblxyXG4gICAgbG9hZGVyOiBhc3luYyAoKSA9PiB7XHJcblxyXG4gICAgICBjb25zdCB7IHVzZUxvYWRlcjogeyB0YWJsZSwgcnBjIH19ID0gcG9zdEF1dGhPcHRpb25zXHJcblxyXG4gICAgICBpZiAodGFibGUgfHwgcnBjKSB7XHJcblxyXG4gICAgICAgIGNvbnN0IHsgdXNlciB9ID0gYXdhaXQgZmlyc3RWYWx1ZUZyb20odG9PYnNlcnZhYmxlKHN0b3JlLmF1dGguc2Vzc2lvbikucGlwZShmaWx0ZXIocmVzID0+IHJlcyAhPT0gdW5kZWZpbmVkKSkgYXMgT2JzZXJ2YWJsZTxTZXNzaW9uPilcclxuICAgICAgICBpZiAoIXVzZXIpIHJldHVyblxyXG5cclxuICAgICAgICBpZiAodGFibGUpIHtcclxuICAgICAgICAgIGNvbnN0IHsgZGF0YSB9ID0gYXdhaXQgc3RvcmUuY2xpZW50KCkuZnJvbSh0YWJsZSkuc2VsZWN0KCcqJykuZXEoJ2lkJywgdXNlcj8uaWQpLnNpbmdsZSgpXHJcbiAgICAgICAgICBwYXRjaFN0YXRlKHN0b3JlLCAgeyBhdXRoOiB7IC4uLnN0b3JlLmF1dGgoKSwgbWV0YWRhdGE6IGRhdGEgfX0pXHJcbiAgICAgICAgfSBlbHNlIGlmIChycGMpIHtcclxuICAgICAgICAgIGNvbnN0IHsgZGF0YSB9ID0gYXdhaXQgc3RvcmUuY2xpZW50KCkucnBjKHJwYywgeyBpbnB1dDogeyB1c2VyX2lkOiB1c2VyPy5pZCB9fSlcclxuICAgICAgICAgIHBhdGNoU3RhdGUoc3RvcmUsIHsgYXV0aDogeyAuLi5zdG9yZS5hdXRoKCksIG1ldGFkYXRhOiBkYXRhIH19KVxyXG4gICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICBwYXRjaFN0YXRlKHN0b3JlLCB7IGF1dGg6IHsgLi4uc3RvcmUuYXV0aCgpLCBtZXRhZGF0YTogbnVsbH19KVxyXG4gICAgICAgIH1cclxuXHJcbiAgICAgIH1cclxuICAgIH0sXHJcblxyXG4gIH0pKSxcclxuXHJcbiAgd2l0aEhvb2tzKHtcclxuXHJcbiAgICBvbkluaXQoc3RvcmUpIHtcclxuXHJcbiAgICAgIC8qIEF1dG8gTG9hZCBBZGRpdGlvbmFsIFVzZXIgQXV0aCBEYXRhICovXHJcbiAgICAgIHN0b3JlLmxvYWRlcigpXHJcblxyXG4gICAgfVxyXG5cclxuICB9KVxyXG5cclxuKVxyXG4iXX0=
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { inject } from '@angular/core';
|
|
2
2
|
import { withDevtools } from '@angular-architects/ngrx-toolkit';
|
|
3
3
|
import { INITIAL_STATE } from '../token/initial-state.token';
|
|
4
|
-
import {
|
|
4
|
+
import { withPostAuthOptions } from '../features/post-auth-loader.feature';
|
|
5
5
|
import { patchState, signalStoreFeature, withHooks, withMethods, withState } from '@ngrx/signals';
|
|
6
|
-
export const withSupaStoreCore = () => signalStoreFeature(withDevtools('supaStore'), withState(() => inject(INITIAL_STATE)),
|
|
6
|
+
export const withSupaStoreCore = () => signalStoreFeature(withDevtools('supaStore'), withState(() => inject(INITIAL_STATE)), withPostAuthOptions(), withMethods(store => ({
|
|
7
7
|
initSession: async () => {
|
|
8
8
|
const { data: { session } } = await store.client().auth.getSession();
|
|
9
9
|
patchState(store, { auth: { ...store.auth(), session } });
|
|
@@ -11,17 +11,15 @@ export const withSupaStoreCore = () => signalStoreFeature(withDevtools('supaStor
|
|
|
11
11
|
initUser: async () => {
|
|
12
12
|
const { data: { user } } = await store.client().auth.getUser();
|
|
13
13
|
patchState(store, { auth: { ...store.auth(), user } });
|
|
14
|
-
}
|
|
14
|
+
}
|
|
15
15
|
})), withHooks({
|
|
16
|
-
|
|
16
|
+
onInit(store) {
|
|
17
17
|
/* Listen For Auth Atate Changes */
|
|
18
18
|
store.client().auth.onAuthStateChange(state => patchState(store, { auth: { ...store.auth(), state: { prev: store.auth.state.curr(), curr: state } } }));
|
|
19
19
|
/* Init Supabase Session */
|
|
20
20
|
store.initSession();
|
|
21
21
|
/* Init Supabase User */
|
|
22
22
|
store.initUser();
|
|
23
|
-
/* Checks & Loads Data In 'postAuthOptions' */
|
|
24
|
-
store.postAuthLoader();
|
|
25
23
|
}
|
|
26
24
|
}));
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VwYS1zdG9yZS1jb3JlLmZlYXR1cmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vYi1zdXBhLXN0b3JlL3NyYy9saWIvY29tbW9uL2ZlYXR1cmVzL3N1cGEtc3RvcmUtY29yZS5mZWF0dXJlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGtDQUFrQyxDQUFBO0FBQy9ELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQTtBQUU1RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQTtBQUMxRSxPQUFPLEVBQUUsVUFBVSxFQUFFLGtCQUFrQixFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBRWpHLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLEdBQUcsRUFBRSxDQUFDLGtCQUFrQixDQUV2RCxZQUFZLENBQUMsV0FBVyxDQUFDLEVBQ3pCLFNBQVMsQ0FBaUIsR0FBRyxFQUFFLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDLEVBQ3RELG1CQUFtQixFQUFFLEVBRXJCLFdBQVcsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUM7SUFFcEIsV0FBVyxFQUFFLEtBQUssSUFBSSxFQUFFO1FBQ3RCLE1BQU0sRUFBRSxJQUFJLEVBQUUsRUFBRSxPQUFPLEVBQUUsRUFBQyxHQUFHLE1BQU0sS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQTtRQUNuRSxVQUFVLENBQUMsS0FBSyxFQUFFLEVBQUUsSUFBSSxFQUFFLEVBQUUsR0FBRyxLQUFLLENBQUMsSUFBSSxFQUFFLEVBQUUsT0FBTyxFQUFFLEVBQUMsQ0FBQyxDQUFBO0lBQzFELENBQUM7SUFFRCxRQUFRLEVBQUUsS0FBSyxJQUFJLEVBQUU7UUFDbkIsTUFBTSxFQUFFLElBQUksRUFBRSxFQUFFLElBQUksRUFBRSxFQUFDLEdBQUcsTUFBTSxLQUFLLENBQUMsTUFBTSxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFBO1FBQzdELFVBQVUsQ0FBQyxLQUFLLEVBQUUsRUFBRSxJQUFJLEVBQUUsRUFBRSxHQUFHLEtBQUssQ0FBQyxJQUFJLEVBQUUsRUFBRSxJQUFJLEVBQUUsRUFBQyxDQUFDLENBQUE7SUFDdkQsQ0FBQztDQUVGLENBQUMsQ0FBQyxFQUVILFNBQVMsQ0FBQztJQUVSLE1BQU0sQ0FBQyxLQUFLO1FBRVYsbUNBQW1DO1FBQ25DLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLEVBQUUsSUFBSSxFQUFFLEVBQUUsR0FBRyxLQUFLLENBQUMsSUFBSSxFQUFFLEVBQUUsS0FBSyxFQUFFLEVBQUUsSUFBSSxFQUFFLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsRUFBRSxFQUFDLENBQUMsQ0FBQyxDQUFBO1FBRXRKLDJCQUEyQjtRQUMzQixLQUFLLENBQUMsV0FBVyxFQUFFLENBQUE7UUFFbkIsd0JBQXdCO1FBQ3hCLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQTtJQUVsQixDQUFDO0NBRUYsQ0FBQyxDQUVILENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgd2l0aERldnRvb2xzIH0gZnJvbSAnQGFuZ3VsYXItYXJjaGl0ZWN0cy9uZ3J4LXRvb2xraXQnXHJcbmltcG9ydCB7IElOSVRJQUxfU1RBVEUgfSBmcm9tICcuLi90b2tlbi9pbml0aWFsLXN0YXRlLnRva2VuJ1xyXG5pbXBvcnQgeyBTdXBhU3RvcmVTdGF0ZSB9IGZyb20gJy4uL3R5cGUvc3VwYS1zdG9yZS50eXBlcydcclxuaW1wb3J0IHsgd2l0aFBvc3RBdXRoT3B0aW9ucyB9IGZyb20gJy4uL2ZlYXR1cmVzL3Bvc3QtYXV0aC1sb2FkZXIuZmVhdHVyZSdcclxuaW1wb3J0IHsgcGF0Y2hTdGF0ZSwgc2lnbmFsU3RvcmVGZWF0dXJlLCB3aXRoSG9va3MsIHdpdGhNZXRob2RzLCB3aXRoU3RhdGUgfSBmcm9tICdAbmdyeC9zaWduYWxzJ1xyXG5cclxuZXhwb3J0IGNvbnN0IHdpdGhTdXBhU3RvcmVDb3JlID0gKCkgPT4gc2lnbmFsU3RvcmVGZWF0dXJlKFxyXG5cclxuICB3aXRoRGV2dG9vbHMoJ3N1cGFTdG9yZScpLFxyXG4gIHdpdGhTdGF0ZTxTdXBhU3RvcmVTdGF0ZT4oKCkgPT4gaW5qZWN0KElOSVRJQUxfU1RBVEUpKSxcclxuICB3aXRoUG9zdEF1dGhPcHRpb25zKCksXHJcblxyXG4gIHdpdGhNZXRob2RzKHN0b3JlID0+ICh7XHJcblxyXG4gICAgaW5pdFNlc3Npb246IGFzeW5jICgpID0+IHtcclxuICAgICAgY29uc3QgeyBkYXRhOiB7IHNlc3Npb24gfX0gPSBhd2FpdCBzdG9yZS5jbGllbnQoKS5hdXRoLmdldFNlc3Npb24oKVxyXG4gICAgICBwYXRjaFN0YXRlKHN0b3JlLCB7IGF1dGg6IHsgLi4uc3RvcmUuYXV0aCgpLCBzZXNzaW9uIH19KVxyXG4gICAgfSxcclxuXHJcbiAgICBpbml0VXNlcjogYXN5bmMgKCkgPT4ge1xyXG4gICAgICBjb25zdCB7IGRhdGE6IHsgdXNlciB9fSA9IGF3YWl0IHN0b3JlLmNsaWVudCgpLmF1dGguZ2V0VXNlcigpXHJcbiAgICAgIHBhdGNoU3RhdGUoc3RvcmUsIHsgYXV0aDogeyAuLi5zdG9yZS5hdXRoKCksIHVzZXIgfX0pXHJcbiAgICB9XHJcblxyXG4gIH0pKSxcclxuXHJcbiAgd2l0aEhvb2tzKHtcclxuXHJcbiAgICBvbkluaXQoc3RvcmUpIHtcclxuXHJcbiAgICAgIC8qIExpc3RlbiBGb3IgQXV0aCBBdGF0ZSBDaGFuZ2VzICovXHJcbiAgICAgIHN0b3JlLmNsaWVudCgpLmF1dGgub25BdXRoU3RhdGVDaGFuZ2Uoc3RhdGUgPT4gcGF0Y2hTdGF0ZShzdG9yZSwgeyBhdXRoOiB7IC4uLnN0b3JlLmF1dGgoKSwgc3RhdGU6IHsgcHJldjogc3RvcmUuYXV0aC5zdGF0ZS5jdXJyKCksIGN1cnI6IHN0YXRlIH0gfX0pKVxyXG5cclxuICAgICAgLyogSW5pdCBTdXBhYmFzZSBTZXNzaW9uICovXHJcbiAgICAgIHN0b3JlLmluaXRTZXNzaW9uKClcclxuXHJcbiAgICAgIC8qIEluaXQgU3VwYWJhc2UgVXNlciAqL1xyXG4gICAgICBzdG9yZS5pbml0VXNlcigpXHJcblxyXG4gICAgfVxyXG5cclxuICB9KVxyXG5cclxuKVxyXG4iXX0=
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -3,4 +3,6 @@
|
|
|
3
3
|
*/
|
|
4
4
|
export * from './lib/supa-store.store';
|
|
5
5
|
export * from './lib/supa-store.provider';
|
|
6
|
-
|
|
6
|
+
export * from './lib/common/features/supa-store-core.feature';
|
|
7
|
+
export * from './lib/common/type/supa-store.types';
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL29iLXN1cGEtc3RvcmUvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0VBRUU7QUFFRixjQUFjLHdCQUF3QixDQUFBO0FBQ3RDLGNBQWMsMkJBQTJCLENBQUE7QUFDekMsY0FBYywrQ0FBK0MsQ0FBQTtBQUM3RCxjQUFjLG9DQUFvQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG9iLXN1cGEtc3RvcmVcclxuKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N1cGEtc3RvcmUuc3RvcmUnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N1cGEtc3RvcmUucHJvdmlkZXInXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbW1vbi9mZWF0dXJlcy9zdXBhLXN0b3JlLWNvcmUuZmVhdHVyZSdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tbW9uL3R5cGUvc3VwYS1zdG9yZS50eXBlcydcclxuIl19
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { signalStoreFeature, type, withMethods, patchState,
|
|
1
|
+
import { signalStoreFeature, type, withMethods, patchState, withHooks, withState, signalStore } from '@ngrx/signals';
|
|
2
2
|
import { InjectionToken, inject, makeEnvironmentProviders } from '@angular/core';
|
|
3
3
|
import { withDevtools } from '@angular-architects/ngrx-toolkit';
|
|
4
4
|
import { createClient } from '@supabase/supabase-js';
|
|
5
|
-
import { firstValueFrom, filter } from 'rxjs';
|
|
6
5
|
import { toObservable } from '@angular/core/rxjs-interop';
|
|
6
|
+
import { firstValueFrom, filter } from 'rxjs';
|
|
7
7
|
import { merge } from 'lodash-es';
|
|
8
8
|
|
|
9
9
|
const SUPA_STORE_OPTIONS = new InjectionToken('SUPA_STORE_OPTIONS');
|
|
@@ -23,8 +23,8 @@ const INITIAL_STATE = new InjectionToken('SupaStoreState', {
|
|
|
23
23
|
},
|
|
24
24
|
});
|
|
25
25
|
|
|
26
|
-
const
|
|
27
|
-
|
|
26
|
+
const withPostAuthOptions = () => signalStoreFeature({ state: type() }, withMethods((store, { postAuthOptions } = inject(SUPA_STORE_OPTIONS)) => ({
|
|
27
|
+
loader: async () => {
|
|
28
28
|
const { useLoader: { table, rpc } } = postAuthOptions;
|
|
29
29
|
if (table || rpc) {
|
|
30
30
|
const { user } = await firstValueFrom(toObservable(store.auth.session).pipe(filter(res => res !== undefined)));
|
|
@@ -43,9 +43,14 @@ const withPostAuthLoader = () => signalStoreFeature({ state: type() }, withMetho
|
|
|
43
43
|
}
|
|
44
44
|
}
|
|
45
45
|
},
|
|
46
|
-
}))
|
|
46
|
+
})), withHooks({
|
|
47
|
+
onInit(store) {
|
|
48
|
+
/* Auto Load Additional User Auth Data */
|
|
49
|
+
store.loader();
|
|
50
|
+
}
|
|
51
|
+
}));
|
|
47
52
|
|
|
48
|
-
const withSupaStoreCore = () => signalStoreFeature(withDevtools('supaStore'), withState(() => inject(INITIAL_STATE)),
|
|
53
|
+
const withSupaStoreCore = () => signalStoreFeature(withDevtools('supaStore'), withState(() => inject(INITIAL_STATE)), withPostAuthOptions(), withMethods(store => ({
|
|
49
54
|
initSession: async () => {
|
|
50
55
|
const { data: { session } } = await store.client().auth.getSession();
|
|
51
56
|
patchState(store, { auth: { ...store.auth(), session } });
|
|
@@ -53,17 +58,15 @@ const withSupaStoreCore = () => signalStoreFeature(withDevtools('supaStore'), wi
|
|
|
53
58
|
initUser: async () => {
|
|
54
59
|
const { data: { user } } = await store.client().auth.getUser();
|
|
55
60
|
patchState(store, { auth: { ...store.auth(), user } });
|
|
56
|
-
}
|
|
61
|
+
}
|
|
57
62
|
})), withHooks({
|
|
58
|
-
|
|
63
|
+
onInit(store) {
|
|
59
64
|
/* Listen For Auth Atate Changes */
|
|
60
65
|
store.client().auth.onAuthStateChange(state => patchState(store, { auth: { ...store.auth(), state: { prev: store.auth.state.curr(), curr: state } } }));
|
|
61
66
|
/* Init Supabase Session */
|
|
62
67
|
store.initSession();
|
|
63
68
|
/* Init Supabase User */
|
|
64
69
|
store.initUser();
|
|
65
|
-
/* Checks & Loads Data In 'postAuthOptions' */
|
|
66
|
-
store.postAuthLoader();
|
|
67
70
|
}
|
|
68
71
|
}));
|
|
69
72
|
|
|
@@ -93,5 +96,5 @@ const provideSupaStore = (opts) => {
|
|
|
93
96
|
* Generated bundle index. Do not edit.
|
|
94
97
|
*/
|
|
95
98
|
|
|
96
|
-
export { SupaStore, provideSupaStore };
|
|
99
|
+
export { SupaStore, provideSupaStore, withSupaStoreCore };
|
|
97
100
|
//# sourceMappingURL=outbuild-supa-store.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"outbuild-supa-store.mjs","sources":["../../../projects/ob-supa-store/src/lib/common/token/supabase-credentials.token.ts","../../../projects/ob-supa-store/src/lib/common/token/initial-state.token.ts","../../../projects/ob-supa-store/src/lib/common/features/post-auth-loader.feature.ts","../../../projects/ob-supa-store/src/lib/common/features/supa-store-core.feature.ts","../../../projects/ob-supa-store/src/lib/supa-store.store.ts","../../../projects/ob-supa-store/src/lib/supa-store.provider.ts","../../../projects/ob-supa-store/src/public-api.ts","../../../projects/ob-supa-store/src/outbuild-supa-store.ts"],"sourcesContent":["import { InjectionToken } from \"@angular/core\"\r\nimport { SupaStoreOptions } from \"../type/supa-store.types\"\r\n\r\nexport const SUPA_STORE_OPTIONS = new InjectionToken<SupaStoreOptions>('SUPA_STORE_OPTIONS')\r\n","import { inject, InjectionToken } from \"@angular/core\"\r\nimport { SUPA_STORE_OPTIONS } from \"./supabase-credentials.token\"\r\nimport { createClient } from \"@supabase/supabase-js\"\r\nimport { SupaStoreState } from \"../type/supa-store.types\"\r\n\r\nexport const INITIAL_STATE = new InjectionToken<SupaStoreState>('SupaStoreState', {\r\n factory: () => {\r\n\r\n const { supabaseUrl, supabaseKey } = inject(SUPA_STORE_OPTIONS)\r\n\r\n return {\r\n client: createClient(supabaseUrl, supabaseKey),\r\n auth: {\r\n session: undefined,\r\n user: undefined,\r\n metadata: undefined,\r\n state: { prev: null, curr: null }\r\n }\r\n }\r\n\r\n },\r\n})\r\n","import {
|
|
1
|
+
{"version":3,"file":"outbuild-supa-store.mjs","sources":["../../../projects/ob-supa-store/src/lib/common/token/supabase-credentials.token.ts","../../../projects/ob-supa-store/src/lib/common/token/initial-state.token.ts","../../../projects/ob-supa-store/src/lib/common/features/post-auth-loader.feature.ts","../../../projects/ob-supa-store/src/lib/common/features/supa-store-core.feature.ts","../../../projects/ob-supa-store/src/lib/supa-store.store.ts","../../../projects/ob-supa-store/src/lib/supa-store.provider.ts","../../../projects/ob-supa-store/src/public-api.ts","../../../projects/ob-supa-store/src/outbuild-supa-store.ts"],"sourcesContent":["import { InjectionToken } from \"@angular/core\"\r\nimport { SupaStoreOptions } from \"../type/supa-store.types\"\r\n\r\nexport const SUPA_STORE_OPTIONS = new InjectionToken<SupaStoreOptions>('SUPA_STORE_OPTIONS')\r\n","import { inject, InjectionToken } from \"@angular/core\"\r\nimport { SUPA_STORE_OPTIONS } from \"./supabase-credentials.token\"\r\nimport { createClient } from \"@supabase/supabase-js\"\r\nimport { SupaStoreState } from \"../type/supa-store.types\"\r\n\r\nexport const INITIAL_STATE = new InjectionToken<SupaStoreState>('SupaStoreState', {\r\n factory: () => {\r\n\r\n const { supabaseUrl, supabaseKey } = inject(SUPA_STORE_OPTIONS)\r\n\r\n return {\r\n client: createClient(supabaseUrl, supabaseKey),\r\n auth: {\r\n session: undefined,\r\n user: undefined,\r\n metadata: undefined,\r\n state: { prev: null, curr: null }\r\n }\r\n }\r\n\r\n },\r\n})\r\n","import { inject } from '@angular/core'\r\nimport { Session } from '@supabase/supabase-js'\r\nimport { toObservable } from \"@angular/core/rxjs-interop\"\r\nimport { SupaStoreState } from '../type/supa-store.types'\r\nimport { SUPA_STORE_OPTIONS } from '../token/supabase-credentials.token'\r\nimport { filter, firstValueFrom, Observable } from 'rxjs'\r\nimport { patchState, signalStoreFeature, type, withHooks, withMethods } from '@ngrx/signals'\r\n\r\nexport const withPostAuthOptions = () => signalStoreFeature(\r\n\r\n { state: type<SupaStoreState>() },\r\n\r\n withMethods((store, { postAuthOptions } = inject(SUPA_STORE_OPTIONS)) => ({\r\n\r\n loader: async () => {\r\n\r\n const { useLoader: { table, rpc }} = postAuthOptions\r\n\r\n if (table || rpc) {\r\n\r\n const { user } = await firstValueFrom(toObservable(store.auth.session).pipe(filter(res => res !== undefined)) as Observable<Session>)\r\n if (!user) return\r\n\r\n if (table) {\r\n const { data } = await store.client().from(table).select('*').eq('id', user?.id).single()\r\n patchState(store, { auth: { ...store.auth(), metadata: data }})\r\n } else if (rpc) {\r\n const { data } = await store.client().rpc(rpc, { input: { user_id: user?.id }})\r\n patchState(store, { auth: { ...store.auth(), metadata: data }})\r\n } else {\r\n patchState(store, { auth: { ...store.auth(), metadata: null}})\r\n }\r\n\r\n }\r\n },\r\n\r\n })),\r\n\r\n withHooks({\r\n\r\n onInit(store) {\r\n\r\n /* Auto Load Additional User Auth Data */\r\n store.loader()\r\n\r\n }\r\n\r\n })\r\n\r\n)\r\n","import { inject } from '@angular/core';\r\nimport { withDevtools } from '@angular-architects/ngrx-toolkit'\r\nimport { INITIAL_STATE } from '../token/initial-state.token'\r\nimport { SupaStoreState } from '../type/supa-store.types'\r\nimport { withPostAuthOptions } from '../features/post-auth-loader.feature'\r\nimport { patchState, signalStoreFeature, withHooks, withMethods, withState } from '@ngrx/signals'\r\n\r\nexport const withSupaStoreCore = () => signalStoreFeature(\r\n\r\n withDevtools('supaStore'),\r\n withState<SupaStoreState>(() => inject(INITIAL_STATE)),\r\n withPostAuthOptions(),\r\n\r\n withMethods(store => ({\r\n\r\n initSession: async () => {\r\n const { data: { session }} = await store.client().auth.getSession()\r\n patchState(store, { auth: { ...store.auth(), session }})\r\n },\r\n\r\n initUser: async () => {\r\n const { data: { user }} = await store.client().auth.getUser()\r\n patchState(store, { auth: { ...store.auth(), user }})\r\n }\r\n\r\n })),\r\n\r\n withHooks({\r\n\r\n onInit(store) {\r\n\r\n /* Listen For Auth Atate Changes */\r\n store.client().auth.onAuthStateChange(state => patchState(store, { auth: { ...store.auth(), state: { prev: store.auth.state.curr(), curr: state } }}))\r\n\r\n /* Init Supabase Session */\r\n store.initSession()\r\n\r\n /* Init Supabase User */\r\n store.initUser()\r\n\r\n }\r\n\r\n })\r\n\r\n)\r\n","import { signalStore } from '@ngrx/signals'\r\nimport { withSupaStoreCore } from './common/features/supa-store-core.feature'\r\n\r\nexport const SupaStore = signalStore(\r\n withSupaStoreCore()\r\n)\r\n","import { EnvironmentProviders, makeEnvironmentProviders } from \"@angular/core\"\r\nimport { SupaStore } from \"./supa-store.store\"\r\nimport { SUPA_STORE_OPTIONS } from \"./common/token/supabase-credentials.token\"\r\nimport { SupaStoreOptions } from \"./common/type/supa-store.types\"\r\nimport { merge } from \"lodash-es\"\r\n\r\nconst defaultOptions: Partial<SupaStoreOptions> = {\r\n postAuthOptions: {\r\n useLoader: { rpc: null, table: null }\r\n }\r\n}\r\n\r\nexport const provideSupaStore = (opts: SupaStoreOptions): EnvironmentProviders => {\r\n\r\n const options = merge(defaultOptions, opts)\r\n\r\n return makeEnvironmentProviders([\r\n {\r\n provide: SUPA_STORE_OPTIONS,\r\n useValue: options\r\n },\r\n SupaStore\r\n ])\r\n}\r\n","/*\r\n * Public API Surface of ob-supa-store\r\n*/\r\n\r\nexport * from './lib/supa-store.store'\r\nexport * from './lib/supa-store.provider'\r\nexport * from './lib/common/features/supa-store-core.feature'\r\nexport * from './lib/common/type/supa-store.types'\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { SupaStoreState } from '../type/supa-store.types';
|
|
2
|
-
export declare const
|
|
2
|
+
export declare const withPostAuthOptions: () => import("@ngrx/signals").SignalStoreFeature<{
|
|
3
3
|
state: SupaStoreState;
|
|
4
4
|
computed: {};
|
|
5
5
|
methods: {};
|
|
@@ -7,6 +7,6 @@ export declare const withPostAuthLoader: () => import("@ngrx/signals").SignalSto
|
|
|
7
7
|
state: {};
|
|
8
8
|
computed: {};
|
|
9
9
|
methods: {
|
|
10
|
-
|
|
10
|
+
loader: () => Promise<void>;
|
|
11
11
|
};
|
|
12
12
|
}>;
|
|
@@ -13,7 +13,7 @@ export declare const withSupaStoreCore: () => import("@ngrx/signals").SignalStor
|
|
|
13
13
|
};
|
|
14
14
|
computed: {};
|
|
15
15
|
methods: {
|
|
16
|
-
|
|
16
|
+
loader: () => Promise<void>;
|
|
17
17
|
initSession: () => Promise<void>;
|
|
18
18
|
initUser: () => Promise<void>;
|
|
19
19
|
};
|
|
@@ -9,7 +9,7 @@ export declare const SupaStore: import("@angular/core").Type<{
|
|
|
9
9
|
curr: import("@supabase/auth-js").AuthChangeEvent | null;
|
|
10
10
|
};
|
|
11
11
|
}>;
|
|
12
|
-
|
|
12
|
+
loader: () => Promise<void>;
|
|
13
13
|
initSession: () => Promise<void>;
|
|
14
14
|
initUser: () => Promise<void>;
|
|
15
15
|
} & import("@ngrx/signals").StateSource<{
|
package/package.json
CHANGED
package/public-api.d.ts
CHANGED