@outbuild/supa-store 0.0.28 → 0.0.30
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 +4 -5
- package/esm2022/lib/common/features/supa-store-core.feature.mjs +7 -15
- package/esm2022/lib/common/token/initial-state.token.mjs +7 -5
- package/esm2022/lib/common/type/supa-store.types.mjs +1 -1
- package/fesm2022/outbuild-supa-store.mjs +25 -31
- package/fesm2022/outbuild-supa-store.mjs.map +1 -1
- package/lib/common/features/supa-store-core.feature.d.ts +1 -0
- package/lib/common/type/supa-store.types.d.ts +2 -1
- package/lib/supa-store.store.d.ts +2 -0
- package/package.json +1 -1
- package/esm2022/lib/common/services/supabase.service.mjs +0 -17
- package/lib/common/services/supabase.service.d.ts +0 -8
|
@@ -3,10 +3,9 @@ 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';
|
|
7
6
|
export const withPostAuthOptions = () => signalStoreFeature({
|
|
8
7
|
state: type()
|
|
9
|
-
}, withMethods((store, { postAuthOptions } = inject(SUPA_STORE_OPTIONS)
|
|
8
|
+
}, withMethods((store, { postAuthOptions } = inject(SUPA_STORE_OPTIONS)) => ({
|
|
10
9
|
_loader: async () => {
|
|
11
10
|
const { useLoader: { table, rpc } } = postAuthOptions;
|
|
12
11
|
if (table || rpc) {
|
|
@@ -14,11 +13,11 @@ export const withPostAuthOptions = () => signalStoreFeature({
|
|
|
14
13
|
if (!session)
|
|
15
14
|
return;
|
|
16
15
|
if (table) {
|
|
17
|
-
const { data } = await client.from(table).select('*').eq('id', session?.user?.id).single();
|
|
16
|
+
const { data } = await store.client().from(table).select('*').eq('id', session?.user?.id).single();
|
|
18
17
|
patchState(store, { auth: { ...store.auth(), metadata: data } });
|
|
19
18
|
}
|
|
20
19
|
else if (rpc) {
|
|
21
|
-
const { data } = await client.rpc(rpc, { input: { user_id: session?.user?.id } });
|
|
20
|
+
const { data } = await store.client().rpc(rpc, { input: { user_id: session?.user?.id } });
|
|
22
21
|
patchState(store, { auth: { ...store.auth(), metadata: data } });
|
|
23
22
|
}
|
|
24
23
|
else {
|
|
@@ -32,4 +31,4 @@ export const withPostAuthOptions = () => signalStoreFeature({
|
|
|
32
31
|
store._loader();
|
|
33
32
|
}
|
|
34
33
|
}));
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9zdC1hdXRoLWxvYWRlci5mZWF0dXJlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb2Itc3VwYS1zdG9yZS9zcmMvbGliL2NvbW1vbi9mZWF0dXJlcy9wb3N0LWF1dGgtbG9hZGVyLmZlYXR1cmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUV0QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNEJBQTRCLENBQUE7QUFFekQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0scUNBQXFDLENBQUE7QUFDeEUsT0FBTyxFQUFFLE1BQU0sRUFBRSxjQUFjLEVBQWMsTUFBTSxNQUFNLENBQUE7QUFDekQsT0FBTyxFQUFFLFVBQVUsRUFBRSxrQkFBa0IsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUU1RixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxHQUFHLEVBQUUsQ0FBQyxrQkFBa0IsQ0FFekQ7SUFDRSxLQUFLLEVBQUUsSUFBSSxFQUFrQjtDQUM5QixFQUVELFdBQVcsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLGVBQWUsRUFBRSxHQUFHLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBRXhFLE9BQU8sRUFBRSxLQUFLLElBQUksRUFBRTtRQUVsQixNQUFNLEVBQUUsU0FBUyxFQUFFLEVBQUUsS0FBSyxFQUFFLEdBQUcsRUFBRSxFQUFDLEdBQUcsZUFBZSxDQUFBO1FBRXBELElBQUksS0FBSyxJQUFJLEdBQUcsRUFBRSxDQUFDO1lBRWpCLE1BQU0sT0FBTyxHQUFHLE1BQU0sY0FBYyxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEtBQUssU0FBUyxDQUFDLENBQXdCLENBQUMsQ0FBQTtZQUNwSSxJQUFJLENBQUMsT0FBTztnQkFBRSxPQUFNO1lBRXBCLElBQUksS0FBSyxFQUFFLENBQUM7Z0JBQ1YsTUFBTSxFQUFFLElBQUksRUFBRSxHQUFHLE1BQU0sS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxDQUFDLElBQUksRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFBO2dCQUNsRyxVQUFVLENBQUMsS0FBSyxFQUFHLEVBQUUsSUFBSSxFQUFFLEVBQUUsR0FBRyxLQUFLLENBQUMsSUFBSSxFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxFQUFDLENBQUMsQ0FBQTtZQUNsRSxDQUFDO2lCQUFNLElBQUksR0FBRyxFQUFFLENBQUM7Z0JBQ2YsTUFBTSxFQUFFLElBQUksRUFBRSxHQUFHLE1BQU0sS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsRUFBRSxLQUFLLEVBQUUsRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUUsRUFBQyxDQUFDLENBQUE7Z0JBQ3hGLFVBQVUsQ0FBQyxLQUFLLEVBQUUsRUFBRSxJQUFJLEVBQUUsRUFBRSxHQUFHLEtBQUssQ0FBQyxJQUFJLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLEVBQUMsQ0FBQyxDQUFBO1lBQ2pFLENBQUM7aUJBQU0sQ0FBQztnQkFDTixVQUFVLENBQUMsS0FBSyxFQUFFLEVBQUUsSUFBSSxFQUFFLEVBQUUsR0FBRyxLQUFLLENBQUMsSUFBSSxFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBQyxFQUFDLENBQUMsQ0FBQTtZQUNoRSxDQUFDO1FBRUgsQ0FBQztJQUNILENBQUM7Q0FFRixDQUFDLENBQUMsRUFFSCxTQUFTLENBQUM7SUFFUixNQUFNLENBQUMsS0FBSztRQUVWLHlDQUF5QztRQUN6QyxLQUFLLENBQUMsT0FBTyxFQUFFLENBQUE7SUFFakIsQ0FBQztDQUVGLENBQUMsQ0FFSCxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcclxuaW1wb3J0IHsgU2Vzc2lvbiB9IGZyb20gJ0BzdXBhYmFzZS9zdXBhYmFzZS1qcydcclxuaW1wb3J0IHsgdG9PYnNlcnZhYmxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmUvcnhqcy1pbnRlcm9wXCJcclxuaW1wb3J0IHsgU3VwYVN0b3JlU3RhdGUgfSBmcm9tICcuLi90eXBlL3N1cGEtc3RvcmUudHlwZXMnXHJcbmltcG9ydCB7IFNVUEFfU1RPUkVfT1BUSU9OUyB9IGZyb20gJy4uL3Rva2VuL3N1cGFiYXNlLWNyZWRlbnRpYWxzLnRva2VuJ1xyXG5pbXBvcnQgeyBmaWx0ZXIsIGZpcnN0VmFsdWVGcm9tLCBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcydcclxuaW1wb3J0IHsgcGF0Y2hTdGF0ZSwgc2lnbmFsU3RvcmVGZWF0dXJlLCB0eXBlLCB3aXRoSG9va3MsIHdpdGhNZXRob2RzIH0gZnJvbSAnQG5ncngvc2lnbmFscydcclxuXHJcbmV4cG9ydCBjb25zdCB3aXRoUG9zdEF1dGhPcHRpb25zID0gKCkgPT4gc2lnbmFsU3RvcmVGZWF0dXJlKFxyXG5cclxuICB7XHJcbiAgICBzdGF0ZTogdHlwZTxTdXBhU3RvcmVTdGF0ZT4oKVxyXG4gIH0sXHJcblxyXG4gIHdpdGhNZXRob2RzKChzdG9yZSwgeyBwb3N0QXV0aE9wdGlvbnMgfSA9IGluamVjdChTVVBBX1NUT1JFX09QVElPTlMpKSA9PiAoe1xyXG5cclxuICAgIF9sb2FkZXI6IGFzeW5jICgpID0+IHtcclxuXHJcbiAgICAgIGNvbnN0IHsgdXNlTG9hZGVyOiB7IHRhYmxlLCBycGMgfX0gPSBwb3N0QXV0aE9wdGlvbnNcclxuXHJcbiAgICAgIGlmICh0YWJsZSB8fCBycGMpIHtcclxuXHJcbiAgICAgICAgY29uc3Qgc2Vzc2lvbiA9IGF3YWl0IGZpcnN0VmFsdWVGcm9tKHRvT2JzZXJ2YWJsZShzdG9yZS5hdXRoLnNlc3Npb24pLnBpcGUoZmlsdGVyKHJlcyA9PiByZXMgIT09IHVuZGVmaW5lZCkpIGFzIE9ic2VydmFibGU8U2Vzc2lvbj4pXHJcbiAgICAgICAgaWYgKCFzZXNzaW9uKSByZXR1cm5cclxuXHJcbiAgICAgICAgaWYgKHRhYmxlKSB7XHJcbiAgICAgICAgICBjb25zdCB7IGRhdGEgfSA9IGF3YWl0IHN0b3JlLmNsaWVudCgpLmZyb20odGFibGUpLnNlbGVjdCgnKicpLmVxKCdpZCcsIHNlc3Npb24/LnVzZXI/LmlkKS5zaW5nbGUoKVxyXG4gICAgICAgICAgcGF0Y2hTdGF0ZShzdG9yZSwgIHsgYXV0aDogeyAuLi5zdG9yZS5hdXRoKCksIG1ldGFkYXRhOiBkYXRhIH19KVxyXG4gICAgICAgIH0gZWxzZSBpZiAocnBjKSB7XHJcbiAgICAgICAgICBjb25zdCB7IGRhdGEgfSA9IGF3YWl0IHN0b3JlLmNsaWVudCgpLnJwYyhycGMsIHsgaW5wdXQ6IHsgdXNlcl9pZDogc2Vzc2lvbj8udXNlcj8uaWQgfX0pXHJcbiAgICAgICAgICBwYXRjaFN0YXRlKHN0b3JlLCB7IGF1dGg6IHsgLi4uc3RvcmUuYXV0aCgpLCBtZXRhZGF0YTogZGF0YSB9fSlcclxuICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgcGF0Y2hTdGF0ZShzdG9yZSwgeyBhdXRoOiB7IC4uLnN0b3JlLmF1dGgoKSwgbWV0YWRhdGE6IG51bGx9fSlcclxuICAgICAgICB9XHJcblxyXG4gICAgICB9XHJcbiAgICB9LFxyXG5cclxuICB9KSksXHJcblxyXG4gIHdpdGhIb29rcyh7XHJcblxyXG4gICAgb25Jbml0KHN0b3JlKSB7XHJcblxyXG4gICAgICAvKiBBdXRvIExvYWQgQWRkaXRpb25hbCBVc2VyIEF1dGggRGF0YSAqL1xyXG4gICAgICBzdG9yZS5fbG9hZGVyKClcclxuXHJcbiAgICB9XHJcblxyXG4gIH0pXHJcblxyXG4pXHJcbiJdfQ==
|
|
@@ -1,33 +1,25 @@
|
|
|
1
1
|
import { inject } from '@angular/core';
|
|
2
2
|
import { withDevtools } from '@angular-architects/ngrx-toolkit';
|
|
3
|
+
import { INITIAL_STATE } from '../token/initial-state.token';
|
|
3
4
|
import { withPostAuthOptions } from '../features/post-auth-loader.feature';
|
|
4
5
|
import { patchState, signalStoreFeature, withHooks, withMethods, withState } from '@ngrx/signals';
|
|
5
|
-
|
|
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)) => ({
|
|
6
|
+
export const withSupaStoreCore = () => signalStoreFeature(withDevtools('supaStore'), withState(() => inject(INITIAL_STATE)), withPostAuthOptions(), withMethods(store => ({
|
|
15
7
|
_initSession: async () => {
|
|
16
|
-
const { data: { session }, error } = await client.auth.getSession();
|
|
8
|
+
const { data: { session }, error } = await store.client().auth.getSession();
|
|
17
9
|
patchState(store, { auth: { ...store.auth(), session } });
|
|
18
10
|
},
|
|
19
11
|
_initUser: async () => {
|
|
20
|
-
const { data: { user }, error } = await client.auth.getUser();
|
|
12
|
+
const { data: { user }, error } = await store.client().auth.getUser();
|
|
21
13
|
patchState(store, { auth: { ...store.auth(), user } });
|
|
22
14
|
}
|
|
23
15
|
})), withHooks({
|
|
24
|
-
onInit(store
|
|
16
|
+
onInit(store) {
|
|
25
17
|
/* Listen For Auth Atate Changes */
|
|
26
|
-
client.auth.onAuthStateChange(state => patchState(store, { auth: { ...store.auth(), state: { prev: store.auth.state.curr(), curr: state } } }));
|
|
18
|
+
store.client().auth.onAuthStateChange(state => patchState(store, { auth: { ...store.auth(), state: { prev: store.auth.state.curr(), curr: state } } }));
|
|
27
19
|
/* Init Supabase Session */
|
|
28
20
|
store._initSession();
|
|
29
21
|
/* Init Supabase User */
|
|
30
22
|
store._initUser();
|
|
31
23
|
}
|
|
32
24
|
}));
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VwYS1zdG9yZS1jb3JlLmZlYXR1cmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vYi1zdXBhLXN0b3JlL3NyYy9saWIvY29tbW9uL2ZlYXR1cmVzL3N1cGEtc3RvcmUtY29yZS5mZWF0dXJlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGtDQUFrQyxDQUFBO0FBQy9ELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQTtBQUU1RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQTtBQUMxRSxPQUFPLEVBQUUsVUFBVSxFQUFFLGtCQUFrQixFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBRWpHLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLEdBQUcsRUFBRSxDQUFDLGtCQUFrQixDQUV2RCxZQUFZLENBQUMsV0FBVyxDQUFDLEVBQ3pCLFNBQVMsQ0FBaUIsR0FBRyxFQUFFLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDLEVBQ3RELG1CQUFtQixFQUFFLEVBRXJCLFdBQVcsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUM7SUFFcEIsWUFBWSxFQUFFLEtBQUssSUFBSSxFQUFFO1FBQ3ZCLE1BQU0sRUFBRSxJQUFJLEVBQUUsRUFBRSxPQUFPLEVBQUUsRUFBRSxLQUFLLEVBQUMsR0FBRyxNQUFNLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUE7UUFDMUUsVUFBVSxDQUFDLEtBQUssRUFBRSxFQUFFLElBQUksRUFBRSxFQUFFLEdBQUcsS0FBSyxDQUFDLElBQUksRUFBRSxFQUFFLE9BQU8sRUFBRSxFQUFDLENBQUMsQ0FBQTtJQUMxRCxDQUFDO0lBRUQsU0FBUyxFQUFFLEtBQUssSUFBSSxFQUFFO1FBQ3BCLE1BQU0sRUFBRSxJQUFJLEVBQUUsRUFBRSxJQUFJLEVBQUUsRUFBRSxLQUFLLEVBQUUsR0FBRyxNQUFNLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUE7UUFDckUsVUFBVSxDQUFDLEtBQUssRUFBRSxFQUFFLElBQUksRUFBRSxFQUFFLEdBQUcsS0FBSyxDQUFDLElBQUksRUFBRSxFQUFFLElBQUksRUFBRSxFQUFDLENBQUMsQ0FBQTtJQUN2RCxDQUFDO0NBRUYsQ0FBQyxDQUFDLEVBRUgsU0FBUyxDQUFDO0lBRVIsTUFBTSxDQUFDLEtBQUs7UUFFVixtQ0FBbUM7UUFDbkMsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsRUFBRSxJQUFJLEVBQUUsRUFBRSxHQUFHLEtBQUssQ0FBQyxJQUFJLEVBQUUsRUFBRSxLQUFLLEVBQUUsRUFBRSxJQUFJLEVBQUUsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxFQUFFLEVBQUMsQ0FBQyxDQUFDLENBQUE7UUFFdEosMkJBQTJCO1FBQzNCLEtBQUssQ0FBQyxZQUFZLEVBQUUsQ0FBQTtRQUVwQix3QkFBd0I7UUFDeEIsS0FBSyxDQUFDLFNBQVMsRUFBRSxDQUFBO0lBRW5CLENBQUM7Q0FFRixDQUFDLENBRUgsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyB3aXRoRGV2dG9vbHMgfSBmcm9tICdAYW5ndWxhci1hcmNoaXRlY3RzL25ncngtdG9vbGtpdCdcclxuaW1wb3J0IHsgSU5JVElBTF9TVEFURSB9IGZyb20gJy4uL3Rva2VuL2luaXRpYWwtc3RhdGUudG9rZW4nXHJcbmltcG9ydCB7IFN1cGFTdG9yZVN0YXRlIH0gZnJvbSAnLi4vdHlwZS9zdXBhLXN0b3JlLnR5cGVzJ1xyXG5pbXBvcnQgeyB3aXRoUG9zdEF1dGhPcHRpb25zIH0gZnJvbSAnLi4vZmVhdHVyZXMvcG9zdC1hdXRoLWxvYWRlci5mZWF0dXJlJ1xyXG5pbXBvcnQgeyBwYXRjaFN0YXRlLCBzaWduYWxTdG9yZUZlYXR1cmUsIHdpdGhIb29rcywgd2l0aE1ldGhvZHMsIHdpdGhTdGF0ZSB9IGZyb20gJ0BuZ3J4L3NpZ25hbHMnXHJcblxyXG5leHBvcnQgY29uc3Qgd2l0aFN1cGFTdG9yZUNvcmUgPSAoKSA9PiBzaWduYWxTdG9yZUZlYXR1cmUoXHJcblxyXG4gIHdpdGhEZXZ0b29scygnc3VwYVN0b3JlJyksXHJcbiAgd2l0aFN0YXRlPFN1cGFTdG9yZVN0YXRlPigoKSA9PiBpbmplY3QoSU5JVElBTF9TVEFURSkpLFxyXG4gIHdpdGhQb3N0QXV0aE9wdGlvbnMoKSxcclxuXHJcbiAgd2l0aE1ldGhvZHMoc3RvcmUgPT4gKHtcclxuXHJcbiAgICBfaW5pdFNlc3Npb246IGFzeW5jICgpID0+IHtcclxuICAgICAgY29uc3QgeyBkYXRhOiB7IHNlc3Npb24gfSwgZXJyb3J9ID0gYXdhaXQgc3RvcmUuY2xpZW50KCkuYXV0aC5nZXRTZXNzaW9uKClcclxuICAgICAgcGF0Y2hTdGF0ZShzdG9yZSwgeyBhdXRoOiB7IC4uLnN0b3JlLmF1dGgoKSwgc2Vzc2lvbiB9fSlcclxuICAgIH0sXHJcblxyXG4gICAgX2luaXRVc2VyOiBhc3luYyAoKSA9PiB7XHJcbiAgICAgIGNvbnN0IHsgZGF0YTogeyB1c2VyIH0sIGVycm9yIH0gPSBhd2FpdCBzdG9yZS5jbGllbnQoKS5hdXRoLmdldFVzZXIoKVxyXG4gICAgICBwYXRjaFN0YXRlKHN0b3JlLCB7IGF1dGg6IHsgLi4uc3RvcmUuYXV0aCgpLCB1c2VyIH19KVxyXG4gICAgfVxyXG5cclxuICB9KSksXHJcblxyXG4gIHdpdGhIb29rcyh7XHJcblxyXG4gICAgb25Jbml0KHN0b3JlKSB7XHJcblxyXG4gICAgICAvKiBMaXN0ZW4gRm9yIEF1dGggQXRhdGUgQ2hhbmdlcyAqL1xyXG4gICAgICBzdG9yZS5jbGllbnQoKS5hdXRoLm9uQXV0aFN0YXRlQ2hhbmdlKHN0YXRlID0+IHBhdGNoU3RhdGUoc3RvcmUsIHsgYXV0aDogeyAuLi5zdG9yZS5hdXRoKCksIHN0YXRlOiB7IHByZXY6IHN0b3JlLmF1dGguc3RhdGUuY3VycigpLCBjdXJyOiBzdGF0ZSB9IH19KSlcclxuXHJcbiAgICAgIC8qIEluaXQgU3VwYWJhc2UgU2Vzc2lvbiAqL1xyXG4gICAgICBzdG9yZS5faW5pdFNlc3Npb24oKVxyXG5cclxuICAgICAgLyogSW5pdCBTdXBhYmFzZSBVc2VyICovXHJcbiAgICAgIHN0b3JlLl9pbml0VXNlcigpXHJcblxyXG4gICAgfVxyXG5cclxuICB9KVxyXG5cclxuKVxyXG4iXX0=
|
|
@@ -1,10 +1,12 @@
|
|
|
1
|
-
import { InjectionToken } from "@angular/core";
|
|
1
|
+
import { inject, InjectionToken } from "@angular/core";
|
|
2
|
+
import { SUPA_STORE_OPTIONS } from "./supabase-credentials.token";
|
|
3
|
+
import { createClient } from "@supabase/supabase-js";
|
|
2
4
|
export const INITIAL_STATE = new InjectionToken('SupaStoreState', {
|
|
3
5
|
factory: () => {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
+
const { supabaseUrl, supabaseKey } = inject(SUPA_STORE_OPTIONS);
|
|
7
|
+
const client = createClient(supabaseUrl, supabaseKey);
|
|
6
8
|
return {
|
|
7
|
-
|
|
9
|
+
client,
|
|
8
10
|
auth: {
|
|
9
11
|
session: undefined,
|
|
10
12
|
user: undefined,
|
|
@@ -14,4 +16,4 @@ export const INITIAL_STATE = new InjectionToken('SupaStoreState', {
|
|
|
14
16
|
};
|
|
15
17
|
},
|
|
16
18
|
});
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5pdGlhbC1zdGF0ZS50b2tlbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL29iLXN1cGEtc3RvcmUvc3JjL2xpYi9jb21tb24vdG9rZW4vaW5pdGlhbC1zdGF0ZS50b2tlbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUN0RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQTtBQUNqRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sdUJBQXVCLENBQUE7QUFHcEQsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLElBQUksY0FBYyxDQUFpQixnQkFBZ0IsRUFBRTtJQUNoRixPQUFPLEVBQUUsR0FBRyxFQUFFO1FBRVosTUFBTSxFQUFFLFdBQVcsRUFBRSxXQUFXLEVBQUUsR0FBRyxNQUFNLENBQUMsa0JBQWtCLENBQUMsQ0FBQTtRQUMvRCxNQUFNLE1BQU0sR0FBRyxZQUFZLENBQUMsV0FBVyxFQUFFLFdBQVcsQ0FBQyxDQUFBO1FBRXJELE9BQU87WUFDTCxNQUFNO1lBQ04sSUFBSSxFQUFFO2dCQUNKLE9BQU8sRUFBRSxTQUFTO2dCQUNsQixJQUFJLEVBQUUsU0FBUztnQkFDZixRQUFRLEVBQUUsU0FBUztnQkFDbkIsS0FBSyxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFO2FBQ2xDO1NBQ0YsQ0FBQTtJQUVILENBQUM7Q0FDRixDQUFDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QsIEluamVjdGlvblRva2VuIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIlxyXG5pbXBvcnQgeyBTVVBBX1NUT1JFX09QVElPTlMgfSBmcm9tIFwiLi9zdXBhYmFzZS1jcmVkZW50aWFscy50b2tlblwiXHJcbmltcG9ydCB7IGNyZWF0ZUNsaWVudCB9IGZyb20gXCJAc3VwYWJhc2Uvc3VwYWJhc2UtanNcIlxyXG5pbXBvcnQgeyBTdXBhU3RvcmVTdGF0ZSB9IGZyb20gXCIuLi90eXBlL3N1cGEtc3RvcmUudHlwZXNcIlxyXG5cclxuZXhwb3J0IGNvbnN0IElOSVRJQUxfU1RBVEUgPSBuZXcgSW5qZWN0aW9uVG9rZW48U3VwYVN0b3JlU3RhdGU+KCdTdXBhU3RvcmVTdGF0ZScsIHtcclxuICBmYWN0b3J5OiAoKSA9PiB7XHJcblxyXG4gICAgY29uc3QgeyBzdXBhYmFzZVVybCwgc3VwYWJhc2VLZXkgfSA9IGluamVjdChTVVBBX1NUT1JFX09QVElPTlMpXHJcbiAgICBjb25zdCBjbGllbnQgPSBjcmVhdGVDbGllbnQoc3VwYWJhc2VVcmwsIHN1cGFiYXNlS2V5KVxyXG5cclxuICAgIHJldHVybiB7XHJcbiAgICAgIGNsaWVudCxcclxuICAgICAgYXV0aDoge1xyXG4gICAgICAgIHNlc3Npb246IHVuZGVmaW5lZCxcclxuICAgICAgICB1c2VyOiB1bmRlZmluZWQsXHJcbiAgICAgICAgbWV0YWRhdGE6IHVuZGVmaW5lZCxcclxuICAgICAgICBzdGF0ZTogeyBwcmV2OiBudWxsLCBjdXJyOiBudWxsIH1cclxuICAgICAgfVxyXG4gICAgfVxyXG5cclxuICB9LFxyXG59KVxyXG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VwYS1zdG9yZS50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL29iLXN1cGEtc3RvcmUvc3JjL2xpYi9jb21tb24vdHlwZS9zdXBhLXN0b3JlLnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBdXRoQ2hhbmdlRXZlbnQsIFNlc3Npb24sIFN1cGFiYXNlQ2xpZW50LCBVc2VyIH0gZnJvbSBcIkBzdXBhYmFzZS9zdXBhYmFzZS1qc1wiXHJcblxyXG5leHBvcnQgdHlwZSBTdXBhU3RvcmVTdGF0ZSA9IHtcclxuICBjbGllbnQ6IFN1cGFiYXNlQ2xpZW50XHJcbiAgYXV0aDoge1xyXG4gICAgc2Vzc2lvbjogU2Vzc2lvbiB8IHVuZGVmaW5lZCB8IG51bGxcclxuICAgIHVzZXI6IFVzZXIgfCB1bmRlZmluZWQgfCBudWxsXHJcbiAgICBtZXRhZGF0YTogdW5rbm93biB8IHVuZGVmaW5lZCB8IG51bGxcclxuICAgIHN0YXRlOiB7XHJcbiAgICAgIHByZXY6IEF1dGhDaGFuZ2VFdmVudCB8IG51bGwsXHJcbiAgICAgIGN1cnI6IEF1dGhDaGFuZ2VFdmVudCB8IG51bGwsXHJcbiAgICB9XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgdHlwZSBTdXBhU3RvcmVPcHRpb25zID0ge1xyXG4gIHN1cGFiYXNlVXJsOiBzdHJpbmcsXHJcbiAgc3VwYWJhc2VLZXk6IHN0cmluZyxcclxuICBwb3N0QXV0aE9wdGlvbnM6IHtcclxuICAgIHVzZUxvYWRlcjogeyB0YWJsZTogc3RyaW5nOyBycGM/OiBuZXZlciB9IHwgeyBycGM6IHN0cmluZzsgdGFibGU/OiBuZXZlciB9IHwgeyBycGM6IG51bGw7IHRhYmxlPzogbnVsbCB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -1,30 +1,32 @@
|
|
|
1
1
|
import { signalStoreFeature, type, withMethods, patchState, withHooks, withState, signalStore } from '@ngrx/signals';
|
|
2
|
-
import
|
|
3
|
-
import { InjectionToken, inject, Injectable, makeEnvironmentProviders } from '@angular/core';
|
|
2
|
+
import { InjectionToken, inject, makeEnvironmentProviders } from '@angular/core';
|
|
4
3
|
import { withDevtools } from '@angular-architects/ngrx-toolkit';
|
|
4
|
+
import { createClient } from '@supabase/supabase-js';
|
|
5
5
|
import { toObservable } from '@angular/core/rxjs-interop';
|
|
6
6
|
import { firstValueFrom, filter } from 'rxjs';
|
|
7
|
-
import { createClient } from '@supabase/supabase-js';
|
|
8
7
|
import { merge } from 'lodash-es';
|
|
9
8
|
|
|
10
9
|
const SUPA_STORE_OPTIONS = new InjectionToken('SUPA_STORE_OPTIONS');
|
|
11
10
|
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
}
|
|
23
|
-
|
|
11
|
+
const INITIAL_STATE = new InjectionToken('SupaStoreState', {
|
|
12
|
+
factory: () => {
|
|
13
|
+
const { supabaseUrl, supabaseKey } = inject(SUPA_STORE_OPTIONS);
|
|
14
|
+
const client = createClient(supabaseUrl, supabaseKey);
|
|
15
|
+
return {
|
|
16
|
+
client,
|
|
17
|
+
auth: {
|
|
18
|
+
session: undefined,
|
|
19
|
+
user: undefined,
|
|
20
|
+
metadata: undefined,
|
|
21
|
+
state: { prev: null, curr: null }
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
},
|
|
25
|
+
});
|
|
24
26
|
|
|
25
27
|
const withPostAuthOptions = () => signalStoreFeature({
|
|
26
28
|
state: type()
|
|
27
|
-
}, withMethods((store, { postAuthOptions } = inject(SUPA_STORE_OPTIONS)
|
|
29
|
+
}, withMethods((store, { postAuthOptions } = inject(SUPA_STORE_OPTIONS)) => ({
|
|
28
30
|
_loader: async () => {
|
|
29
31
|
const { useLoader: { table, rpc } } = postAuthOptions;
|
|
30
32
|
if (table || rpc) {
|
|
@@ -32,11 +34,11 @@ const withPostAuthOptions = () => signalStoreFeature({
|
|
|
32
34
|
if (!session)
|
|
33
35
|
return;
|
|
34
36
|
if (table) {
|
|
35
|
-
const { data } = await client.from(table).select('*').eq('id', session?.user?.id).single();
|
|
37
|
+
const { data } = await store.client().from(table).select('*').eq('id', session?.user?.id).single();
|
|
36
38
|
patchState(store, { auth: { ...store.auth(), metadata: data } });
|
|
37
39
|
}
|
|
38
40
|
else if (rpc) {
|
|
39
|
-
const { data } = await client.rpc(rpc, { input: { user_id: session?.user?.id } });
|
|
41
|
+
const { data } = await store.client().rpc(rpc, { input: { user_id: session?.user?.id } });
|
|
40
42
|
patchState(store, { auth: { ...store.auth(), metadata: data } });
|
|
41
43
|
}
|
|
42
44
|
else {
|
|
@@ -51,27 +53,19 @@ const withPostAuthOptions = () => signalStoreFeature({
|
|
|
51
53
|
}
|
|
52
54
|
}));
|
|
53
55
|
|
|
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)) => ({
|
|
56
|
+
const withSupaStoreCore = () => signalStoreFeature(withDevtools('supaStore'), withState(() => inject(INITIAL_STATE)), withPostAuthOptions(), withMethods(store => ({
|
|
63
57
|
_initSession: async () => {
|
|
64
|
-
const { data: { session }, error } = await client.auth.getSession();
|
|
58
|
+
const { data: { session }, error } = await store.client().auth.getSession();
|
|
65
59
|
patchState(store, { auth: { ...store.auth(), session } });
|
|
66
60
|
},
|
|
67
61
|
_initUser: async () => {
|
|
68
|
-
const { data: { user }, error } = await client.auth.getUser();
|
|
62
|
+
const { data: { user }, error } = await store.client().auth.getUser();
|
|
69
63
|
patchState(store, { auth: { ...store.auth(), user } });
|
|
70
64
|
}
|
|
71
65
|
})), withHooks({
|
|
72
|
-
onInit(store
|
|
66
|
+
onInit(store) {
|
|
73
67
|
/* Listen For Auth Atate Changes */
|
|
74
|
-
client.auth.onAuthStateChange(state => patchState(store, { auth: { ...store.auth(), state: { prev: store.auth.state.curr(), curr: state } } }));
|
|
68
|
+
store.client().auth.onAuthStateChange(state => patchState(store, { auth: { ...store.auth(), state: { prev: store.auth.state.curr(), curr: state } } }));
|
|
75
69
|
/* Init Supabase Session */
|
|
76
70
|
store._initSession();
|
|
77
71
|
/* Init Supabase User */
|
|
@@ -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/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 const client = createClient(supabaseUrl, supabaseKey)\r\n\r\n return {\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\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 {\r\n state: type<SupaStoreState>()\r\n },\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 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 store.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 store.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\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 }, error} = 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 }, error } = 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,6 @@
|
|
|
1
1
|
export declare const withSupaStoreCore: () => import("@ngrx/signals").SignalStoreFeature<import("@ngrx/signals").EmptyFeatureResult, {
|
|
2
2
|
state: {
|
|
3
|
+
client: import("@supabase/supabase-js").SupabaseClient;
|
|
3
4
|
auth: {
|
|
4
5
|
session: import("@supabase/auth-js").Session | undefined | null;
|
|
5
6
|
user: import("@supabase/auth-js").User | undefined | null;
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import { AuthChangeEvent, Session, User } from "@supabase/supabase-js";
|
|
1
|
+
import { AuthChangeEvent, Session, SupabaseClient, User } from "@supabase/supabase-js";
|
|
2
2
|
export type SupaStoreState = {
|
|
3
|
+
client: SupabaseClient;
|
|
3
4
|
auth: {
|
|
4
5
|
session: Session | undefined | null;
|
|
5
6
|
user: User | undefined | null;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export declare const SupaStore: import("@angular/core").Type<{
|
|
2
|
+
client: import("@ngrx/signals").DeepSignal<import("@supabase/supabase-js").SupabaseClient<any, "public", any>>;
|
|
2
3
|
auth: import("@ngrx/signals").DeepSignal<{
|
|
3
4
|
session: import("@supabase/auth-js").Session | undefined | null;
|
|
4
5
|
user: import("@supabase/auth-js").User | undefined | null;
|
|
@@ -9,6 +10,7 @@ export declare const SupaStore: import("@angular/core").Type<{
|
|
|
9
10
|
};
|
|
10
11
|
}>;
|
|
11
12
|
} & import("@ngrx/signals").StateSource<{
|
|
13
|
+
client: import("@supabase/supabase-js").SupabaseClient;
|
|
12
14
|
auth: {
|
|
13
15
|
session: import("@supabase/auth-js").Session | undefined | null;
|
|
14
16
|
user: import("@supabase/auth-js").User | undefined | null;
|
package/package.json
CHANGED
|
@@ -1,17 +0,0 @@
|
|
|
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,8 +0,0 @@
|
|
|
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
|
-
}
|