@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.
- package/dist/clients.d.ts +30 -0
- package/dist/clients.js +144 -0
- package/dist/clients.js.map +1 -0
- package/dist/components/InfiniteList/index.d.ts +11 -0
- package/dist/components/InfiniteList/index.js +160 -0
- package/dist/components/InfiniteList/index.js.map +1 -0
- package/dist/genOptsId.d.ts +4 -0
- package/dist/genOptsId.js +14 -0
- package/dist/genOptsId.js.map +1 -0
- package/dist/gql.d.ts +9 -0
- package/dist/gql.js +162 -0
- package/dist/gql.js.map +1 -0
- package/dist/index.d.ts +5 -5
- package/dist/index.js +24 -2
- package/dist/index.js.map +1 -1
- package/dist/meta.d.ts +8 -0
- package/dist/meta.js +70 -0
- package/dist/meta.js.map +1 -0
- package/dist/reducer.d.ts +18 -0
- package/dist/reducer.js +35 -0
- package/dist/reducer.js.map +1 -0
- package/dist/types.d.ts +3 -0
- package/dist/types.js +3 -0
- package/dist/types.js.map +1 -0
- package/package.json +1 -1
- package/src/index.ts +27 -2
|
@@ -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 {};
|
package/dist/clients.js
ADDED
|
@@ -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,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
|
package/dist/gql.js.map
ADDED
|
@@ -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 {
|
|
1
|
+
import { FC } from 'react';
|
|
2
2
|
import { BasedClient, AuthState } from '@based/client';
|
|
3
|
-
export declare const Provider:
|
|
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,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
package/dist/meta.d.ts
ADDED
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
|
package/dist/meta.js.map
ADDED
|
@@ -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
|
+
};
|
package/dist/reducer.js
ADDED
|
@@ -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"}
|
package/dist/types.d.ts
ADDED
package/dist/types.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}
|
package/package.json
CHANGED
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)
|