@livestore/devtools-web-common 0.4.0-dev.9 → 0.4.0
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/.tsbuildinfo +1 -1
- package/dist/web-channel/index.d.ts +3 -3
- package/dist/web-channel/index.d.ts.map +1 -1
- package/dist/web-channel/index.js +8 -7
- package/dist/web-channel/index.js.map +1 -1
- package/dist/worker/mod.js +1 -1
- package/dist/worker/mod.js.map +1 -1
- package/package.json +48 -13
- package/src/web-channel/index.ts +10 -9
- package/src/worker/mod.ts +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Devtools,
|
|
1
|
+
import { Devtools, UnknownError } from '@livestore/common';
|
|
2
2
|
import type { Scope, Worker } from '@livestore/utils/effect';
|
|
3
3
|
import { Effect, Schema, WebChannel } from '@livestore/utils/effect';
|
|
4
4
|
import type { MeshNode } from '@livestore/webmesh';
|
|
@@ -7,7 +7,7 @@ export * as WorkerSchema from '../worker/schema.ts';
|
|
|
7
7
|
declare global {
|
|
8
8
|
var __debugWebmeshNode: any;
|
|
9
9
|
}
|
|
10
|
-
export declare const makeSessionInfoBroadcastChannel: Effect.Effect<WebChannel.WebChannel<Devtools.SessionInfo.Message, Devtools.SessionInfo.Message>,
|
|
10
|
+
export declare const makeSessionInfoBroadcastChannel: Effect.Effect<WebChannel.WebChannel<Devtools.SessionInfo.Message, Devtools.SessionInfo.Message>, UnknownError, Scope.Scope>;
|
|
11
11
|
export declare const makeNodeName: {
|
|
12
12
|
sharedWorker: ({ storeId }: {
|
|
13
13
|
storeId: string;
|
|
@@ -49,5 +49,5 @@ export declare const connectViaWorker: ({ node, target, worker, }: {
|
|
|
49
49
|
node: MeshNode;
|
|
50
50
|
target: string;
|
|
51
51
|
worker: Worker.SerializedWorkerPool<typeof WorkerSchema.Request.Type>;
|
|
52
|
-
}) => Effect.Effect<void,
|
|
52
|
+
}) => Effect.Effect<void, UnknownError, Scope.Scope>;
|
|
53
53
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/web-channel/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/web-channel/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AAE1D,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAC5D,OAAO,EAAY,MAAM,EAAE,MAAM,EAAU,UAAU,EAAE,MAAM,yBAAyB,CAAA;AAEtF,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAA;AAGlD,OAAO,KAAK,YAAY,MAAM,qBAAqB,CAAA;AAEnD,OAAO,KAAK,YAAY,MAAM,qBAAqB,CAAA;AAEnD,OAAO,CAAC,MAAM,CAAC;IACb,IAAI,kBAAkB,EAAE,GAAG,CAAA;CAC5B;AAED,eAAO,MAAM,+BAA+B,EAAE,MAAM,CAAC,MAAM,CACzD,UAAU,CAAC,UAAU,CAAC,QAAQ,CAAC,WAAW,CAAC,OAAO,EAAE,QAAQ,CAAC,WAAW,CAAC,OAAO,CAAC,EACjF,YAAY,EACZ,KAAK,CAAC,KAAK,CAIX,CAAA;AAEF,eAAO,MAAM,YAAY;gCACK;QAAE,OAAO,EAAE,MAAM,CAAA;KAAE;;mCAIlB,MAAM;qCACJ,MAAM;;CAEtC,CAAA;AAED,eAAO,MAAM,iCAAiC;;;;EAI5C,CAAA;AAEF,eAAO,MAAM,iCAAiC;;EAE5C,CAAA;AAGF,eAAO,MAAM,8BAA8B;;;;;;;;;;;;;;;;;;;CAmB1C,CAAA;AAED,eAAO,MAAM,gBAAgB,GAAI,2BAI9B;IACD,IAAI,EAAE,QAAQ,CAAA;IACd,MAAM,EAAE,MAAM,CAAA;IACd,MAAM,EAAE,MAAM,CAAC,oBAAoB,CAAC,OAAO,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;CACtE,mDA+BwC,CAAA"}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import { Devtools,
|
|
1
|
+
import { Devtools, UnknownError } from '@livestore/common';
|
|
2
2
|
import { LS_DEV } from '@livestore/utils';
|
|
3
3
|
import { Deferred, Effect, Schema, Stream, WebChannel } from '@livestore/utils/effect';
|
|
4
|
+
import { WebChannelBrowser } from '@livestore/utils/effect/browser';
|
|
4
5
|
import { WebmeshSchema } from '@livestore/webmesh';
|
|
5
6
|
import * as WorkerSchema from "../worker/schema.js";
|
|
6
7
|
export * as WorkerSchema from "../worker/schema.js";
|
|
7
|
-
export const makeSessionInfoBroadcastChannel =
|
|
8
|
+
export const makeSessionInfoBroadcastChannel = WebChannelBrowser.broadcastChannel({
|
|
8
9
|
channelName: 'session-info',
|
|
9
10
|
schema: Devtools.SessionInfo.Message,
|
|
10
11
|
});
|
|
@@ -27,13 +28,13 @@ export const ClientSessionContentscriptMainRes = Schema.TaggedStruct('ClientSess
|
|
|
27
28
|
});
|
|
28
29
|
// Effect.suspend is needed since `window` is not available in the shared worker
|
|
29
30
|
export const makeStaticClientSessionChannel = {
|
|
30
|
-
contentscriptMain: Effect.suspend(() =>
|
|
31
|
+
contentscriptMain: Effect.suspend(() => WebChannelBrowser.windowChannel({
|
|
31
32
|
listenWindow: window,
|
|
32
33
|
sendWindow: window,
|
|
33
34
|
schema: { listen: ClientSessionContentscriptMainReq, send: ClientSessionContentscriptMainRes },
|
|
34
35
|
ids: { own: 'contentscript-main-static', other: 'client-session-static' },
|
|
35
36
|
})),
|
|
36
|
-
clientSession: Effect.suspend(() =>
|
|
37
|
+
clientSession: Effect.suspend(() => WebChannelBrowser.windowChannel({
|
|
37
38
|
listenWindow: window,
|
|
38
39
|
sendWindow: window,
|
|
39
40
|
schema: { listen: ClientSessionContentscriptMainRes, send: ClientSessionContentscriptMainReq },
|
|
@@ -43,7 +44,7 @@ export const makeStaticClientSessionChannel = {
|
|
|
43
44
|
export const connectViaWorker = ({ node, target, worker, }) => Effect.gen(function* () {
|
|
44
45
|
const mc = new MessageChannel();
|
|
45
46
|
const isConnected = yield* Deferred.make();
|
|
46
|
-
if (LS_DEV) {
|
|
47
|
+
if (LS_DEV === true) {
|
|
47
48
|
yield* Effect.addFinalizerLog(`@livestore/devtools-web-common: closing message channel ${node.nodeName} → ${target}`);
|
|
48
49
|
}
|
|
49
50
|
yield* worker.execute(WorkerSchema.CreateConnection.make({ from: node.nodeName, port: mc.port1 })).pipe(Stream.tap(() => Deferred.succeed(isConnected, true)), Stream.runDrain, Effect.tapCauseLogPretty, Effect.forkScoped);
|
|
@@ -53,8 +54,8 @@ export const connectViaWorker = ({ node, target, worker, }) => Effect.gen(functi
|
|
|
53
54
|
schema: WebmeshSchema.Packet,
|
|
54
55
|
});
|
|
55
56
|
yield* node.addEdge({ target, edgeChannel: sharedWorkerConnection, replaceIfExists: true });
|
|
56
|
-
if (LS_DEV) {
|
|
57
|
+
if (LS_DEV === true) {
|
|
57
58
|
yield* Effect.logDebug(`@livestore/devtools-web-common: initiated connection: ${node.nodeName} → ${target}`);
|
|
58
59
|
}
|
|
59
|
-
}).pipe(
|
|
60
|
+
}).pipe(UnknownError.mapToUnknownError);
|
|
60
61
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/web-channel/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/web-channel/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AAC1D,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AAEzC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAA;AACtF,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAEnE,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAElD,OAAO,KAAK,YAAY,MAAM,qBAAqB,CAAA;AAEnD,OAAO,KAAK,YAAY,MAAM,qBAAqB,CAAA;AAMnD,MAAM,CAAC,MAAM,+BAA+B,GAIxC,iBAAiB,CAAC,gBAAgB,CAAC;IACrC,WAAW,EAAE,cAAc;IAC3B,MAAM,EAAE,QAAQ,CAAC,WAAW,CAAC,OAAO;CACrC,CAAC,CAAA;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG;IAC1B,YAAY,EAAE,CAAC,EAAE,OAAO,EAAuB,EAAE,EAAE,CAAC,iBAAiB,OAAO,EAAE;IAC9E,sFAAsF;IACtF,uCAAuC;IACvC,gBAAgB,EAAE;QAChB,iBAAiB,EAAE,CAAC,KAAa,EAAE,EAAE,CAAC,sBAAsB,KAAK,EAAE;QACnE,mBAAmB,EAAE,CAAC,KAAa,EAAE,EAAE,CAAC,wBAAwB,KAAK,EAAE;KACxE;CACF,CAAA;AAED,MAAM,CAAC,MAAM,iCAAiC,GAAG,MAAM,CAAC,YAAY,CAAC,mCAAmC,EAAE;IACxG,OAAO,EAAE,MAAM,CAAC,MAAM;IACtB,QAAQ,EAAE,MAAM,CAAC,MAAM;IACvB,SAAS,EAAE,MAAM,CAAC,MAAM;CACzB,CAAC,CAAA;AAEF,MAAM,CAAC,MAAM,iCAAiC,GAAG,MAAM,CAAC,YAAY,CAAC,mCAAmC,EAAE;IACxG,KAAK,EAAE,MAAM,CAAC,MAAM;CACrB,CAAC,CAAA;AAEF,gFAAgF;AAChF,MAAM,CAAC,MAAM,8BAA8B,GAAG;IAC5C,iBAAiB,EAAE,MAAM,CAAC,OAAO,CAAC,GAAG,EAAE,CACrC,iBAAiB,CAAC,aAAa,CAAC;QAC9B,YAAY,EAAE,MAAM;QAEpB,UAAU,EAAE,MAAM;QAClB,MAAM,EAAE,EAAE,MAAM,EAAE,iCAAiC,EAAE,IAAI,EAAE,iCAAiC,EAAE;QAC9F,GAAG,EAAE,EAAE,GAAG,EAAE,2BAA2B,EAAE,KAAK,EAAE,uBAAuB,EAAE;KAC1E,CAAC,CACH;IACD,aAAa,EAAE,MAAM,CAAC,OAAO,CAAC,GAAG,EAAE,CACjC,iBAAiB,CAAC,aAAa,CAAC;QAC9B,YAAY,EAAE,MAAM;QAEpB,UAAU,EAAE,MAAM;QAClB,MAAM,EAAE,EAAE,MAAM,EAAE,iCAAiC,EAAE,IAAI,EAAE,iCAAiC,EAAE;QAC9F,GAAG,EAAE,EAAE,GAAG,EAAE,uBAAuB,EAAE,KAAK,EAAE,2BAA2B,EAAE;KAC1E,CAAC,CACH;CACF,CAAA;AAED,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,EAC/B,IAAI,EACJ,MAAM,EACN,MAAM,GAKP,EAAE,EAAE,CACH,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;IAClB,MAAM,EAAE,GAAG,IAAI,cAAc,EAAE,CAAA;IAE/B,MAAM,WAAW,GAAG,KAAK,CAAC,CAAC,QAAQ,CAAC,IAAI,EAAW,CAAA;IAEnD,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;QACpB,KAAK,CAAC,CAAC,MAAM,CAAC,eAAe,CAC3B,2DAA2D,IAAI,CAAC,QAAQ,MAAM,MAAM,EAAE,CACvF,CAAA;IACH,CAAC;IAED,KAAK,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE,EAAE,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CACrG,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,EACrD,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,iBAAiB,EACxB,MAAM,CAAC,UAAU,CAClB,CAAA;IAED,KAAK,CAAC,CAAC,WAAW,CAAA;IAElB,MAAM,sBAAsB,GAAG,KAAK,CAAC,CAAC,UAAU,CAAC,kBAAkB,CAAC;QAClE,IAAI,EAAE,EAAE,CAAC,KAAK;QACd,MAAM,EAAE,aAAa,CAAC,MAAM;KAC7B,CAAC,CAAA;IAEF,KAAK,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,WAAW,EAAE,sBAAsB,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC,CAAA;IAE3F,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;QACpB,KAAK,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,yDAAyD,IAAI,CAAC,QAAQ,MAAM,MAAM,EAAE,CAAC,CAAA;IAC9G,CAAC;AACH,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC,CAAA"}
|
package/dist/worker/mod.js
CHANGED
|
@@ -13,7 +13,7 @@ export const CreateConnection = ({ from, port }) => Stream.asyncScoped((emit) =>
|
|
|
13
13
|
const { node } = yield* CacheService;
|
|
14
14
|
const messagePortChannel = yield* WebChannel.messagePortChannel({ port, schema: WebmeshSchema.Packet });
|
|
15
15
|
yield* node.addEdge({ target: from, edgeChannel: messagePortChannel, replaceIfExists: true });
|
|
16
|
-
if (LS_DEV) {
|
|
16
|
+
if (LS_DEV === true) {
|
|
17
17
|
yield* Effect.logDebug(`@livestore/devtools-web-common: accepted edge: ${node.nodeName} ← ${from}`);
|
|
18
18
|
}
|
|
19
19
|
emit.single({});
|
package/dist/worker/mod.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mod.js","sourceRoot":"","sources":["../../src/worker/mod.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AACzC,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAA;AAEpF,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAIhE,OAAO,KAAK,MAAM,MAAM,aAAa,CAAA;AAErC,MAAM,OAAO,YAAa,SAAQ,OAAO,CAAC,GAAG,CAAC,6CAA6C,CAAC,EAGzF;IACD,MAAM,CAAC,KAAK,GAAG,CAAC,EAAE,QAAQ,EAAwB,EAAE,EAAE,CACpD,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;QAClB,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAA;QAE1C,UAAU,CAAC,kBAAkB,GAAG,IAAI,CAAA;QAEpC,OAAO,EAAE,IAAI,EAAE,CAAA;IACjB,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAA;;AAGvC,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,EAAE,IAAI,EAAE,IAAI,EAAmD,EAAE,EAAE,CAClG,MAAM,CAAC,WAAW,CAA0B,CAAC,IAAI,EAAE,EAAE,CACnD,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;IAClB,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC,CAAC,YAAY,CAAA;IAEpC,MAAM,kBAAkB,GAAG,KAAK,CAAC,CAAC,UAAU,CAAC,kBAAkB,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,aAAa,CAAC,MAAM,EAAE,CAAC,CAAA;IAEvG,KAAK,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,kBAAkB,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC,CAAA;IAE7F,IAAI,MAAM,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"mod.js","sourceRoot":"","sources":["../../src/worker/mod.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AACzC,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAA;AAEpF,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAIhE,OAAO,KAAK,MAAM,MAAM,aAAa,CAAA;AAErC,MAAM,OAAO,YAAa,SAAQ,OAAO,CAAC,GAAG,CAAC,6CAA6C,CAAC,EAGzF;IACD,MAAM,CAAC,KAAK,GAAG,CAAC,EAAE,QAAQ,EAAwB,EAAE,EAAE,CACpD,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;QAClB,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAA;QAE1C,UAAU,CAAC,kBAAkB,GAAG,IAAI,CAAA;QAEpC,OAAO,EAAE,IAAI,EAAE,CAAA;IACjB,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAA;;AAGvC,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,EAAE,IAAI,EAAE,IAAI,EAAmD,EAAE,EAAE,CAClG,MAAM,CAAC,WAAW,CAA0B,CAAC,IAAI,EAAE,EAAE,CACnD,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;IAClB,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC,CAAC,YAAY,CAAA;IAEpC,MAAM,kBAAkB,GAAG,KAAK,CAAC,CAAC,UAAU,CAAC,kBAAkB,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,aAAa,CAAC,MAAM,EAAE,CAAC,CAAA;IAEvG,KAAK,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,kBAAkB,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC,CAAA;IAE7F,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;QACpB,KAAK,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,kDAAkD,IAAI,CAAC,QAAQ,MAAM,IAAI,EAAE,CAAC,CAAA;IACrG,CAAC;IAED,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;IAEf,KAAK,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,WAAW,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;IAE5D,wBAAwB;IACxB,sBAAsB;IAEtB,YAAY;AACd,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CACtB,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,2DAA2D,IAAI,EAAE,CAAC,CAAC,CAAA"}
|
package/package.json
CHANGED
|
@@ -1,27 +1,62 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@livestore/devtools-web-common",
|
|
3
|
-
"version": "0.4.0
|
|
3
|
+
"version": "0.4.0",
|
|
4
|
+
"license": "Apache-2.0",
|
|
5
|
+
"repository": {
|
|
6
|
+
"type": "git",
|
|
7
|
+
"url": "git+https://github.com/livestorejs/livestore.git"
|
|
8
|
+
},
|
|
9
|
+
"files": [
|
|
10
|
+
"dist",
|
|
11
|
+
"package.json",
|
|
12
|
+
"src"
|
|
13
|
+
],
|
|
4
14
|
"type": "module",
|
|
5
15
|
"sideEffects": false,
|
|
6
16
|
"exports": {
|
|
7
17
|
"./web-channel": "./dist/web-channel/index.js",
|
|
8
18
|
"./worker": "./dist/worker/mod.js"
|
|
9
19
|
},
|
|
10
|
-
"dependencies": {
|
|
11
|
-
"@livestore/common": "0.4.0-dev.9",
|
|
12
|
-
"@livestore/utils": "0.4.0-dev.9",
|
|
13
|
-
"@livestore/webmesh": "0.4.0-dev.9"
|
|
14
|
-
},
|
|
15
|
-
"devDependencies": {},
|
|
16
|
-
"files": [
|
|
17
|
-
"package.json",
|
|
18
|
-
"src",
|
|
19
|
-
"dist"
|
|
20
|
-
],
|
|
21
|
-
"license": "Apache-2.0",
|
|
22
20
|
"publishConfig": {
|
|
23
21
|
"access": "public"
|
|
24
22
|
},
|
|
23
|
+
"dependencies": {
|
|
24
|
+
"@livestore/common": "^0.4.0",
|
|
25
|
+
"@livestore/utils": "^0.4.0",
|
|
26
|
+
"@livestore/webmesh": "^0.4.0"
|
|
27
|
+
},
|
|
28
|
+
"peerDependencies": {
|
|
29
|
+
"@effect/ai": "^0.35.0",
|
|
30
|
+
"@effect/cli": "^0.75.1",
|
|
31
|
+
"@effect/cluster": "^0.58.2",
|
|
32
|
+
"@effect/experimental": "^0.60.0",
|
|
33
|
+
"@effect/opentelemetry": "^0.63.0",
|
|
34
|
+
"@effect/platform": "^0.96.1",
|
|
35
|
+
"@effect/platform-browser": "^0.76.0",
|
|
36
|
+
"@effect/platform-bun": "^0.89.0",
|
|
37
|
+
"@effect/platform-node": "^0.106.0",
|
|
38
|
+
"@effect/printer": "^0.49.0",
|
|
39
|
+
"@effect/printer-ansi": "^0.49.0",
|
|
40
|
+
"@effect/rpc": "^0.75.1",
|
|
41
|
+
"@effect/sql": "^0.51.1",
|
|
42
|
+
"@effect/typeclass": "^0.40.0",
|
|
43
|
+
"@effect/vitest": "^0.29.0",
|
|
44
|
+
"@opentelemetry/api": "^1.9.0",
|
|
45
|
+
"@opentelemetry/resources": "^2.2.0",
|
|
46
|
+
"@standard-schema/spec": "^1.1.0",
|
|
47
|
+
"effect": "^3.21.2"
|
|
48
|
+
},
|
|
49
|
+
"$genie": {
|
|
50
|
+
"source": "package.json.genie.ts",
|
|
51
|
+
"warning": "DO NOT EDIT - changes will be overwritten",
|
|
52
|
+
"workspaceClosureDirs": [
|
|
53
|
+
"packages/@livestore/common",
|
|
54
|
+
"packages/@livestore/devtools-web-common",
|
|
55
|
+
"packages/@livestore/utils",
|
|
56
|
+
"packages/@livestore/utils-dev",
|
|
57
|
+
"packages/@livestore/webmesh"
|
|
58
|
+
]
|
|
59
|
+
},
|
|
25
60
|
"scripts": {
|
|
26
61
|
"test": "echo No tests yet"
|
|
27
62
|
}
|
package/src/web-channel/index.ts
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import { Devtools,
|
|
1
|
+
import { Devtools, UnknownError } from '@livestore/common'
|
|
2
2
|
import { LS_DEV } from '@livestore/utils'
|
|
3
3
|
import type { Scope, Worker } from '@livestore/utils/effect'
|
|
4
4
|
import { Deferred, Effect, Schema, Stream, WebChannel } from '@livestore/utils/effect'
|
|
5
|
+
import { WebChannelBrowser } from '@livestore/utils/effect/browser'
|
|
5
6
|
import type { MeshNode } from '@livestore/webmesh'
|
|
6
7
|
import { WebmeshSchema } from '@livestore/webmesh'
|
|
7
8
|
|
|
@@ -15,9 +16,9 @@ declare global {
|
|
|
15
16
|
|
|
16
17
|
export const makeSessionInfoBroadcastChannel: Effect.Effect<
|
|
17
18
|
WebChannel.WebChannel<Devtools.SessionInfo.Message, Devtools.SessionInfo.Message>,
|
|
18
|
-
|
|
19
|
+
UnknownError,
|
|
19
20
|
Scope.Scope
|
|
20
|
-
> =
|
|
21
|
+
> = WebChannelBrowser.broadcastChannel({
|
|
21
22
|
channelName: 'session-info',
|
|
22
23
|
schema: Devtools.SessionInfo.Message,
|
|
23
24
|
})
|
|
@@ -45,7 +46,7 @@ export const ClientSessionContentscriptMainRes = Schema.TaggedStruct('ClientSess
|
|
|
45
46
|
// Effect.suspend is needed since `window` is not available in the shared worker
|
|
46
47
|
export const makeStaticClientSessionChannel = {
|
|
47
48
|
contentscriptMain: Effect.suspend(() =>
|
|
48
|
-
|
|
49
|
+
WebChannelBrowser.windowChannel({
|
|
49
50
|
listenWindow: window,
|
|
50
51
|
|
|
51
52
|
sendWindow: window,
|
|
@@ -54,7 +55,7 @@ export const makeStaticClientSessionChannel = {
|
|
|
54
55
|
}),
|
|
55
56
|
),
|
|
56
57
|
clientSession: Effect.suspend(() =>
|
|
57
|
-
|
|
58
|
+
WebChannelBrowser.windowChannel({
|
|
58
59
|
listenWindow: window,
|
|
59
60
|
|
|
60
61
|
sendWindow: window,
|
|
@@ -76,9 +77,9 @@ export const connectViaWorker = ({
|
|
|
76
77
|
Effect.gen(function* () {
|
|
77
78
|
const mc = new MessageChannel()
|
|
78
79
|
|
|
79
|
-
const isConnected = yield* Deferred.make<boolean
|
|
80
|
+
const isConnected = yield* Deferred.make<boolean>()
|
|
80
81
|
|
|
81
|
-
if (LS_DEV) {
|
|
82
|
+
if (LS_DEV === true) {
|
|
82
83
|
yield* Effect.addFinalizerLog(
|
|
83
84
|
`@livestore/devtools-web-common: closing message channel ${node.nodeName} → ${target}`,
|
|
84
85
|
)
|
|
@@ -100,7 +101,7 @@ export const connectViaWorker = ({
|
|
|
100
101
|
|
|
101
102
|
yield* node.addEdge({ target, edgeChannel: sharedWorkerConnection, replaceIfExists: true })
|
|
102
103
|
|
|
103
|
-
if (LS_DEV) {
|
|
104
|
+
if (LS_DEV === true) {
|
|
104
105
|
yield* Effect.logDebug(`@livestore/devtools-web-common: initiated connection: ${node.nodeName} → ${target}`)
|
|
105
106
|
}
|
|
106
|
-
}).pipe(
|
|
107
|
+
}).pipe(UnknownError.mapToUnknownError)
|
package/src/worker/mod.ts
CHANGED
|
@@ -30,7 +30,7 @@ export const CreateConnection = ({ from, port }: typeof SharedWorkerSchema.Creat
|
|
|
30
30
|
|
|
31
31
|
yield* node.addEdge({ target: from, edgeChannel: messagePortChannel, replaceIfExists: true })
|
|
32
32
|
|
|
33
|
-
if (LS_DEV) {
|
|
33
|
+
if (LS_DEV === true) {
|
|
34
34
|
yield* Effect.logDebug(`@livestore/devtools-web-common: accepted edge: ${node.nodeName} ← ${from}`)
|
|
35
35
|
}
|
|
36
36
|
|