@outbuild/supa-store 0.0.27 → 0.0.29
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 +5 -4
- package/esm2022/lib/common/features/supa-store-core.feature.mjs +16 -9
- package/esm2022/lib/common/services/supabase.service.mjs +17 -0
- package/esm2022/lib/common/token/initial-state.token.mjs +5 -7
- package/esm2022/lib/common/type/supa-store.types.mjs +1 -1
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/outbuild-supa-store.mjs +33 -28
- package/fesm2022/outbuild-supa-store.mjs.map +1 -1
- package/lib/common/features/supa-store-core.feature.d.ts +0 -1
- package/lib/common/services/supabase.service.d.ts +8 -0
- package/lib/common/type/supa-store.types.d.ts +1 -2
- package/lib/supa-store.store.d.ts +0 -2
- package/package.json +2 -2
- package/public-api.d.ts +1 -0
|
@@ -3,9 +3,10 @@ import { toObservable } from "@angular/core/rxjs-interop";
|
|
|
3
3
|
import { SUPA_STORE_OPTIONS } from '../token/supabase-credentials.token';
|
|
4
4
|
import { filter, firstValueFrom } from 'rxjs';
|
|
5
5
|
import { patchState, signalStoreFeature, type, withHooks, withMethods } from '@ngrx/signals';
|
|
6
|
+
import { SupabaseService } from '../services/supabase.service';
|
|
6
7
|
export const withPostAuthOptions = () => signalStoreFeature({
|
|
7
8
|
state: type()
|
|
8
|
-
}, withMethods((store, { postAuthOptions } = inject(SUPA_STORE_OPTIONS)) => ({
|
|
9
|
+
}, withMethods((store, { postAuthOptions } = inject(SUPA_STORE_OPTIONS), { client } = inject(SupabaseService)) => ({
|
|
9
10
|
_loader: async () => {
|
|
10
11
|
const { useLoader: { table, rpc } } = postAuthOptions;
|
|
11
12
|
if (table || rpc) {
|
|
@@ -13,11 +14,11 @@ export const withPostAuthOptions = () => signalStoreFeature({
|
|
|
13
14
|
if (!session)
|
|
14
15
|
return;
|
|
15
16
|
if (table) {
|
|
16
|
-
const { data } = await
|
|
17
|
+
const { data } = await client.from(table).select('*').eq('id', session?.user?.id).single();
|
|
17
18
|
patchState(store, { auth: { ...store.auth(), metadata: data } });
|
|
18
19
|
}
|
|
19
20
|
else if (rpc) {
|
|
20
|
-
const { data } = await
|
|
21
|
+
const { data } = await client.rpc(rpc, { input: { user_id: session?.user?.id } });
|
|
21
22
|
patchState(store, { auth: { ...store.auth(), metadata: data } });
|
|
22
23
|
}
|
|
23
24
|
else {
|
|
@@ -31,4 +32,4 @@ export const withPostAuthOptions = () => signalStoreFeature({
|
|
|
31
32
|
store._loader();
|
|
32
33
|
}
|
|
33
34
|
}));
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9zdC1hdXRoLWxvYWRlci5mZWF0dXJlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb2Itc3VwYS1zdG9yZS9zcmMvbGliL2NvbW1vbi9mZWF0dXJlcy9wb3N0LWF1dGgtbG9hZGVyLmZlYXR1cmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUV0QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNEJBQTRCLENBQUE7QUFFekQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0scUNBQXFDLENBQUE7QUFDeEUsT0FBTyxFQUFFLE1BQU0sRUFBRSxjQUFjLEVBQWMsTUFBTSxNQUFNLENBQUE7QUFDekQsT0FBTyxFQUFFLFVBQVUsRUFBRSxrQkFBa0IsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUM1RixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sOEJBQThCLENBQUE7QUFFOUQsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsR0FBRyxFQUFFLENBQUMsa0JBQWtCLENBRXpEO0lBQ0UsS0FBSyxFQUFFLElBQUksRUFBa0I7Q0FDOUIsRUFFRCxXQUFXLENBQUMsQ0FDVixLQUFLLEVBQ0wsRUFBRSxlQUFlLEVBQUUsR0FBRyxNQUFNLENBQUMsa0JBQWtCLENBQUMsRUFDaEQsRUFBRSxNQUFNLEVBQUUsR0FBRyxNQUFNLENBQUMsZUFBZSxDQUFDLEVBQ3BDLEVBQUUsQ0FBQyxDQUFDO0lBRUosT0FBTyxFQUFFLEtBQUssSUFBSSxFQUFFO1FBRWxCLE1BQU0sRUFBRSxTQUFTLEVBQUUsRUFBRSxLQUFLLEVBQUUsR0FBRyxFQUFFLEVBQUMsR0FBRyxlQUFlLENBQUE7UUFFcEQsSUFBSSxLQUFLLElBQUksR0FBRyxFQUFFLENBQUM7WUFFakIsTUFBTSxPQUFPLEdBQUcsTUFBTSxjQUFjLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsS0FBSyxTQUFTLENBQUMsQ0FBd0IsQ0FBQyxDQUFBO1lBQ3BJLElBQUksQ0FBQyxPQUFPO2dCQUFFLE9BQU07WUFFcEIsSUFBSSxLQUFLLEVBQUUsQ0FBQztnQkFDVixNQUFNLEVBQUUsSUFBSSxFQUFFLEdBQUcsTUFBTSxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUE7Z0JBQzFGLFVBQVUsQ0FBQyxLQUFLLEVBQUcsRUFBRSxJQUFJLEVBQUUsRUFBRSxHQUFHLEtBQUssQ0FBQyxJQUFJLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLEVBQUMsQ0FBQyxDQUFBO1lBQ2xFLENBQUM7aUJBQU0sSUFBSSxHQUFHLEVBQUUsQ0FBQztnQkFDZixNQUFNLEVBQUUsSUFBSSxFQUFFLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxFQUFFLEtBQUssRUFBRSxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxFQUFDLENBQUMsQ0FBQTtnQkFDaEYsVUFBVSxDQUFDLEtBQUssRUFBRSxFQUFFLElBQUksRUFBRSxFQUFFLEdBQUcsS0FBSyxDQUFDLElBQUksRUFBRSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsRUFBQyxDQUFDLENBQUE7WUFDakUsQ0FBQztpQkFBTSxDQUFDO2dCQUNOLFVBQVUsQ0FBQyxLQUFLLEVBQUUsRUFBRSxJQUFJLEVBQUUsRUFBRSxHQUFHLEtBQUssQ0FBQyxJQUFJLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFDLEVBQUMsQ0FBQyxDQUFBO1lBQ2hFLENBQUM7UUFFSCxDQUFDO0lBQ0gsQ0FBQztDQUVGLENBQUMsQ0FBQyxFQUVILFNBQVMsQ0FBQztJQUVSLE1BQU0sQ0FBQyxLQUFLO1FBRVYseUNBQXlDO1FBQ3pDLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQTtJQUVqQixDQUFDO0NBRUYsQ0FBQyxDQUVILENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xyXG5pbXBvcnQgeyBTZXNzaW9uIH0gZnJvbSAnQHN1cGFiYXNlL3N1cGFiYXNlLWpzJ1xyXG5pbXBvcnQgeyB0b09ic2VydmFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3BcIlxyXG5pbXBvcnQgeyBTdXBhU3RvcmVTdGF0ZSB9IGZyb20gJy4uL3R5cGUvc3VwYS1zdG9yZS50eXBlcydcclxuaW1wb3J0IHsgU1VQQV9TVE9SRV9PUFRJT05TIH0gZnJvbSAnLi4vdG9rZW4vc3VwYWJhc2UtY3JlZGVudGlhbHMudG9rZW4nXHJcbmltcG9ydCB7IGZpbHRlciwgZmlyc3RWYWx1ZUZyb20sIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJ1xyXG5pbXBvcnQgeyBwYXRjaFN0YXRlLCBzaWduYWxTdG9yZUZlYXR1cmUsIHR5cGUsIHdpdGhIb29rcywgd2l0aE1ldGhvZHMgfSBmcm9tICdAbmdyeC9zaWduYWxzJ1xyXG5pbXBvcnQgeyBTdXBhYmFzZVNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9zdXBhYmFzZS5zZXJ2aWNlJ1xyXG5cclxuZXhwb3J0IGNvbnN0IHdpdGhQb3N0QXV0aE9wdGlvbnMgPSAoKSA9PiBzaWduYWxTdG9yZUZlYXR1cmUoXHJcblxyXG4gIHtcclxuICAgIHN0YXRlOiB0eXBlPFN1cGFTdG9yZVN0YXRlPigpXHJcbiAgfSxcclxuXHJcbiAgd2l0aE1ldGhvZHMoKFxyXG4gICAgc3RvcmUsXHJcbiAgICB7IHBvc3RBdXRoT3B0aW9ucyB9ID0gaW5qZWN0KFNVUEFfU1RPUkVfT1BUSU9OUyksXHJcbiAgICB7IGNsaWVudCB9ID0gaW5qZWN0KFN1cGFiYXNlU2VydmljZSlcclxuICApID0+ICh7XHJcblxyXG4gICAgX2xvYWRlcjogYXN5bmMgKCkgPT4ge1xyXG5cclxuICAgICAgY29uc3QgeyB1c2VMb2FkZXI6IHsgdGFibGUsIHJwYyB9fSA9IHBvc3RBdXRoT3B0aW9uc1xyXG5cclxuICAgICAgaWYgKHRhYmxlIHx8IHJwYykge1xyXG5cclxuICAgICAgICBjb25zdCBzZXNzaW9uID0gYXdhaXQgZmlyc3RWYWx1ZUZyb20odG9PYnNlcnZhYmxlKHN0b3JlLmF1dGguc2Vzc2lvbikucGlwZShmaWx0ZXIocmVzID0+IHJlcyAhPT0gdW5kZWZpbmVkKSkgYXMgT2JzZXJ2YWJsZTxTZXNzaW9uPilcclxuICAgICAgICBpZiAoIXNlc3Npb24pIHJldHVyblxyXG5cclxuICAgICAgICBpZiAodGFibGUpIHtcclxuICAgICAgICAgIGNvbnN0IHsgZGF0YSB9ID0gYXdhaXQgY2xpZW50LmZyb20odGFibGUpLnNlbGVjdCgnKicpLmVxKCdpZCcsIHNlc3Npb24/LnVzZXI/LmlkKS5zaW5nbGUoKVxyXG4gICAgICAgICAgcGF0Y2hTdGF0ZShzdG9yZSwgIHsgYXV0aDogeyAuLi5zdG9yZS5hdXRoKCksIG1ldGFkYXRhOiBkYXRhIH19KVxyXG4gICAgICAgIH0gZWxzZSBpZiAocnBjKSB7XHJcbiAgICAgICAgICBjb25zdCB7IGRhdGEgfSA9IGF3YWl0IGNsaWVudC5ycGMocnBjLCB7IGlucHV0OiB7IHVzZXJfaWQ6IHNlc3Npb24/LnVzZXI/LmlkIH19KVxyXG4gICAgICAgICAgcGF0Y2hTdGF0ZShzdG9yZSwgeyBhdXRoOiB7IC4uLnN0b3JlLmF1dGgoKSwgbWV0YWRhdGE6IGRhdGEgfX0pXHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgIHBhdGNoU3RhdGUoc3RvcmUsIHsgYXV0aDogeyAuLi5zdG9yZS5hdXRoKCksIG1ldGFkYXRhOiBudWxsfX0pXHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgfVxyXG4gICAgfSxcclxuXHJcbiAgfSkpLFxyXG5cclxuICB3aXRoSG9va3Moe1xyXG5cclxuICAgIG9uSW5pdChzdG9yZSkge1xyXG5cclxuICAgICAgLyogQXV0byBMb2FkIEFkZGl0aW9uYWwgVXNlciBBdXRoIERhdGEgKi9cclxuICAgICAgc3RvcmUuX2xvYWRlcigpXHJcblxyXG4gICAgfVxyXG5cclxuICB9KVxyXG5cclxuKVxyXG4iXX0=
|
|
@@ -1,26 +1,33 @@
|
|
|
1
1
|
import { inject } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { withDevtools } from '@angular-architects/ngrx-toolkit';
|
|
3
3
|
import { withPostAuthOptions } from '../features/post-auth-loader.feature';
|
|
4
4
|
import { patchState, signalStoreFeature, withHooks, withMethods, withState } from '@ngrx/signals';
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
5
|
+
import { SupabaseService } from '../services/supabase.service';
|
|
6
|
+
export const withSupaStoreCore = () => signalStoreFeature(withDevtools('supaStore'), withState({
|
|
7
|
+
// client,
|
|
8
|
+
auth: {
|
|
9
|
+
session: undefined,
|
|
10
|
+
user: undefined,
|
|
11
|
+
metadata: undefined,
|
|
12
|
+
state: { prev: null, curr: null }
|
|
13
|
+
}
|
|
14
|
+
}), withPostAuthOptions(), withMethods((store, { client } = inject(SupabaseService)) => ({
|
|
8
15
|
_initSession: async () => {
|
|
9
|
-
const { data: { session }, error } = await
|
|
16
|
+
const { data: { session }, error } = await client.auth.getSession();
|
|
10
17
|
patchState(store, { auth: { ...store.auth(), session } });
|
|
11
18
|
},
|
|
12
19
|
_initUser: async () => {
|
|
13
|
-
const { data: { user }, error } = await
|
|
20
|
+
const { data: { user }, error } = await client.auth.getUser();
|
|
14
21
|
patchState(store, { auth: { ...store.auth(), user } });
|
|
15
22
|
}
|
|
16
23
|
})), withHooks({
|
|
17
|
-
onInit(store) {
|
|
24
|
+
onInit(store, { client } = inject(SupabaseService)) {
|
|
18
25
|
/* Listen For Auth Atate Changes */
|
|
19
|
-
|
|
26
|
+
client.auth.onAuthStateChange(state => patchState(store, { auth: { ...store.auth(), state: { prev: store.auth.state.curr(), curr: state } } }));
|
|
20
27
|
/* Init Supabase Session */
|
|
21
28
|
store._initSession();
|
|
22
29
|
/* Init Supabase User */
|
|
23
30
|
store._initUser();
|
|
24
31
|
}
|
|
25
32
|
}));
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VwYS1zdG9yZS1jb3JlLmZlYXR1cmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vYi1zdXBhLXN0b3JlL3NyYy9saWIvY29tbW9uL2ZlYXR1cmVzL3N1cGEtc3RvcmUtY29yZS5mZWF0dXJlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGtDQUFrQyxDQUFBO0FBRy9ELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHNDQUFzQyxDQUFBO0FBQzFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsa0JBQWtCLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDakcsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDhCQUE4QixDQUFBO0FBRTlELE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLEdBQUcsRUFBRSxDQUFDLGtCQUFrQixDQUV2RCxZQUFZLENBQUMsV0FBVyxDQUFDLEVBQ3pCLFNBQVMsQ0FBaUI7SUFDeEIsVUFBVTtJQUNWLElBQUksRUFBRTtRQUNKLE9BQU8sRUFBRSxTQUFTO1FBQ2xCLElBQUksRUFBRSxTQUFTO1FBQ2YsUUFBUSxFQUFFLFNBQVM7UUFDbkIsS0FBSyxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFO0tBQ2xDO0NBQ0YsQ0FBQyxFQUNGLG1CQUFtQixFQUFFLEVBRXJCLFdBQVcsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLE1BQU0sRUFBRSxHQUFHLE1BQU0sQ0FBQyxlQUFlLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUU1RCxZQUFZLEVBQUUsS0FBSyxJQUFJLEVBQUU7UUFDdkIsTUFBTSxFQUFFLElBQUksRUFBRSxFQUFFLE9BQU8sRUFBRSxFQUFFLEtBQUssRUFBQyxHQUFHLE1BQU0sTUFBTSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQTtRQUNsRSxVQUFVLENBQUMsS0FBSyxFQUFFLEVBQUUsSUFBSSxFQUFFLEVBQUUsR0FBRyxLQUFLLENBQUMsSUFBSSxFQUFFLEVBQUUsT0FBTyxFQUFFLEVBQUMsQ0FBQyxDQUFBO0lBQzFELENBQUM7SUFFRCxTQUFTLEVBQUUsS0FBSyxJQUFJLEVBQUU7UUFDcEIsTUFBTSxFQUFFLElBQUksRUFBRSxFQUFFLElBQUksRUFBRSxFQUFFLEtBQUssRUFBRSxHQUFHLE1BQU0sTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQTtRQUM3RCxVQUFVLENBQUMsS0FBSyxFQUFFLEVBQUUsSUFBSSxFQUFFLEVBQUUsR0FBRyxLQUFLLENBQUMsSUFBSSxFQUFFLEVBQUUsSUFBSSxFQUFFLEVBQUMsQ0FBQyxDQUFBO0lBQ3ZELENBQUM7Q0FFRixDQUFDLENBQUMsRUFFSCxTQUFTLENBQUM7SUFFUixNQUFNLENBQUMsS0FBSyxFQUFFLEVBQUMsTUFBTSxFQUFDLEdBQUcsTUFBTSxDQUFDLGVBQWUsQ0FBQztRQUU5QyxtQ0FBbUM7UUFDbkMsTUFBTSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsRUFBRSxJQUFJLEVBQUUsRUFBRSxHQUFHLEtBQUssQ0FBQyxJQUFJLEVBQUUsRUFBRSxLQUFLLEVBQUUsRUFBRSxJQUFJLEVBQUUsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxFQUFFLEVBQUMsQ0FBQyxDQUFDLENBQUE7UUFFOUksMkJBQTJCO1FBQzNCLEtBQUssQ0FBQyxZQUFZLEVBQUUsQ0FBQTtRQUVwQix3QkFBd0I7UUFDeEIsS0FBSyxDQUFDLFNBQVMsRUFBRSxDQUFBO0lBRW5CLENBQUM7Q0FFRixDQUFDLENBRUgsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyB3aXRoRGV2dG9vbHMgfSBmcm9tICdAYW5ndWxhci1hcmNoaXRlY3RzL25ncngtdG9vbGtpdCdcclxuaW1wb3J0IHsgSU5JVElBTF9TVEFURSB9IGZyb20gJy4uL3Rva2VuL2luaXRpYWwtc3RhdGUudG9rZW4nXHJcbmltcG9ydCB7IFN1cGFTdG9yZVN0YXRlIH0gZnJvbSAnLi4vdHlwZS9zdXBhLXN0b3JlLnR5cGVzJ1xyXG5pbXBvcnQgeyB3aXRoUG9zdEF1dGhPcHRpb25zIH0gZnJvbSAnLi4vZmVhdHVyZXMvcG9zdC1hdXRoLWxvYWRlci5mZWF0dXJlJ1xyXG5pbXBvcnQgeyBwYXRjaFN0YXRlLCBzaWduYWxTdG9yZUZlYXR1cmUsIHdpdGhIb29rcywgd2l0aE1ldGhvZHMsIHdpdGhTdGF0ZSB9IGZyb20gJ0BuZ3J4L3NpZ25hbHMnXHJcbmltcG9ydCB7IFN1cGFiYXNlU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL3N1cGFiYXNlLnNlcnZpY2UnXHJcblxyXG5leHBvcnQgY29uc3Qgd2l0aFN1cGFTdG9yZUNvcmUgPSAoKSA9PiBzaWduYWxTdG9yZUZlYXR1cmUoXHJcblxyXG4gIHdpdGhEZXZ0b29scygnc3VwYVN0b3JlJyksXHJcbiAgd2l0aFN0YXRlPFN1cGFTdG9yZVN0YXRlPih7XHJcbiAgICAvLyBjbGllbnQsXHJcbiAgICBhdXRoOiB7XHJcbiAgICAgIHNlc3Npb246IHVuZGVmaW5lZCxcclxuICAgICAgdXNlcjogdW5kZWZpbmVkLFxyXG4gICAgICBtZXRhZGF0YTogdW5kZWZpbmVkLFxyXG4gICAgICBzdGF0ZTogeyBwcmV2OiBudWxsLCBjdXJyOiBudWxsIH1cclxuICAgIH1cclxuICB9KSxcclxuICB3aXRoUG9zdEF1dGhPcHRpb25zKCksXHJcblxyXG4gIHdpdGhNZXRob2RzKChzdG9yZSwgeyBjbGllbnQgfSA9IGluamVjdChTdXBhYmFzZVNlcnZpY2UpKSA9PiAoe1xyXG5cclxuICAgIF9pbml0U2Vzc2lvbjogYXN5bmMgKCkgPT4ge1xyXG4gICAgICBjb25zdCB7IGRhdGE6IHsgc2Vzc2lvbiB9LCBlcnJvcn0gPSBhd2FpdCBjbGllbnQuYXV0aC5nZXRTZXNzaW9uKClcclxuICAgICAgcGF0Y2hTdGF0ZShzdG9yZSwgeyBhdXRoOiB7IC4uLnN0b3JlLmF1dGgoKSwgc2Vzc2lvbiB9fSlcclxuICAgIH0sXHJcblxyXG4gICAgX2luaXRVc2VyOiBhc3luYyAoKSA9PiB7XHJcbiAgICAgIGNvbnN0IHsgZGF0YTogeyB1c2VyIH0sIGVycm9yIH0gPSBhd2FpdCBjbGllbnQuYXV0aC5nZXRVc2VyKClcclxuICAgICAgcGF0Y2hTdGF0ZShzdG9yZSwgeyBhdXRoOiB7IC4uLnN0b3JlLmF1dGgoKSwgdXNlciB9fSlcclxuICAgIH1cclxuXHJcbiAgfSkpLFxyXG5cclxuICB3aXRoSG9va3Moe1xyXG5cclxuICAgIG9uSW5pdChzdG9yZSwge2NsaWVudH0gPSBpbmplY3QoU3VwYWJhc2VTZXJ2aWNlKSkge1xyXG5cclxuICAgICAgLyogTGlzdGVuIEZvciBBdXRoIEF0YXRlIENoYW5nZXMgKi9cclxuICAgICAgY2xpZW50LmF1dGgub25BdXRoU3RhdGVDaGFuZ2Uoc3RhdGUgPT4gcGF0Y2hTdGF0ZShzdG9yZSwgeyBhdXRoOiB7IC4uLnN0b3JlLmF1dGgoKSwgc3RhdGU6IHsgcHJldjogc3RvcmUuYXV0aC5zdGF0ZS5jdXJyKCksIGN1cnI6IHN0YXRlIH0gfX0pKVxyXG5cclxuICAgICAgLyogSW5pdCBTdXBhYmFzZSBTZXNzaW9uICovXHJcbiAgICAgIHN0b3JlLl9pbml0U2Vzc2lvbigpXHJcblxyXG4gICAgICAvKiBJbml0IFN1cGFiYXNlIFVzZXIgKi9cclxuICAgICAgc3RvcmUuX2luaXRVc2VyKClcclxuXHJcbiAgICB9XHJcblxyXG4gIH0pXHJcblxyXG4pXHJcbiJdfQ==
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { inject, Injectable } from '@angular/core';
|
|
2
|
+
import { SUPA_STORE_OPTIONS } from '../token/supabase-credentials.token';
|
|
3
|
+
import { createClient } from '@supabase/supabase-js';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class SupabaseService {
|
|
6
|
+
supaStoreOptions = inject(SUPA_STORE_OPTIONS);
|
|
7
|
+
client = createClient(this.supaStoreOptions?.supabaseUrl, this.supaStoreOptions?.supabaseKey);
|
|
8
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: SupabaseService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
9
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: SupabaseService, providedIn: 'root' });
|
|
10
|
+
}
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: SupabaseService, decorators: [{
|
|
12
|
+
type: Injectable,
|
|
13
|
+
args: [{
|
|
14
|
+
providedIn: 'root'
|
|
15
|
+
}]
|
|
16
|
+
}] });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VwYWJhc2Uuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL29iLXN1cGEtc3RvcmUvc3JjL2xpYi9jb21tb24vc2VydmljZXMvc3VwYWJhc2Uuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQTtBQUN4RSxPQUFPLEVBQUUsWUFBWSxFQUFrQixNQUFNLHVCQUF1QixDQUFBOztBQUtwRSxNQUFNLE9BQU8sZUFBZTtJQUVuQixnQkFBZ0IsR0FBUyxNQUFNLENBQUMsa0JBQWtCLENBQUMsQ0FBQTtJQUNuRCxNQUFNLEdBQW1CLFlBQVksQ0FDMUMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLFdBQVcsRUFDbEMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLFdBQVcsQ0FDbkMsQ0FBQTt1R0FOVSxlQUFlOzJHQUFmLGVBQWUsY0FGZCxNQUFNOzsyRkFFUCxlQUFlO2tCQUgzQixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBTVVBBX1NUT1JFX09QVElPTlMgfSBmcm9tICcuLi90b2tlbi9zdXBhYmFzZS1jcmVkZW50aWFscy50b2tlbidcclxuaW1wb3J0IHsgY3JlYXRlQ2xpZW50LCBTdXBhYmFzZUNsaWVudCB9IGZyb20gJ0BzdXBhYmFzZS9zdXBhYmFzZS1qcydcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIFN1cGFiYXNlU2VydmljZSB7XHJcblxyXG4gIHB1YmxpYyBzdXBhU3RvcmVPcHRpb25zICAgICAgID0gaW5qZWN0KFNVUEFfU1RPUkVfT1BUSU9OUylcclxuICBwdWJsaWMgY2xpZW50OiBTdXBhYmFzZUNsaWVudCA9IGNyZWF0ZUNsaWVudChcclxuICAgIHRoaXMuc3VwYVN0b3JlT3B0aW9ucz8uc3VwYWJhc2VVcmwsXHJcbiAgICB0aGlzLnN1cGFTdG9yZU9wdGlvbnM/LnN1cGFiYXNlS2V5XHJcbiAgKVxyXG5cclxufVxyXG4iXX0=
|
|
@@ -1,12 +1,10 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { SUPA_STORE_OPTIONS } from "./supabase-credentials.token";
|
|
3
|
-
import { createClient } from "@supabase/supabase-js";
|
|
1
|
+
import { InjectionToken } from "@angular/core";
|
|
4
2
|
export const INITIAL_STATE = new InjectionToken('SupaStoreState', {
|
|
5
3
|
factory: () => {
|
|
6
|
-
const { supabaseUrl, supabaseKey } = inject(SUPA_STORE_OPTIONS)
|
|
7
|
-
const client = createClient(supabaseUrl, supabaseKey)
|
|
4
|
+
// const { supabaseUrl, supabaseKey } = inject(SUPA_STORE_OPTIONS)
|
|
5
|
+
// const client = createClient(supabaseUrl, supabaseKey)
|
|
8
6
|
return {
|
|
9
|
-
client,
|
|
7
|
+
// client,
|
|
10
8
|
auth: {
|
|
11
9
|
session: undefined,
|
|
12
10
|
user: undefined,
|
|
@@ -16,4 +14,4 @@ export const INITIAL_STATE = new InjectionToken('SupaStoreState', {
|
|
|
16
14
|
};
|
|
17
15
|
},
|
|
18
16
|
});
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5pdGlhbC1zdGF0ZS50b2tlbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL29iLXN1cGEtc3RvcmUvc3JjL2xpYi9jb21tb24vdG9rZW4vaW5pdGlhbC1zdGF0ZS50b2tlbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQVUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBS3RELE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRyxJQUFJLGNBQWMsQ0FBaUIsZ0JBQWdCLEVBQUU7SUFDaEYsT0FBTyxFQUFFLEdBQUcsRUFBRTtRQUVaLGtFQUFrRTtRQUNsRSx3REFBd0Q7UUFFeEQsT0FBTztZQUNMLFVBQVU7WUFDVixJQUFJLEVBQUU7Z0JBQ0osT0FBTyxFQUFFLFNBQVM7Z0JBQ2xCLElBQUksRUFBRSxTQUFTO2dCQUNmLFFBQVEsRUFBRSxTQUFTO2dCQUNuQixLQUFLLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUU7YUFDbEM7U0FDRixDQUFBO0lBRUgsQ0FBQztDQUNGLENBQUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCwgSW5qZWN0aW9uVG9rZW4gfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXHJcbmltcG9ydCB7IFNVUEFfU1RPUkVfT1BUSU9OUyB9IGZyb20gXCIuL3N1cGFiYXNlLWNyZWRlbnRpYWxzLnRva2VuXCJcclxuaW1wb3J0IHsgY3JlYXRlQ2xpZW50IH0gZnJvbSBcIkBzdXBhYmFzZS9zdXBhYmFzZS1qc1wiXHJcbmltcG9ydCB7IFN1cGFTdG9yZVN0YXRlIH0gZnJvbSBcIi4uL3R5cGUvc3VwYS1zdG9yZS50eXBlc1wiXHJcblxyXG5leHBvcnQgY29uc3QgSU5JVElBTF9TVEFURSA9IG5ldyBJbmplY3Rpb25Ub2tlbjxTdXBhU3RvcmVTdGF0ZT4oJ1N1cGFTdG9yZVN0YXRlJywge1xyXG4gIGZhY3Rvcnk6ICgpID0+IHtcclxuXHJcbiAgICAvLyBjb25zdCB7IHN1cGFiYXNlVXJsLCBzdXBhYmFzZUtleSB9ID0gaW5qZWN0KFNVUEFfU1RPUkVfT1BUSU9OUylcclxuICAgIC8vIGNvbnN0IGNsaWVudCA9IGNyZWF0ZUNsaWVudChzdXBhYmFzZVVybCwgc3VwYWJhc2VLZXkpXHJcblxyXG4gICAgcmV0dXJuIHtcclxuICAgICAgLy8gY2xpZW50LFxyXG4gICAgICBhdXRoOiB7XHJcbiAgICAgICAgc2Vzc2lvbjogdW5kZWZpbmVkLFxyXG4gICAgICAgIHVzZXI6IHVuZGVmaW5lZCxcclxuICAgICAgICBtZXRhZGF0YTogdW5kZWZpbmVkLFxyXG4gICAgICAgIHN0YXRlOiB7IHByZXY6IG51bGwsIGN1cnI6IG51bGwgfVxyXG4gICAgICB9XHJcbiAgICB9XHJcblxyXG4gIH0sXHJcbn0pXHJcbiJdfQ==
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VwYS1zdG9yZS50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL29iLXN1cGEtc3RvcmUvc3JjL2xpYi9jb21tb24vdHlwZS9zdXBhLXN0b3JlLnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBdXRoQ2hhbmdlRXZlbnQsIFNlc3Npb24sIFN1cGFiYXNlQ2xpZW50LCBVc2VyIH0gZnJvbSBcIkBzdXBhYmFzZS9zdXBhYmFzZS1qc1wiXHJcblxyXG5leHBvcnQgdHlwZSBTdXBhU3RvcmVTdGF0ZSA9IHtcclxuICAvLyBjbGllbnQ6IFN1cGFiYXNlQ2xpZW50XHJcbiAgYXV0aDoge1xyXG4gICAgc2Vzc2lvbjogU2Vzc2lvbiB8IHVuZGVmaW5lZCB8IG51bGxcclxuICAgIHVzZXI6IFVzZXIgfCB1bmRlZmluZWQgfCBudWxsXHJcbiAgICBtZXRhZGF0YTogdW5rbm93biB8IHVuZGVmaW5lZCB8IG51bGxcclxuICAgIHN0YXRlOiB7XHJcbiAgICAgIHByZXY6IEF1dGhDaGFuZ2VFdmVudCB8IG51bGwsXHJcbiAgICAgIGN1cnI6IEF1dGhDaGFuZ2VFdmVudCB8IG51bGwsXHJcbiAgICB9XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgdHlwZSBTdXBhU3RvcmVPcHRpb25zID0ge1xyXG4gIHN1cGFiYXNlVXJsOiBzdHJpbmcsXHJcbiAgc3VwYWJhc2VLZXk6IHN0cmluZyxcclxuICBwb3N0QXV0aE9wdGlvbnM6IHtcclxuICAgIHVzZUxvYWRlcjogeyB0YWJsZTogc3RyaW5nOyBycGM/OiBuZXZlciB9IHwgeyBycGM6IHN0cmluZzsgdGFibGU/OiBuZXZlciB9IHwgeyBycGM6IG51bGw7IHRhYmxlPzogbnVsbCB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -2,7 +2,8 @@
|
|
|
2
2
|
* Public API Surface of ob-supa-store
|
|
3
3
|
*/
|
|
4
4
|
export * from './lib/supa-store.store';
|
|
5
|
+
export * from './lib/common/services/supabase.service';
|
|
5
6
|
export * from './lib/supa-store.provider';
|
|
6
7
|
export * from './lib/common/features/supa-store-core.feature';
|
|
7
8
|
export * from './lib/common/type/supa-store.types';
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL29iLXN1cGEtc3RvcmUvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0VBRUU7QUFFRixjQUFjLHdCQUF3QixDQUFBO0FBQ3RDLGNBQWMsd0NBQXdDLENBQUE7QUFDdEQsY0FBYywyQkFBMkIsQ0FBQTtBQUN6QyxjQUFjLCtDQUErQyxDQUFBO0FBQzdELGNBQWMsb0NBQW9DLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2Ygb2Itc3VwYS1zdG9yZVxyXG4qL1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc3VwYS1zdG9yZS5zdG9yZSdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tbW9uL3NlcnZpY2VzL3N1cGFiYXNlLnNlcnZpY2UnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N1cGEtc3RvcmUucHJvdmlkZXInXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbW1vbi9mZWF0dXJlcy9zdXBhLXN0b3JlLWNvcmUuZmVhdHVyZSdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tbW9uL3R5cGUvc3VwYS1zdG9yZS50eXBlcydcclxuIl19
|
|
@@ -1,31 +1,30 @@
|
|
|
1
1
|
import { signalStoreFeature, type, withMethods, patchState, withHooks, withState, signalStore } from '@ngrx/signals';
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
2
|
+
import * as i0 from '@angular/core';
|
|
3
|
+
import { InjectionToken, inject, Injectable, makeEnvironmentProviders } from '@angular/core';
|
|
4
|
+
import { withDevtools } from '@angular-architects/ngrx-toolkit';
|
|
4
5
|
import { toObservable } from '@angular/core/rxjs-interop';
|
|
5
6
|
import { firstValueFrom, filter } from 'rxjs';
|
|
7
|
+
import { createClient } from '@supabase/supabase-js';
|
|
6
8
|
import { merge } from 'lodash-es';
|
|
7
9
|
|
|
8
10
|
const SUPA_STORE_OPTIONS = new InjectionToken('SUPA_STORE_OPTIONS');
|
|
9
11
|
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
};
|
|
23
|
-
},
|
|
24
|
-
});
|
|
12
|
+
class SupabaseService {
|
|
13
|
+
supaStoreOptions = inject(SUPA_STORE_OPTIONS);
|
|
14
|
+
client = createClient(this.supaStoreOptions?.supabaseUrl, this.supaStoreOptions?.supabaseKey);
|
|
15
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: SupabaseService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
16
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: SupabaseService, providedIn: 'root' });
|
|
17
|
+
}
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: SupabaseService, decorators: [{
|
|
19
|
+
type: Injectable,
|
|
20
|
+
args: [{
|
|
21
|
+
providedIn: 'root'
|
|
22
|
+
}]
|
|
23
|
+
}] });
|
|
25
24
|
|
|
26
25
|
const withPostAuthOptions = () => signalStoreFeature({
|
|
27
26
|
state: type()
|
|
28
|
-
}, withMethods((store, { postAuthOptions } = inject(SUPA_STORE_OPTIONS)) => ({
|
|
27
|
+
}, withMethods((store, { postAuthOptions } = inject(SUPA_STORE_OPTIONS), { client } = inject(SupabaseService)) => ({
|
|
29
28
|
_loader: async () => {
|
|
30
29
|
const { useLoader: { table, rpc } } = postAuthOptions;
|
|
31
30
|
if (table || rpc) {
|
|
@@ -33,11 +32,11 @@ const withPostAuthOptions = () => signalStoreFeature({
|
|
|
33
32
|
if (!session)
|
|
34
33
|
return;
|
|
35
34
|
if (table) {
|
|
36
|
-
const { data } = await
|
|
35
|
+
const { data } = await client.from(table).select('*').eq('id', session?.user?.id).single();
|
|
37
36
|
patchState(store, { auth: { ...store.auth(), metadata: data } });
|
|
38
37
|
}
|
|
39
38
|
else if (rpc) {
|
|
40
|
-
const { data } = await
|
|
39
|
+
const { data } = await client.rpc(rpc, { input: { user_id: session?.user?.id } });
|
|
41
40
|
patchState(store, { auth: { ...store.auth(), metadata: data } });
|
|
42
41
|
}
|
|
43
42
|
else {
|
|
@@ -52,21 +51,27 @@ const withPostAuthOptions = () => signalStoreFeature({
|
|
|
52
51
|
}
|
|
53
52
|
}));
|
|
54
53
|
|
|
55
|
-
const withSupaStoreCore = () => signalStoreFeature(
|
|
56
|
-
//
|
|
57
|
-
|
|
54
|
+
const withSupaStoreCore = () => signalStoreFeature(withDevtools('supaStore'), withState({
|
|
55
|
+
// client,
|
|
56
|
+
auth: {
|
|
57
|
+
session: undefined,
|
|
58
|
+
user: undefined,
|
|
59
|
+
metadata: undefined,
|
|
60
|
+
state: { prev: null, curr: null }
|
|
61
|
+
}
|
|
62
|
+
}), withPostAuthOptions(), withMethods((store, { client } = inject(SupabaseService)) => ({
|
|
58
63
|
_initSession: async () => {
|
|
59
|
-
const { data: { session }, error } = await
|
|
64
|
+
const { data: { session }, error } = await client.auth.getSession();
|
|
60
65
|
patchState(store, { auth: { ...store.auth(), session } });
|
|
61
66
|
},
|
|
62
67
|
_initUser: async () => {
|
|
63
|
-
const { data: { user }, error } = await
|
|
68
|
+
const { data: { user }, error } = await client.auth.getUser();
|
|
64
69
|
patchState(store, { auth: { ...store.auth(), user } });
|
|
65
70
|
}
|
|
66
71
|
})), withHooks({
|
|
67
|
-
onInit(store) {
|
|
72
|
+
onInit(store, { client } = inject(SupabaseService)) {
|
|
68
73
|
/* Listen For Auth Atate Changes */
|
|
69
|
-
|
|
74
|
+
client.auth.onAuthStateChange(state => patchState(store, { auth: { ...store.auth(), state: { prev: store.auth.state.curr(), curr: state } } }));
|
|
70
75
|
/* Init Supabase Session */
|
|
71
76
|
store._initSession();
|
|
72
77
|
/* Init Supabase User */
|
|
@@ -100,5 +105,5 @@ const provideSupaStore = (opts) => {
|
|
|
100
105
|
* Generated bundle index. Do not edit.
|
|
101
106
|
*/
|
|
102
107
|
|
|
103
|
-
export { SupaStore, provideSupaStore, withSupaStoreCore };
|
|
108
|
+
export { SupaStore, SupabaseService, provideSupaStore, withSupaStoreCore };
|
|
104
109
|
//# 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/
|
|
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/services/supabase.service.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, Injectable } from '@angular/core';\r\nimport { SUPA_STORE_OPTIONS } from '../token/supabase-credentials.token'\r\nimport { createClient, SupabaseClient } from '@supabase/supabase-js'\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class SupabaseService {\r\n\r\n public supaStoreOptions = inject(SUPA_STORE_OPTIONS)\r\n public client: SupabaseClient = createClient(\r\n this.supaStoreOptions?.supabaseUrl,\r\n this.supaStoreOptions?.supabaseKey\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\nimport { SupabaseService } from '../services/supabase.service'\r\n\r\nexport const withPostAuthOptions = () => signalStoreFeature(\r\n\r\n {\r\n state: type<SupaStoreState>()\r\n },\r\n\r\n withMethods((\r\n store,\r\n { postAuthOptions } = inject(SUPA_STORE_OPTIONS),\r\n { client } = inject(SupabaseService)\r\n ) => ({\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 session = await firstValueFrom(toObservable(store.auth.session).pipe(filter(res => res !== undefined)) as Observable<Session>)\r\n if (!session) return\r\n\r\n if (table) {\r\n const { data } = await client.from(table).select('*').eq('id', session?.user?.id).single()\r\n patchState(store, { auth: { ...store.auth(), metadata: data }})\r\n } else if (rpc) {\r\n const { data } = await client.rpc(rpc, { input: { user_id: session?.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\nimport { SupabaseService } from '../services/supabase.service'\r\n\r\nexport const withSupaStoreCore = () => signalStoreFeature(\r\n\r\n withDevtools('supaStore'),\r\n withState<SupaStoreState>({\r\n // client,\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 withPostAuthOptions(),\r\n\r\n withMethods((store, { client } = inject(SupabaseService)) => ({\r\n\r\n _initSession: async () => {\r\n const { data: { session }, error} = await client.auth.getSession()\r\n patchState(store, { auth: { ...store.auth(), session }})\r\n },\r\n\r\n _initUser: async () => {\r\n const { data: { user }, error } = await 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, {client} = inject(SupabaseService)) {\r\n\r\n /* Listen For Auth Atate Changes */\r\n 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/common/services/supabase.service'\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,6 +1,5 @@
|
|
|
1
1
|
export declare const withSupaStoreCore: () => import("@ngrx/signals").SignalStoreFeature<import("@ngrx/signals").EmptyFeatureResult, {
|
|
2
2
|
state: {
|
|
3
|
-
client: import("@supabase/supabase-js").SupabaseClient;
|
|
4
3
|
auth: {
|
|
5
4
|
session: import("@supabase/auth-js").Session | undefined | null;
|
|
6
5
|
user: import("@supabase/auth-js").User | undefined | null;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { SupabaseClient } from '@supabase/supabase-js';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class SupabaseService {
|
|
4
|
+
supaStoreOptions: import("@outbuild/supa-store").SupaStoreOptions;
|
|
5
|
+
client: SupabaseClient;
|
|
6
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SupabaseService, never>;
|
|
7
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<SupabaseService>;
|
|
8
|
+
}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import { AuthChangeEvent, Session,
|
|
1
|
+
import { AuthChangeEvent, Session, User } from "@supabase/supabase-js";
|
|
2
2
|
export type SupaStoreState = {
|
|
3
|
-
client: SupabaseClient;
|
|
4
3
|
auth: {
|
|
5
4
|
session: Session | undefined | null;
|
|
6
5
|
user: User | undefined | null;
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
export declare const SupaStore: import("@angular/core").Type<{
|
|
2
|
-
client: import("@ngrx/signals").DeepSignal<import("@supabase/supabase-js").SupabaseClient<any, "public", any>>;
|
|
3
2
|
auth: import("@ngrx/signals").DeepSignal<{
|
|
4
3
|
session: import("@supabase/auth-js").Session | undefined | null;
|
|
5
4
|
user: import("@supabase/auth-js").User | undefined | null;
|
|
@@ -10,7 +9,6 @@ export declare const SupaStore: import("@angular/core").Type<{
|
|
|
10
9
|
};
|
|
11
10
|
}>;
|
|
12
11
|
} & import("@ngrx/signals").StateSource<{
|
|
13
|
-
client: import("@supabase/supabase-js").SupabaseClient;
|
|
14
12
|
auth: {
|
|
15
13
|
session: import("@supabase/auth-js").Session | undefined | null;
|
|
16
14
|
user: import("@supabase/auth-js").User | undefined | null;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@outbuild/supa-store",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.29",
|
|
4
4
|
"peerDependencies": {
|
|
5
5
|
"@angular/common": "^18.2.0",
|
|
6
6
|
"@angular/core": "^18.2.0",
|
|
@@ -29,4 +29,4 @@
|
|
|
29
29
|
"default": "./fesm2022/outbuild-supa-store.mjs"
|
|
30
30
|
}
|
|
31
31
|
}
|
|
32
|
-
}
|
|
32
|
+
}
|
package/public-api.d.ts
CHANGED