@based/react 4.2.0 → 4.2.1

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.
@@ -0,0 +1,30 @@
1
+ import React, { FunctionComponent, ReactNode } from 'react';
2
+ import { Based, BasedOpts } from '@based/client';
3
+ export declare type CreateClient = (selector: string | (BasedOpts & {
4
+ key?: string;
5
+ })) => Based;
6
+ interface BasedContextType {
7
+ clients: {
8
+ [key: string]: Based;
9
+ };
10
+ createClient?: CreateClient;
11
+ removeClient: (selector: string | (BasedOpts & {
12
+ key?: string;
13
+ }) | Based) => void;
14
+ }
15
+ export declare const BasedContext: React.Context<BasedContextType>;
16
+ export declare const defaultCreateClient: CreateClient;
17
+ export declare const Provider: FunctionComponent<{
18
+ client?: Based;
19
+ clients?: {
20
+ [key: string]: Based;
21
+ };
22
+ children: ReactNode;
23
+ createClient?: CreateClient;
24
+ }>;
25
+ export declare const useBasedContext: () => BasedContextType;
26
+ export declare const useClients: () => Based[];
27
+ export declare const useClient: (selector?: string | (BasedOpts & {
28
+ key?: string;
29
+ })) => Based;
30
+ export {};
@@ -0,0 +1,144 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.useClient = exports.useClients = exports.useBasedContext = exports.Provider = exports.defaultCreateClient = exports.BasedContext = void 0;
27
+ const react_1 = __importStar(require("react"));
28
+ const client_1 = __importStar(require("@based/client"));
29
+ const genOptsId_1 = require("./genOptsId");
30
+ const newClientListeners = new Set();
31
+ exports.BasedContext = (0, react_1.createContext)({
32
+ clients: {},
33
+ // eslint-disable-next-line
34
+ removeClient: (...args) => { },
35
+ });
36
+ const defaultCreateClient = (selector) => {
37
+ if (typeof selector === 'object') {
38
+ if (typeof process !== 'undefined' &&
39
+ process.env.CLUSTER &&
40
+ process.env.CLUSTER.startsWith('local') &&
41
+ !selector.cluster) {
42
+ selector.cluster = process.env.CLUSTER;
43
+ }
44
+ return (0, client_1.default)(selector);
45
+ }
46
+ else {
47
+ // default
48
+ console.error('Cannot create client from ' + selector);
49
+ }
50
+ };
51
+ exports.defaultCreateClient = defaultCreateClient;
52
+ const Provider = ({ client, children, clients, createClient }) => {
53
+ if (!clients && client) {
54
+ clients = {
55
+ default: client,
56
+ };
57
+ }
58
+ else if (clients && client) {
59
+ clients.default = client;
60
+ }
61
+ const ctx = react_1.default.createElement(exports.BasedContext.Provider, {
62
+ value: {
63
+ clients,
64
+ createClient: createClient || exports.defaultCreateClient,
65
+ removeClient: (selector) => {
66
+ if (selector instanceof client_1.Based) {
67
+ for (const cl in clients) {
68
+ if (clients[cl] === selector) {
69
+ selector = cl;
70
+ break;
71
+ }
72
+ }
73
+ if (typeof selector !== 'string') {
74
+ console.error('Cannot find client to remove from ctx', selector);
75
+ return;
76
+ }
77
+ }
78
+ else if (typeof selector !== 'string') {
79
+ selector = (0, genOptsId_1.genOptsId)(selector);
80
+ }
81
+ // @ts-ignore
82
+ if (clients[selector]) {
83
+ // @ts-ignore
84
+ clients[selector].disconnect();
85
+ // @ts-ignore
86
+ delete clients[selector];
87
+ newClientListeners.forEach((fn) => fn());
88
+ }
89
+ },
90
+ },
91
+ }, children);
92
+ return ctx;
93
+ };
94
+ exports.Provider = Provider;
95
+ const useBasedContext = () => {
96
+ return (0, react_1.useContext)(exports.BasedContext);
97
+ };
98
+ exports.useBasedContext = useBasedContext;
99
+ function forceUpdate(state) {
100
+ return state + 1;
101
+ }
102
+ const useClients = () => {
103
+ const ctx = (0, exports.useBasedContext)();
104
+ const [, update] = (0, react_1.useReducer)(forceUpdate, 0);
105
+ (0, react_1.useEffect)(() => {
106
+ let timer;
107
+ const fn = () => {
108
+ timer = setTimeout(update, 0);
109
+ };
110
+ newClientListeners.add(fn);
111
+ return () => {
112
+ newClientListeners.delete(fn);
113
+ clearTimeout(timer);
114
+ };
115
+ }, []);
116
+ return Object.values(ctx.clients);
117
+ };
118
+ exports.useClients = useClients;
119
+ const useClient = (selector = 'default') => {
120
+ const basedCtx = (0, react_1.useContext)(exports.BasedContext);
121
+ if (typeof selector === 'object') {
122
+ if (!(selector.env && selector.project && selector.org)) {
123
+ return;
124
+ }
125
+ }
126
+ let key;
127
+ if (typeof selector === 'string') {
128
+ key = selector;
129
+ }
130
+ else {
131
+ key = selector.key || (0, genOptsId_1.genOptsId)(selector);
132
+ }
133
+ let client = basedCtx.clients[key];
134
+ if (!client && basedCtx.createClient) {
135
+ client = basedCtx.createClient(selector);
136
+ if (client) {
137
+ basedCtx.clients[key] = client;
138
+ newClientListeners.forEach((fn) => fn());
139
+ }
140
+ }
141
+ return client;
142
+ };
143
+ exports.useClient = useClient;
144
+ //# sourceMappingURL=clients.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"clients.js","sourceRoot":"","sources":["../src/clients.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ /// <reference types="react" />
2
+ export declare function InfiniteList({ query, delay, itemSize, height, limit, treshold, target, ...props }: {
3
+ [x: string]: any;
4
+ query: any;
5
+ delay?: number;
6
+ itemSize?: number;
7
+ height?: number;
8
+ limit?: number;
9
+ treshold?: number;
10
+ target?: string;
11
+ }): JSX.Element;
@@ -0,0 +1,160 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.InfiniteList = void 0;
27
+ const client_1 = require("@based/client");
28
+ const react_1 = __importStar(require("react"));
29
+ const react_window_1 = require("react-window");
30
+ const __1 = require("../..");
31
+ const addScrollSub = (client, subId, payload, offset, current, setChecksum) => {
32
+ const [, subscriberId] = (0, client_1.addSubscriber)(client.client, payload, ({ items }, checksum) => {
33
+ for (let i = 0; i < items.length; i++) {
34
+ current.items[i + offset] = items[i];
35
+ }
36
+ setChecksum(`${offset}-${checksum}`);
37
+ }, (err) => err && console.error(err), console.error, subId);
38
+ return subscriberId;
39
+ };
40
+ function InfiniteList({ query, delay = 100, itemSize = 50, height = 400, limit = Math.ceil(height / itemSize), treshold = 0, target = 'root', ...props }) {
41
+ const blockHeight = itemSize * limit;
42
+ const client = (0, __1.useClient)();
43
+ const [offset, setOffset] = (0, react_1.useState)(0);
44
+ const [blocks, setBlocks] = (0, react_1.useState)(() => {
45
+ let blocks = Math.ceil(height / blockHeight);
46
+ if (treshold) {
47
+ blocks += Math.ceil((height / itemSize + treshold - blocks * limit) / limit);
48
+ }
49
+ return blocks;
50
+ });
51
+ const [, setChecksum] = (0, react_1.useState)();
52
+ const { current } = (0, react_1.useRef)({
53
+ offset,
54
+ blocks,
55
+ scroll: 0,
56
+ items: [],
57
+ timer: null,
58
+ subs: {},
59
+ });
60
+ const { data: { itemCount }, } = (0, __1.useData)({
61
+ itemCount: {
62
+ $aggregate: {
63
+ $function: 'count',
64
+ ...query().$list.$find,
65
+ },
66
+ },
67
+ });
68
+ (0, react_1.useEffect)(() => {
69
+ if (client) {
70
+ return () => {
71
+ const { subs } = current;
72
+ current.subs = {};
73
+ setTimeout(() => {
74
+ for (const subId in subs) {
75
+ const subscriberId = current.subs[subId];
76
+ (0, client_1.removeSubscriber)(client.client, Number(subId), subscriberId);
77
+ }
78
+ });
79
+ };
80
+ }
81
+ }, [client, current]);
82
+ (0, react_1.useEffect)(() => {
83
+ if (client) {
84
+ const subs = {};
85
+ let i = blocks;
86
+ while (i--) {
87
+ const start = offset + limit * i;
88
+ const payload = {
89
+ $id: target,
90
+ items: query(start, limit),
91
+ };
92
+ const subId = (0, client_1.generateSubscriptionId)(payload);
93
+ subs[subId] =
94
+ current.subs[subId] ||
95
+ addScrollSub(client, subId, payload, start, current, setChecksum);
96
+ }
97
+ for (const subId in current.subs) {
98
+ if (!(subId in subs)) {
99
+ const subscriberId = current.subs[subId];
100
+ (0, client_1.removeSubscriber)(client.client, Number(subId), subscriberId);
101
+ }
102
+ }
103
+ current.subs = subs;
104
+ }
105
+ }, [target, client, offset, blocks, query, current]); // dont include limit
106
+ (0, react_1.useEffect)(update, [
107
+ blockHeight,
108
+ delay,
109
+ height,
110
+ itemSize,
111
+ current,
112
+ limit,
113
+ treshold,
114
+ ]);
115
+ if (!itemCount || !current.items.length) {
116
+ return null;
117
+ }
118
+ return (react_1.default.createElement(react_window_1.FixedSizeList, { ...props, height: height, itemSize: itemSize, itemData: current.items, itemCount: itemCount, onScroll: ({ scrollOffset }) => {
119
+ current.scroll = scrollOffset;
120
+ update();
121
+ } }));
122
+ function update() {
123
+ const start = Math.max(0, current.scroll / itemSize - treshold);
124
+ const end = (current.scroll + height) / itemSize;
125
+ const newOffset = start - (start % limit);
126
+ let newBlocks = Math.ceil(height / blockHeight + (current.scroll % blockHeight) / blockHeight);
127
+ if (treshold) {
128
+ const newLength = newOffset + limit * newBlocks;
129
+ newBlocks += Math.max(0, Math.ceil((end + treshold - newLength) / limit));
130
+ }
131
+ if (newOffset !== current.offset || newBlocks !== current.blocks) {
132
+ current.offset = newOffset;
133
+ current.blocks = newBlocks;
134
+ const set = () => {
135
+ setOffset(current.offset);
136
+ setBlocks(current.blocks);
137
+ };
138
+ if (current.timer) {
139
+ clearTimeout(current.timer);
140
+ }
141
+ else {
142
+ set();
143
+ }
144
+ current.timer = setTimeout(() => {
145
+ current.timer = null;
146
+ set();
147
+ }, delay);
148
+ }
149
+ else if (current.timer) {
150
+ clearTimeout(current.timer);
151
+ current.timer = setTimeout(() => {
152
+ current.timer = null;
153
+ setOffset(current.offset);
154
+ setBlocks(current.blocks);
155
+ }, delay);
156
+ }
157
+ }
158
+ }
159
+ exports.InfiniteList = InfiniteList;
160
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/InfiniteList/index.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import { BasedOpts } from '@based/client';
2
+ export declare const genOptsId: (opts: BasedOpts & {
3
+ key?: string;
4
+ }) => string;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.genOptsId = void 0;
4
+ const genOptsId = (opts) => {
5
+ if (!opts) {
6
+ return;
7
+ }
8
+ if (opts.key) {
9
+ return opts.key;
10
+ }
11
+ return `${opts.env}_${opts.project}_${opts.org}_${opts.cluster || ''}_${opts.name || ''}`;
12
+ };
13
+ exports.genOptsId = genOptsId;
14
+ //# sourceMappingURL=genOptsId.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"genOptsId.js","sourceRoot":"","sources":["../src/genOptsId.ts"],"names":[],"mappings":";;;AAEO,MAAM,SAAS,GAAG,CAAC,IAAkC,EAAU,EAAE;IACtE,IAAI,CAAC,IAAI,EAAE;QACT,OAAM;KACP;IACD,IAAI,IAAI,CAAC,GAAG,EAAE;QACZ,OAAO,IAAI,CAAC,GAAG,CAAA;KAChB;IACD,OAAO,GAAG,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,OAAO,IAAI,EAAE,IAClE,IAAI,CAAC,IAAI,IAAI,EACf,EAAE,CAAA;AACJ,CAAC,CAAA;AAVY,QAAA,SAAS,aAUrB"}
package/dist/gql.d.ts ADDED
@@ -0,0 +1,9 @@
1
+ import { BasedGraphQL, BasedOpts } from '@based/client';
2
+ import { Loading, Data } from './types';
3
+ export declare function useQuery(query?: string | BasedGraphQL, variables?: Record<string, any>, clientSelector?: string | (BasedOpts & {
4
+ key?: string;
5
+ })): {
6
+ data: Data;
7
+ error?: Error;
8
+ loading: Loading;
9
+ };
package/dist/gql.js ADDED
@@ -0,0 +1,162 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useQuery = void 0;
4
+ const react_1 = require("react");
5
+ const client_1 = require("@based/client");
6
+ const reducer_1 = require("./reducer");
7
+ const clients_1 = require("./clients");
8
+ const genOptsId_1 = require("./genOptsId");
9
+ const meta_1 = require("./meta");
10
+ const hash_1 = require("@saulx/hash");
11
+ const schemaSubId = (0, client_1.generateSubscriptionId)({ $subscribe_schema: 'default' });
12
+ // step one make 1 useEffect
13
+ // - and the nessecary if
14
+ function useQuery(query, variables = {}, clientSelector) {
15
+ const [result, dispatch] = (0, react_1.useReducer)(reducer_1.resultReducer, {
16
+ loading: true,
17
+ data: {},
18
+ checksum: 0,
19
+ });
20
+ const r = (0, react_1.useRef)({ checksum: 0, fns: {} });
21
+ const selector = clientSelector || 'default';
22
+ const client = (0, clients_1.useClient)(selector);
23
+ if (query) {
24
+ const [configState, updateConfigState] = (0, react_1.useState)(0);
25
+ (0, react_1.useEffect)(() => {
26
+ const [, subscriberId] = (0, client_1.addSubscriber)(client.client,
27
+ // FIXME dont want too many updates plz this has to become 1 use effect
28
+ { $subscribe_schema: 'default' }, (d, checksum) => {
29
+ if (!client.client.configuration) {
30
+ client.client.configuration = {
31
+ dbs: [],
32
+ schema: {},
33
+ functions: {},
34
+ }; // TODO: FIX
35
+ }
36
+ client.client.configuration.schema.default = d;
37
+ updateConfigState(checksum);
38
+ }, (err) => {
39
+ if (err) {
40
+ console.error(err);
41
+ }
42
+ }, (err) => {
43
+ console.error(err);
44
+ }, schemaSubId);
45
+ return () => {
46
+ (0, client_1.removeSubscriber)(client.client, schemaSubId, subscriberId);
47
+ };
48
+ return () => { };
49
+ }, []);
50
+ if (configState) {
51
+ let op;
52
+ if (typeof query === 'string') {
53
+ op = client.gql(query);
54
+ }
55
+ else {
56
+ op = query;
57
+ }
58
+ op = (0, client_1.handleGraphqlVariables)(op, op, variables);
59
+ const fns = {};
60
+ const queryObj = {};
61
+ for (const key in op.ops) {
62
+ if (op.ops[key].fnObserve) {
63
+ const { name, payload } = op.ops[key].fnObserve;
64
+ fns[key] = { name: name, payload, key };
65
+ continue;
66
+ }
67
+ queryObj[key] = op.ops[key].get;
68
+ }
69
+ const fnHash = (0, react_1.useMemo)(() => {
70
+ return (0, hash_1.hashObjectIgnoreKeyOrder)(fns);
71
+ }, [fns]);
72
+ const subId = (0, react_1.useMemo)(() => {
73
+ // fn?
74
+ return (0, client_1.generateSubscriptionId)(queryObj);
75
+ }, [queryObj]);
76
+ const clientKey = typeof selector === 'string' ? selector : (0, genOptsId_1.genOptsId)(selector);
77
+ if (client) {
78
+ const subKey = clientKey + subId;
79
+ (0, react_1.useEffect)(() => {
80
+ const subs = [];
81
+ for (const key in fns) {
82
+ subs.push((0, client_1.addSubscriber)(client.client, fns[key].payload, (d, checksum) => {
83
+ (0, meta_1.updateMeta)(subKey, false, false);
84
+ if (r.current.fns[key] !== checksum) {
85
+ r.current.fns[key] = checksum;
86
+ dispatch({
87
+ merge: { [key]: d },
88
+ checksum: (0, hash_1.hashObjectIgnoreKeyOrder)(r.current),
89
+ });
90
+ }
91
+ }, (err) => {
92
+ if (err) {
93
+ console.error(err);
94
+ dispatch({ error: err, loading: false });
95
+ }
96
+ }, (err) => {
97
+ console.error(err);
98
+ (0, meta_1.updateMeta)(subKey, false, err);
99
+ dispatch({ error: err });
100
+ }, undefined, fns[key].name));
101
+ }
102
+ return () => {
103
+ for (const [subId, subscriberId] of subs) {
104
+ (0, client_1.removeSubscriber)(client.client, subId, subscriberId);
105
+ }
106
+ };
107
+ }, [fnHash]);
108
+ (0, react_1.useEffect)(() => {
109
+ if (!configState) {
110
+ return;
111
+ }
112
+ (0, meta_1.updateMeta)(subKey, true, false);
113
+ const [, subscriberId] = (0, client_1.addSubscriber)(client.client, queryObj, (d, checksum) => {
114
+ (0, meta_1.updateMeta)(subKey, false, false);
115
+ if (r.current.checksum !== checksum) {
116
+ r.current.checksum = checksum;
117
+ dispatch({
118
+ merge: d,
119
+ checksum: (0, hash_1.hashObjectIgnoreKeyOrder)(r.current),
120
+ });
121
+ }
122
+ }, (err) => {
123
+ if (err) {
124
+ console.error(err);
125
+ (0, meta_1.updateMeta)(subKey, false, err);
126
+ dispatch({ error: err, loading: false });
127
+ }
128
+ }, (err) => {
129
+ console.error(err);
130
+ (0, meta_1.updateMeta)(subKey, false, err);
131
+ dispatch({ error: err });
132
+ }, subId);
133
+ return () => {
134
+ (0, meta_1.updateMeta)(subKey, false, false);
135
+ (0, client_1.removeSubscriber)(client.client, subId, subscriberId);
136
+ };
137
+ }, [subId, clientKey, configState]);
138
+ }
139
+ else {
140
+ (0, react_1.useEffect)(stubFn, [null, null]);
141
+ }
142
+ }
143
+ else {
144
+ (0, react_1.useMemo)(stubFn, [null]);
145
+ (0, react_1.useMemo)(stubFn, [null]);
146
+ (0, react_1.useEffect)(stubFn, [null]);
147
+ (0, react_1.useEffect)(stubFn, [null, null, null]);
148
+ }
149
+ }
150
+ else {
151
+ (0, react_1.useState)(null);
152
+ (0, react_1.useEffect)(stubFn, [null]);
153
+ (0, react_1.useMemo)(stubFn, [null]);
154
+ (0, react_1.useMemo)(stubFn, [null]);
155
+ (0, react_1.useEffect)(stubFn, [null]);
156
+ (0, react_1.useEffect)(stubFn, [null, null, null]);
157
+ }
158
+ return result;
159
+ }
160
+ exports.useQuery = useQuery;
161
+ function stubFn() { }
162
+ //# sourceMappingURL=gql.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gql.js","sourceRoot":"","sources":["../src/gql.ts"],"names":[],"mappings":"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"}
package/dist/index.d.ts CHANGED
@@ -1,10 +1,10 @@
1
- import { ReactNode } from 'react';
1
+ import { FC } from 'react';
2
2
  import { BasedClient, AuthState } from '@based/client';
3
- export declare const Provider: ({ client, children, }: {
4
- client: BasedClient;
5
- children: ReactNode;
6
- }) => any;
3
+ export declare const Provider: FC;
7
4
  export declare const useAuthState: () => AuthState;
5
+ export declare const useConnected: () => {
6
+ connected: any;
7
+ };
8
8
  export declare const useQuery: (name?: string, payload?: any, opts?: {
9
9
  persistent: boolean;
10
10
  }) => {
package/dist/index.js CHANGED
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.useClient = exports.useQuery = exports.useAuthState = exports.Provider = void 0;
3
+ exports.useClient = exports.useQuery = exports.useConnected = exports.useAuthState = exports.Provider = void 0;
4
4
  const react_1 = require("react");
5
5
  const Ctx = (0, react_1.createContext)();
6
6
  const Provider = ({ client, children, }) => {
@@ -23,9 +23,31 @@ const useAuthState = () => {
23
23
  return state;
24
24
  };
25
25
  exports.useAuthState = useAuthState;
26
+ const useConnected = () => {
27
+ const client = (0, react_1.useContext)(Ctx);
28
+ const [connected, setConnected] = (0, react_1.useState)(client.connected);
29
+ (0, react_1.useEffect)(() => {
30
+ if (client) {
31
+ setConnected(client.connected);
32
+ const listener = () => {
33
+ setConnected(client.connected);
34
+ };
35
+ client.on('disconnect', listener);
36
+ client.on('reconnect', listener);
37
+ client.on('connect', listener);
38
+ return () => {
39
+ client.off('disconnect', listener);
40
+ client.off('reconnect', listener);
41
+ client.off('connect', listener);
42
+ };
43
+ }
44
+ }, [client]);
45
+ return { connected };
46
+ };
47
+ exports.useConnected = useConnected;
26
48
  const useQuery = (name, payload, opts) => {
27
49
  const client = (0, react_1.useContext)(Ctx);
28
- if (name) {
50
+ if (client && name) {
29
51
  const q = client.query(name, payload, opts);
30
52
  const { id, cache } = q;
31
53
  const [checksum, update] = (0, react_1.useState)(cache?.checksum);
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,iCAOc;AAGd,MAAM,GAAG,GAAG,IAAA,qBAAa,GAAe,CAAA;AAEjC,MAAM,QAAQ,GAAG,CAAC,EACvB,MAAM,EACN,QAAQ,GAIT,EAAE,EAAE;IACH,OAAO,IAAA,qBAAa,EAAC,GAAG,CAAC,QAAQ,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,QAAQ,CAAC,CAAA;AACjE,CAAC,CAAA;AARY,QAAA,QAAQ,YAQpB;AAEM,MAAM,YAAY,GAAG,GAAc,EAAE;IAC1C,MAAM,MAAM,GAAgB,IAAA,kBAAU,EAAC,GAAG,CAAC,CAAA;IAC3C,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,EAAY,MAAM,EAAE,SAAS,IAAI,EAAE,CAAC,CAAA;IAEtE,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,IAAI,MAAM,EAAE;YACV,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAA;YAC1B,MAAM,QAAQ,GAAG,CAAC,SAAS,EAAE,EAAE;gBAC7B,QAAQ,CAAC,SAAS,CAAC,CAAA;YACrB,CAAC,CAAA;YACD,MAAM,CAAC,EAAE,CAAC,kBAAkB,EAAE,QAAQ,CAAC,CAAA;YACvC,OAAO,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,kBAAkB,EAAE,QAAQ,CAAC,CAAA;SACtD;IACH,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAA;IAEZ,OAAO,KAAK,CAAA;AACd,CAAC,CAAA;AAhBY,QAAA,YAAY,gBAgBxB;AAEM,MAAM,QAAQ,GAAG,CACtB,IAAa,EACb,OAAa,EACb,IAEC,EAKD,EAAE;IACF,MAAM,MAAM,GAAgB,IAAA,kBAAU,EAAC,GAAG,CAAC,CAAA;IAE3C,IAAI,IAAI,EAAE;QACR,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,CAAA;QAC3C,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,GAAG,CAAC,CAAA;QACvB,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,EAAE,QAAQ,CAAC,CAAA;QAEpD,IAAA,iBAAS,EAAC,GAAG,EAAE;YACb,MAAM,WAAW,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE;gBAC9C,MAAM,CAAC,QAAQ,CAAC,CAAA;YAClB,CAAC,CAAC,CAAA;YAEF,OAAO,GAAG,EAAE;gBACV,WAAW,EAAE,CAAA;YACf,CAAC,CAAA;QACH,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAA;QAER,OAAO,KAAK;YACV,CAAC,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,CAAC,KAAK,EAAE,QAAQ,EAAE;YACjD,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAA;KACtB;IAED,QAAQ;IACR,IAAA,iBAAS,EAAC,GAAG,EAAE,GAAE,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAC3B,IAAA,gBAAQ,GAAE,CAAA;IAEV,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,CAAA;AACtC,CAAC,CAAA;AAtCY,QAAA,QAAQ,YAsCpB;AAEM,MAAM,SAAS,GAAG,GAAgB,EAAE;IACzC,MAAM,MAAM,GAAG,IAAA,kBAAU,EAAC,GAAG,CAAC,CAAA;IAC9B,OAAO,MAAM,CAAA;AACf,CAAC,CAAA;AAHY,QAAA,SAAS,aAGrB"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,iCAQc;AAGd,MAAM,GAAG,GAAG,IAAA,qBAAa,GAAe,CAAA;AAEjC,MAAM,QAAQ,GAAO,CAAC,EAC3B,MAAM,EACN,QAAQ,GAIT,EAAE,EAAE;IACH,OAAO,IAAA,qBAAa,EAAC,GAAG,CAAC,QAAQ,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,QAAQ,CAAC,CAAA;AACjE,CAAC,CAAA;AARY,QAAA,QAAQ,YAQpB;AAEM,MAAM,YAAY,GAAG,GAAc,EAAE;IAC1C,MAAM,MAAM,GAAgB,IAAA,kBAAU,EAAC,GAAG,CAAC,CAAA;IAC3C,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,EAAY,MAAM,EAAE,SAAS,IAAI,EAAE,CAAC,CAAA;IAEtE,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,IAAI,MAAM,EAAE;YACV,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAA;YAC1B,MAAM,QAAQ,GAAG,CAAC,SAAS,EAAE,EAAE;gBAC7B,QAAQ,CAAC,SAAS,CAAC,CAAA;YACrB,CAAC,CAAA;YACD,MAAM,CAAC,EAAE,CAAC,kBAAkB,EAAE,QAAQ,CAAC,CAAA;YACvC,OAAO,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,kBAAkB,EAAE,QAAQ,CAAC,CAAA;SACtD;IACH,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAA;IAEZ,OAAO,KAAK,CAAA;AACd,CAAC,CAAA;AAhBY,QAAA,YAAY,gBAgBxB;AAEM,MAAM,YAAY,GAAG,GAAG,EAAE;IAC/B,MAAM,MAAM,GAAgB,IAAA,kBAAU,EAAC,GAAG,CAAC,CAAA;IAC3C,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,IAAA,gBAAQ,EAAC,MAAM,CAAC,SAAS,CAAC,CAAA;IAE5D,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,IAAI,MAAM,EAAE;YACV,YAAY,CAAC,MAAM,CAAC,SAAS,CAAC,CAAA;YAC9B,MAAM,QAAQ,GAAG,GAAG,EAAE;gBACpB,YAAY,CAAC,MAAM,CAAC,SAAS,CAAC,CAAA;YAChC,CAAC,CAAA;YACD,MAAM,CAAC,EAAE,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAA;YACjC,MAAM,CAAC,EAAE,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAA;YAChC,MAAM,CAAC,EAAE,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAA;YAC9B,OAAO,GAAG,EAAE;gBACV,MAAM,CAAC,GAAG,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAA;gBAClC,MAAM,CAAC,GAAG,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAA;gBACjC,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAA;YACjC,CAAC,CAAA;SACF;IACH,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAA;IAEZ,OAAO,EAAE,SAAS,EAAE,CAAA;AACtB,CAAC,CAAA;AAtBY,QAAA,YAAY,gBAsBxB;AAEM,MAAM,QAAQ,GAAG,CACtB,IAAa,EACb,OAAa,EACb,IAEC,EAKD,EAAE;IACF,MAAM,MAAM,GAAgB,IAAA,kBAAU,EAAC,GAAG,CAAC,CAAA;IAE3C,IAAI,MAAM,IAAI,IAAI,EAAE;QAClB,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,CAAA;QAC3C,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,GAAG,CAAC,CAAA;QACvB,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,EAAE,QAAQ,CAAC,CAAA;QAEpD,IAAA,iBAAS,EAAC,GAAG,EAAE;YACb,MAAM,WAAW,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE;gBAC9C,MAAM,CAAC,QAAQ,CAAC,CAAA;YAClB,CAAC,CAAC,CAAA;YAEF,OAAO,GAAG,EAAE;gBACV,WAAW,EAAE,CAAA;YACf,CAAC,CAAA;QACH,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAA;QAER,OAAO,KAAK;YACV,CAAC,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,CAAC,KAAK,EAAE,QAAQ,EAAE;YACjD,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAA;KACtB;IAED,QAAQ;IACR,IAAA,iBAAS,EAAC,GAAG,EAAE,GAAE,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAC3B,IAAA,gBAAQ,GAAE,CAAA;IAEV,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,CAAA;AACtC,CAAC,CAAA;AAtCY,QAAA,QAAQ,YAsCpB;AAEM,MAAM,SAAS,GAAG,GAAgB,EAAE;IACzC,MAAM,MAAM,GAAG,IAAA,kBAAU,EAAC,GAAG,CAAC,CAAA;IAC9B,OAAO,MAAM,CAAA;AACf,CAAC,CAAA;AAHY,QAAA,SAAS,aAGrB"}
package/dist/meta.d.ts ADDED
@@ -0,0 +1,8 @@
1
+ export declare function updateMeta(subKey: any, loading: any, error: any): void;
2
+ export declare function useLoading(): {
3
+ loading: boolean;
4
+ };
5
+ export declare function useError(): {
6
+ error: string;
7
+ errors: unknown[];
8
+ };
package/dist/meta.js ADDED
@@ -0,0 +1,70 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useError = exports.useLoading = exports.updateMeta = void 0;
4
+ const react_1 = require("react");
5
+ const errors = {};
6
+ const errorListeners = new Set();
7
+ const loadings = new Set();
8
+ const loadingListeners = new Set();
9
+ let isLoading = false;
10
+ let lastError = '';
11
+ let errorCnt = 0;
12
+ let errorKey = errorCnt + lastError;
13
+ function updateMeta(subKey, loading, error) {
14
+ if (error) {
15
+ lastError = error;
16
+ if (subKey in errors) {
17
+ errors[subKey] = error;
18
+ }
19
+ else {
20
+ errors[subKey] = error;
21
+ errorCnt++;
22
+ }
23
+ }
24
+ else {
25
+ if (subKey in errors) {
26
+ errorCnt--;
27
+ delete errors[subKey];
28
+ }
29
+ }
30
+ const newErrorKey = errorCnt + lastError;
31
+ if (newErrorKey !== errorKey) {
32
+ errorKey = newErrorKey;
33
+ errorListeners.forEach((fn) => fn(errorKey));
34
+ }
35
+ if (loading) {
36
+ loadings.add(subKey);
37
+ }
38
+ else {
39
+ loadings.delete(subKey);
40
+ }
41
+ const newLoading = !!loadings.size;
42
+ if (newLoading !== isLoading) {
43
+ isLoading = newLoading;
44
+ loadingListeners.forEach((fn) => fn(isLoading));
45
+ }
46
+ }
47
+ exports.updateMeta = updateMeta;
48
+ function useLoading() {
49
+ const [, setLoading] = (0, react_1.useState)(isLoading);
50
+ loadingListeners.add(setLoading);
51
+ (0, react_1.useEffect)(() => {
52
+ return () => {
53
+ loadingListeners.delete(setLoading);
54
+ };
55
+ }, []);
56
+ return { loading: isLoading };
57
+ }
58
+ exports.useLoading = useLoading;
59
+ function useError() {
60
+ const [, setError] = (0, react_1.useState)(errorKey);
61
+ errorListeners.add(setError);
62
+ (0, react_1.useEffect)(() => {
63
+ return () => {
64
+ errorListeners.delete(setError);
65
+ };
66
+ }, []);
67
+ return { error: errorCnt ? lastError : null, errors: Object.values(errors) };
68
+ }
69
+ exports.useError = useError;
70
+ //# sourceMappingURL=meta.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"meta.js","sourceRoot":"","sources":["../src/meta.ts"],"names":[],"mappings":";;;AAAA,iCAA2C;AAE3C,MAAM,MAAM,GAAG,EAAE,CAAA;AACjB,MAAM,cAAc,GAAG,IAAI,GAAG,EAAE,CAAA;AAChC,MAAM,QAAQ,GAAG,IAAI,GAAG,EAAE,CAAA;AAC1B,MAAM,gBAAgB,GAAG,IAAI,GAAG,EAAE,CAAA;AAElC,IAAI,SAAS,GAAG,KAAK,CAAA;AACrB,IAAI,SAAS,GAAG,EAAE,CAAA;AAClB,IAAI,QAAQ,GAAG,CAAC,CAAA;AAChB,IAAI,QAAQ,GAAG,QAAQ,GAAG,SAAS,CAAA;AAEnC,SAAgB,UAAU,CAAC,MAAM,EAAE,OAAO,EAAE,KAAK;IAC/C,IAAI,KAAK,EAAE;QACT,SAAS,GAAG,KAAK,CAAA;QACjB,IAAI,MAAM,IAAI,MAAM,EAAE;YACpB,MAAM,CAAC,MAAM,CAAC,GAAG,KAAK,CAAA;SACvB;aAAM;YACL,MAAM,CAAC,MAAM,CAAC,GAAG,KAAK,CAAA;YACtB,QAAQ,EAAE,CAAA;SACX;KACF;SAAM;QACL,IAAI,MAAM,IAAI,MAAM,EAAE;YACpB,QAAQ,EAAE,CAAA;YACV,OAAO,MAAM,CAAC,MAAM,CAAC,CAAA;SACtB;KACF;IAED,MAAM,WAAW,GAAG,QAAQ,GAAG,SAAS,CAAA;IACxC,IAAI,WAAW,KAAK,QAAQ,EAAE;QAC5B,QAAQ,GAAG,WAAW,CAAA;QACtB,cAAc,CAAC,OAAO,CAAC,CAAC,EAAY,EAAE,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAA;KACvD;IAED,IAAI,OAAO,EAAE;QACX,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;KACrB;SAAM;QACL,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;KACxB;IAED,MAAM,UAAU,GAAG,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAA;IAClC,IAAI,UAAU,KAAK,SAAS,EAAE;QAC5B,SAAS,GAAG,UAAU,CAAA;QACtB,gBAAgB,CAAC,OAAO,CAAC,CAAC,EAAY,EAAE,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;KAC1D;AACH,CAAC;AAjCD,gCAiCC;AAED,SAAgB,UAAU;IACxB,MAAM,CAAC,EAAE,UAAU,CAAC,GAAG,IAAA,gBAAQ,EAAC,SAAS,CAAC,CAAA;IAE1C,gBAAgB,CAAC,GAAG,CAAC,UAAU,CAAC,CAAA;IAEhC,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,OAAO,GAAG,EAAE;YACV,gBAAgB,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;QACrC,CAAC,CAAA;IACH,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,CAAA;AAC/B,CAAC;AAZD,gCAYC;AAED,SAAgB,QAAQ;IACtB,MAAM,CAAC,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,EAAC,QAAQ,CAAC,CAAA;IAEvC,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;IAE5B,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,OAAO,GAAG,EAAE;YACV,cAAc,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;QACjC,CAAC,CAAA;IACH,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAA;AAC9E,CAAC;AAZD,4BAYC"}
@@ -0,0 +1,18 @@
1
+ import { Data, Loading } from './types';
2
+ export declare function resultReducer(state: {
3
+ data: Data;
4
+ error?: Error;
5
+ loading: Loading;
6
+ checksum: number;
7
+ }, action: {
8
+ merge?: Data;
9
+ data?: Data;
10
+ error?: Error;
11
+ loading?: Loading;
12
+ checksum?: number;
13
+ }): {
14
+ data: Data;
15
+ error?: Error;
16
+ loading: Loading;
17
+ checksum: number;
18
+ };
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.resultReducer = void 0;
4
+ function resultReducer(state, action) {
5
+ if (action.error) {
6
+ state.error = action.error;
7
+ }
8
+ if (action.data) {
9
+ state.checksum = action.checksum || 0;
10
+ state.data = action.data;
11
+ state.loading = false;
12
+ if (state.error) {
13
+ delete state.error;
14
+ }
15
+ }
16
+ if (action.merge) {
17
+ state.checksum = action.checksum || 0;
18
+ if (!state.data) {
19
+ state.data = action.merge;
20
+ }
21
+ else {
22
+ Object.assign(state.data, action.merge);
23
+ }
24
+ state.loading = false;
25
+ if (state.error) {
26
+ delete state.error;
27
+ }
28
+ }
29
+ if (action.loading) {
30
+ state.loading = action.loading;
31
+ }
32
+ return { ...state };
33
+ }
34
+ exports.resultReducer = resultReducer;
35
+ //# sourceMappingURL=reducer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reducer.js","sourceRoot":"","sources":["../src/reducer.ts"],"names":[],"mappings":";;;AAEA,SAAgB,aAAa,CAC3B,KAAwE,EACxE,MAMC;IAED,IAAI,MAAM,CAAC,KAAK,EAAE;QAChB,KAAK,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAA;KAC3B;IACD,IAAI,MAAM,CAAC,IAAI,EAAE;QACf,KAAK,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,IAAI,CAAC,CAAA;QACrC,KAAK,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAA;QACxB,KAAK,CAAC,OAAO,GAAG,KAAK,CAAA;QACrB,IAAI,KAAK,CAAC,KAAK,EAAE;YACf,OAAO,KAAK,CAAC,KAAK,CAAA;SACnB;KACF;IAED,IAAI,MAAM,CAAC,KAAK,EAAE;QAChB,KAAK,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,IAAI,CAAC,CAAA;QACrC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE;YACf,KAAK,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,CAAA;SAC1B;aAAM;YACL,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;SACxC;QACD,KAAK,CAAC,OAAO,GAAG,KAAK,CAAA;QACrB,IAAI,KAAK,CAAC,KAAK,EAAE;YACf,OAAO,KAAK,CAAC,KAAK,CAAA;SACnB;KACF;IAED,IAAI,MAAM,CAAC,OAAO,EAAE;QAClB,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,CAAA;KAC/B;IACD,OAAO,EAAE,GAAG,KAAK,EAAE,CAAA;AACrB,CAAC;AAvCD,sCAuCC"}
@@ -0,0 +1,3 @@
1
+ import { GenericObject } from '@based/client';
2
+ export declare type Data = GenericObject;
3
+ export declare type Loading = boolean;
package/dist/types.js ADDED
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@based/react",
3
- "version": "4.2.0",
3
+ "version": "4.2.1",
4
4
  "license": "MIT",
5
5
  "main": "dist/index.js",
6
6
  "scripts": {
package/src/index.ts CHANGED
@@ -5,12 +5,13 @@ import {
5
5
  ReactNode,
6
6
  useState,
7
7
  useEffect,
8
+ FC,
8
9
  } from 'react'
9
10
  import { BasedClient, AuthState } from '@based/client'
10
11
 
11
12
  const Ctx = createContext<BasedClient>()
12
13
 
13
- export const Provider = ({
14
+ export const Provider: FC = ({
14
15
  client,
15
16
  children,
16
17
  }: {
@@ -38,6 +39,30 @@ export const useAuthState = (): AuthState => {
38
39
  return state
39
40
  }
40
41
 
42
+ export const useConnected = () => {
43
+ const client: BasedClient = useContext(Ctx)
44
+ const [connected, setConnected] = useState(client.connected)
45
+
46
+ useEffect(() => {
47
+ if (client) {
48
+ setConnected(client.connected)
49
+ const listener = () => {
50
+ setConnected(client.connected)
51
+ }
52
+ client.on('disconnect', listener)
53
+ client.on('reconnect', listener)
54
+ client.on('connect', listener)
55
+ return () => {
56
+ client.off('disconnect', listener)
57
+ client.off('reconnect', listener)
58
+ client.off('connect', listener)
59
+ }
60
+ }
61
+ }, [client])
62
+
63
+ return { connected }
64
+ }
65
+
41
66
  export const useQuery = (
42
67
  name?: string,
43
68
  payload?: any,
@@ -51,7 +76,7 @@ export const useQuery = (
51
76
  } => {
52
77
  const client: BasedClient = useContext(Ctx)
53
78
 
54
- if (name) {
79
+ if (client && name) {
55
80
  const q = client.query(name, payload, opts)
56
81
  const { id, cache } = q
57
82
  const [checksum, update] = useState(cache?.checksum)