@symbo.ls/sdk 3.1.1 → 3.2.3
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/README.md +174 -13
- package/dist/cjs/config/environment.js +32 -42
- package/dist/cjs/index.js +31 -24
- package/dist/cjs/services/AIService.js +3 -3
- package/dist/cjs/services/AuthService.js +44 -3
- package/dist/cjs/services/BasedService.js +530 -24
- package/dist/cjs/services/CollabService.js +420 -0
- package/dist/cjs/services/CoreService.js +2295 -0
- package/dist/cjs/services/SocketService.js +207 -59
- package/dist/cjs/services/SymstoryService.js +135 -49
- package/dist/cjs/services/index.js +8 -16
- package/dist/cjs/state/RootStateManager.js +86 -0
- package/dist/cjs/state/rootEventBus.js +65 -0
- package/dist/cjs/utils/CollabClient.js +157 -0
- package/dist/cjs/utils/TokenManager.js +409 -0
- package/dist/cjs/utils/basedQuerys.js +120 -0
- package/dist/cjs/utils/jsonDiff.js +103 -0
- package/dist/cjs/utils/permission.js +4 -4
- package/dist/cjs/utils/services.js +133 -69
- package/dist/cjs/utils/symstoryClient.js +33 -2
- package/dist/esm/config/environment.js +32 -42
- package/dist/esm/index.js +20586 -11525
- package/dist/esm/services/AIService.js +3 -3
- package/dist/esm/services/AuthService.js +48 -7
- package/dist/esm/services/BasedService.js +676 -65
- package/dist/esm/services/CollabService.js +18028 -0
- package/dist/esm/services/CoreService.js +2827 -0
- package/dist/esm/services/SocketService.js +323 -58
- package/dist/esm/services/SymstoryService.js +287 -111
- package/dist/esm/services/index.js +20456 -11470
- package/dist/esm/state/RootStateManager.js +102 -0
- package/dist/esm/state/rootEventBus.js +47 -0
- package/dist/esm/utils/CollabClient.js +17483 -0
- package/dist/esm/utils/TokenManager.js +395 -0
- package/dist/esm/utils/basedQuerys.js +120 -0
- package/dist/esm/utils/jsonDiff.js +6096 -0
- package/dist/esm/utils/permission.js +4 -4
- package/dist/esm/utils/services.js +133 -69
- package/dist/esm/utils/symstoryClient.js +63 -43
- package/dist/esm/utils/validation.js +89 -19
- package/dist/node/config/environment.js +32 -42
- package/dist/node/index.js +37 -28
- package/dist/node/services/AIService.js +3 -3
- package/dist/node/services/AuthService.js +44 -3
- package/dist/node/services/BasedService.js +531 -25
- package/dist/node/services/CollabService.js +401 -0
- package/dist/node/services/CoreService.js +2266 -0
- package/dist/node/services/SocketService.js +197 -59
- package/dist/node/services/SymstoryService.js +135 -49
- package/dist/node/services/index.js +8 -16
- package/dist/node/state/RootStateManager.js +57 -0
- package/dist/node/state/rootEventBus.js +46 -0
- package/dist/node/utils/CollabClient.js +128 -0
- package/dist/node/utils/TokenManager.js +390 -0
- package/dist/node/utils/basedQuerys.js +120 -0
- package/dist/node/utils/jsonDiff.js +74 -0
- package/dist/node/utils/permission.js +4 -4
- package/dist/node/utils/services.js +133 -69
- package/dist/node/utils/symstoryClient.js +33 -2
- package/package.json +23 -14
- package/src/config/environment.js +33 -42
- package/src/index.js +45 -28
- package/src/services/AIService.js +3 -3
- package/src/services/AuthService.js +52 -3
- package/src/services/BasedService.js +603 -23
- package/src/services/CollabService.js +491 -0
- package/src/services/CoreService.js +2548 -0
- package/src/services/SocketService.js +227 -59
- package/src/services/SymstoryService.js +150 -64
- package/src/services/index.js +7 -14
- package/src/state/RootStateManager.js +71 -0
- package/src/state/rootEventBus.js +48 -0
- package/src/utils/CollabClient.js +161 -0
- package/src/utils/TokenManager.js +462 -0
- package/src/utils/basedQuerys.js +123 -0
- package/src/utils/jsonDiff.js +109 -0
- package/src/utils/permission.js +4 -4
- package/src/utils/services.js +144 -69
- package/src/utils/symstoryClient.js +36 -2
- package/dist/cjs/services/SocketIOService.js +0 -309
- package/dist/esm/services/SocketIOService.js +0 -467
- package/dist/node/services/SocketIOService.js +0 -280
- package/src/services/SocketIOService.js +0 -356
|
@@ -17,26 +17,18 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
17
17
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
18
18
|
var services_exports = {};
|
|
19
19
|
__export(services_exports, {
|
|
20
|
-
AIService: () => import_AIService.AIService,
|
|
21
20
|
AuthService: () => import_AuthService.AuthService,
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
SymstoryService: () => import_SymstoryService.SymstoryService,
|
|
25
|
-
createAIService: () => createAIService,
|
|
21
|
+
CollabService: () => import_CollabService.CollabService,
|
|
22
|
+
CoreService: () => import_CoreService.CoreService,
|
|
26
23
|
createAuthService: () => createAuthService,
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
createSymstoryService: () => createSymstoryService
|
|
24
|
+
createCollabService: () => createCollabService,
|
|
25
|
+
createCoreService: () => createCoreService
|
|
30
26
|
});
|
|
31
27
|
module.exports = __toCommonJS(services_exports);
|
|
32
|
-
var import_BasedService = require("./BasedService.js");
|
|
33
|
-
var import_SymstoryService = require("./SymstoryService.js");
|
|
34
28
|
var import_AuthService = require("./AuthService.js");
|
|
35
|
-
var
|
|
36
|
-
var
|
|
29
|
+
var import_CoreService = require("./CoreService.js");
|
|
30
|
+
var import_CollabService = require("./CollabService.js");
|
|
37
31
|
const createService = (ServiceClass, config) => new ServiceClass(config);
|
|
38
|
-
const createBasedService = (config) => createService(import_BasedService.BasedService, config);
|
|
39
|
-
const createSymstoryService = (config) => createService(import_SymstoryService.SymstoryService, config);
|
|
40
32
|
const createAuthService = (config) => createService(import_AuthService.AuthService, config);
|
|
41
|
-
const
|
|
42
|
-
const
|
|
33
|
+
const createCoreService = (config) => createService(import_CoreService.CoreService, config);
|
|
34
|
+
const createCollabService = (config) => createService(import_CollabService.CollabService, config);
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all)
|
|
9
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
+
};
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from))
|
|
14
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
+
}
|
|
17
|
+
return to;
|
|
18
|
+
};
|
|
19
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
20
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
21
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
22
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
23
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
24
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
25
|
+
mod
|
|
26
|
+
));
|
|
27
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
28
|
+
var RootStateManager_exports = {};
|
|
29
|
+
__export(RootStateManager_exports, {
|
|
30
|
+
RootStateManager: () => RootStateManager
|
|
31
|
+
});
|
|
32
|
+
module.exports = __toCommonJS(RootStateManager_exports);
|
|
33
|
+
var utils = __toESM(require("@domql/utils"), 1);
|
|
34
|
+
var import_rootEventBus = require("./rootEventBus.js");
|
|
35
|
+
const { isFunction } = utils.default || utils;
|
|
36
|
+
class RootStateManager {
|
|
37
|
+
constructor(rootState) {
|
|
38
|
+
this._rootState = rootState;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Apply change tuples to the root state using the built-in setPathCollection
|
|
42
|
+
* of Symbo.ls APP state tree.
|
|
43
|
+
*
|
|
44
|
+
* @param {Array} changes – eg. ['update', ['foo'], 'bar']
|
|
45
|
+
* @param {Object} opts – forwarded to setPathCollection
|
|
46
|
+
*/
|
|
47
|
+
applyChanges(changes = [], opts = {}) {
|
|
48
|
+
if (!this._rootState || !isFunction(this._rootState.setPathCollection)) {
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
const result = this._rootState.setPathCollection(changes, {
|
|
52
|
+
preventUpdate: true,
|
|
53
|
+
...opts
|
|
54
|
+
});
|
|
55
|
+
try {
|
|
56
|
+
const changedKeys = /* @__PURE__ */ new Set();
|
|
57
|
+
changes.forEach((tuple) => {
|
|
58
|
+
const [, path = []] = tuple;
|
|
59
|
+
if (!Array.isArray(path) || !path.length) {
|
|
60
|
+
return;
|
|
61
|
+
}
|
|
62
|
+
if (path[0] === "components" && typeof path[1] === "string") {
|
|
63
|
+
changedKeys.add(path[1]);
|
|
64
|
+
}
|
|
65
|
+
if (path[0] === "schema" && path[1] === "components" && typeof path[2] === "string") {
|
|
66
|
+
changedKeys.add(path[2]);
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
if (changedKeys.size) {
|
|
70
|
+
console.log("emit components:changed", [...changedKeys]);
|
|
71
|
+
import_rootEventBus.rootBus.emit("components:changed", [...changedKeys]);
|
|
72
|
+
}
|
|
73
|
+
} catch (err) {
|
|
74
|
+
console.error("[RootStateManager] emit components:changed failed", err);
|
|
75
|
+
}
|
|
76
|
+
return result;
|
|
77
|
+
}
|
|
78
|
+
setVersion(v) {
|
|
79
|
+
if (this._rootState) {
|
|
80
|
+
this._rootState.version = v;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
get root() {
|
|
84
|
+
return this._rootState;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __export = (target, all) => {
|
|
6
|
+
for (var name in all)
|
|
7
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
8
|
+
};
|
|
9
|
+
var __copyProps = (to, from, except, desc) => {
|
|
10
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
11
|
+
for (let key of __getOwnPropNames(from))
|
|
12
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
13
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
14
|
+
}
|
|
15
|
+
return to;
|
|
16
|
+
};
|
|
17
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
18
|
+
var rootEventBus_exports = {};
|
|
19
|
+
__export(rootEventBus_exports, {
|
|
20
|
+
default: () => rootEventBus_default,
|
|
21
|
+
rootBus: () => rootBus
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(rootEventBus_exports);
|
|
24
|
+
const getGlobalBus = () => {
|
|
25
|
+
if (globalThis.__SMBLS_ROOT_BUS__) {
|
|
26
|
+
return globalThis.__SMBLS_ROOT_BUS__;
|
|
27
|
+
}
|
|
28
|
+
const events = {};
|
|
29
|
+
const bus = {
|
|
30
|
+
on(event, handler) {
|
|
31
|
+
(events[event] ||= []).push(handler);
|
|
32
|
+
},
|
|
33
|
+
off(event, handler) {
|
|
34
|
+
const list = events[event];
|
|
35
|
+
if (!list) {
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
const idx = list.indexOf(handler);
|
|
39
|
+
if (idx !== -1) {
|
|
40
|
+
list.splice(idx, 1);
|
|
41
|
+
}
|
|
42
|
+
},
|
|
43
|
+
emit(event, payload) {
|
|
44
|
+
const list = events[event];
|
|
45
|
+
if (!list || !list.length) {
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
list.slice().forEach((fn) => {
|
|
49
|
+
try {
|
|
50
|
+
fn(payload);
|
|
51
|
+
} catch (err) {
|
|
52
|
+
console.error("[rootBus] handler error for", event, err);
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
Object.defineProperty(bus, "_listeners", {
|
|
58
|
+
value: events,
|
|
59
|
+
enumerable: false
|
|
60
|
+
});
|
|
61
|
+
globalThis.__SMBLS_ROOT_BUS__ = bus;
|
|
62
|
+
return bus;
|
|
63
|
+
};
|
|
64
|
+
const rootBus = getGlobalBus();
|
|
65
|
+
var rootEventBus_default = rootBus;
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all)
|
|
9
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
+
};
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from))
|
|
14
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
+
}
|
|
17
|
+
return to;
|
|
18
|
+
};
|
|
19
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
20
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
21
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
22
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
23
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
24
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
25
|
+
mod
|
|
26
|
+
));
|
|
27
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
28
|
+
var CollabClient_exports = {};
|
|
29
|
+
__export(CollabClient_exports, {
|
|
30
|
+
CollabClient: () => CollabClient
|
|
31
|
+
});
|
|
32
|
+
module.exports = __toCommonJS(CollabClient_exports);
|
|
33
|
+
var import_socket = require("socket.io-client");
|
|
34
|
+
var Y = __toESM(require("yjs"), 1);
|
|
35
|
+
var import_y_indexeddb = require("y-indexeddb");
|
|
36
|
+
var import_dexie = __toESM(require("dexie"), 1);
|
|
37
|
+
var import_nanoid = require("nanoid");
|
|
38
|
+
var import_environment = __toESM(require("../config/environment.js"), 1);
|
|
39
|
+
var import_jsonDiff = require("./jsonDiff.js");
|
|
40
|
+
class CollabClient {
|
|
41
|
+
/* public fields */
|
|
42
|
+
socket = null;
|
|
43
|
+
ydoc = null;
|
|
44
|
+
branch = "main";
|
|
45
|
+
live = false;
|
|
46
|
+
projectId = null;
|
|
47
|
+
jwt = null;
|
|
48
|
+
/* private state */
|
|
49
|
+
_buffer = [];
|
|
50
|
+
_flushTimer = null;
|
|
51
|
+
_clientId = (0, import_nanoid.nanoid)();
|
|
52
|
+
_outboxStore = null;
|
|
53
|
+
// Dexie table
|
|
54
|
+
_readyResolve;
|
|
55
|
+
ready = new Promise((res) => this._readyResolve = res);
|
|
56
|
+
constructor({ jwt, projectId, branch = "main", live = false }) {
|
|
57
|
+
Object.assign(this, { jwt, projectId, branch, live });
|
|
58
|
+
this.ydoc = new Y.Doc();
|
|
59
|
+
new import_y_indexeddb.IndexeddbPersistence(`${projectId}:${branch}`, this.ydoc);
|
|
60
|
+
this._outboxStore = createDexieOutbox(`${projectId}:${branch}`);
|
|
61
|
+
this.socket = (0, import_socket.io)(import_environment.default.socketUrl, {
|
|
62
|
+
path: "/collab-socket",
|
|
63
|
+
transports: ["websocket"],
|
|
64
|
+
auth: { token: jwt, projectId, branch, live },
|
|
65
|
+
reconnectionAttempts: Infinity,
|
|
66
|
+
reconnectionDelayMax: 4e3
|
|
67
|
+
});
|
|
68
|
+
this.socket.on("snapshot", this._onSnapshot).on("ops", this._onOps).on("commit", this._onCommit).on("liveMode", (flag) => {
|
|
69
|
+
this.live = flag;
|
|
70
|
+
}).on("connect", this._onConnect).on("error", (e) => console.warn("[collab] socket error", e));
|
|
71
|
+
this._prevJson = this.ydoc.getMap("root").toJSON();
|
|
72
|
+
this.ydoc.on("afterTransaction", (tr) => {
|
|
73
|
+
if (tr.origin === "remote") {
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
const currentJson = this.ydoc.getMap("root").toJSON();
|
|
77
|
+
const ops = (0, import_jsonDiff.diffJson)(this._prevJson, currentJson);
|
|
78
|
+
this._prevJson = currentJson;
|
|
79
|
+
if (!ops.length) {
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
this._queueOps(ops);
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
/* ---------- public helpers ---------- */
|
|
86
|
+
toggleLive(flag) {
|
|
87
|
+
this.socket.emit("toggleLive", Boolean(flag));
|
|
88
|
+
}
|
|
89
|
+
sendCursor(data) {
|
|
90
|
+
this.socket.emit("cursor", data);
|
|
91
|
+
}
|
|
92
|
+
sendPresence(d) {
|
|
93
|
+
this.socket.emit("presence", d);
|
|
94
|
+
}
|
|
95
|
+
/* ---------- private handlers ---------- */
|
|
96
|
+
_onSnapshot = ({
|
|
97
|
+
data
|
|
98
|
+
/* Uint8Array */
|
|
99
|
+
}) => {
|
|
100
|
+
Y.applyUpdate(this.ydoc, Uint8Array.from(data));
|
|
101
|
+
this._prevJson = this.ydoc.getMap("root").toJSON();
|
|
102
|
+
if (typeof this._readyResolve === "function") {
|
|
103
|
+
this._readyResolve();
|
|
104
|
+
this._readyResolve = null;
|
|
105
|
+
}
|
|
106
|
+
};
|
|
107
|
+
_onOps = ({ changes }) => {
|
|
108
|
+
(0, import_jsonDiff.applyOpsToJson)(changes, this.ydoc);
|
|
109
|
+
this._prevJson = this.ydoc.getMap("root").toJSON();
|
|
110
|
+
};
|
|
111
|
+
_onCommit = async ({ version }) => {
|
|
112
|
+
await this._outboxStore.clear();
|
|
113
|
+
console.info("[collab] committed", version);
|
|
114
|
+
};
|
|
115
|
+
_onConnect = async () => {
|
|
116
|
+
if (typeof this._readyResolve === "function") {
|
|
117
|
+
this._readyResolve();
|
|
118
|
+
this._readyResolve = null;
|
|
119
|
+
}
|
|
120
|
+
const queued = await this._outboxStore.toArray();
|
|
121
|
+
if (queued.length) {
|
|
122
|
+
this.socket.emit("ops", {
|
|
123
|
+
changes: queued.flatMap((e) => e.ops),
|
|
124
|
+
ts: Date.now(),
|
|
125
|
+
clientId: this._clientId
|
|
126
|
+
});
|
|
127
|
+
await this._outboxStore.clear();
|
|
128
|
+
}
|
|
129
|
+
};
|
|
130
|
+
/* ---------- buffering & debounce ---------- */
|
|
131
|
+
_queueOps(ops) {
|
|
132
|
+
this._buffer.push(...ops);
|
|
133
|
+
this._outboxStore.put({ id: (0, import_nanoid.nanoid)(), ops });
|
|
134
|
+
if (this.live && this.socket.connected) {
|
|
135
|
+
this._flushNow();
|
|
136
|
+
} else {
|
|
137
|
+
clearTimeout(this._flushTimer);
|
|
138
|
+
this._flushTimer = setTimeout(() => this._flushNow(), 40);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
_flushNow() {
|
|
142
|
+
if (!this._buffer.length || !this.socket.connected) {
|
|
143
|
+
return;
|
|
144
|
+
}
|
|
145
|
+
this.socket.emit("ops", {
|
|
146
|
+
changes: this._buffer,
|
|
147
|
+
ts: Date.now(),
|
|
148
|
+
clientId: this._clientId
|
|
149
|
+
});
|
|
150
|
+
this._buffer.length = 0;
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
function createDexieOutbox(name) {
|
|
154
|
+
const db = new import_dexie.default(`collab-${name}`);
|
|
155
|
+
db.version(1).stores({ outbox: "id, ops" });
|
|
156
|
+
return db.table("outbox");
|
|
157
|
+
}
|