@powerhousedao/connect 1.0.24-dev.0 → 1.1.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/.env +1 -1
- package/dist/assets/{app-DWlDE8AF.css → app-Dtx0nq4m.css} +181 -240
- package/dist/assets/{app-B5yYl0zv.js → app-SJyv410V.js} +33037 -34663
- package/dist/assets/{app-loader-NDVZu4bS.css → app-loader-3ipafc56.css} +228 -238
- package/dist/assets/{app-loader-CmEZOj3m.js → app-loader-BsJCIY3v.js} +417 -735
- package/dist/assets/{ccip-KtRjx9vh.js → ccip-CWiYf37C.js} +8 -6
- package/dist/assets/{content-2lJzkjLx.js → content-DrqtiFBt.js} +456 -1094
- package/dist/assets/{index-BVVRVlZN.js → index-CS0mQFrd.js} +3 -4
- package/dist/assets/{index-BhHOiwFw.js → index-DFoYtrS6.js} +3693 -3516
- package/dist/assets/{index-dSMCpjcQ.js → index-n2OSuQ3g.js} +171 -23
- package/dist/assets/{main.DA6nl4Ov.js → main.BcxEuVs0.js} +12 -3
- package/dist/assets/{style-CdxGKc2g.css → style-0ej1afQi.css} +95 -39
- package/dist/external-packages.js +0 -1
- package/dist/hmr.js +0 -1
- package/dist/index.html +1 -1
- package/dist/service-worker.js +0 -1
- package/dist/vite-envs.sh +1 -1
- package/package.json +20 -21
- package/dist/assets/app-B5yYl0zv.js.map +0 -1
- package/dist/assets/app-loader-CmEZOj3m.js.map +0 -1
- package/dist/assets/browser-D5LEpLBa.js +0 -27224
- package/dist/assets/browser-D5LEpLBa.js.map +0 -1
- package/dist/assets/ccip-KtRjx9vh.js.map +0 -1
- package/dist/assets/content-2lJzkjLx.js.map +0 -1
- package/dist/assets/index-BVVRVlZN.js.map +0 -1
- package/dist/assets/index-BhHOiwFw.js.map +0 -1
- package/dist/assets/index-DZiF5od7.js +0 -208
- package/dist/assets/index-DZiF5od7.js.map +0 -1
- package/dist/assets/index-dSMCpjcQ.js.map +0 -1
- package/dist/assets/main.DA6nl4Ov.js.map +0 -1
- package/dist/assets/reactor-analytics-CF_JKt8H.js +0 -42
- package/dist/assets/reactor-analytics-CF_JKt8H.js.map +0 -1
- package/dist/assets/router-Ch1WZD-6.js +0 -1585
- package/dist/assets/router-Ch1WZD-6.js.map +0 -1
- package/dist/external-packages.js.map +0 -1
- package/dist/hmr.js.map +0 -1
- package/dist/service-worker.js.map +0 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/app-
|
|
1
|
+
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/app-SJyv410V.js","assets/main.BcxEuVs0.js","assets/app-Dtx0nq4m.css"])))=>i.map(i=>d[i]);
|
|
2
2
|
var __defProp = Object.defineProperty;
|
|
3
3
|
var __typeError = (msg) => {
|
|
4
4
|
throw TypeError(msg);
|
|
@@ -11,7 +11,7 @@ var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot
|
|
|
11
11
|
var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
|
|
12
12
|
var __privateMethod = (obj, member, method) => (__accessCheck(obj, member, "access private method"), method);
|
|
13
13
|
var _tags, _levelString, _errorHandler, _ConsoleLogger_instances, levelValue_get, _getDocumentModelModule, _drives, _ReadModeService_instances, parseGraphQLErrors_fn, fetchDrive_fn, _a, _ServiceWorkerManager_instances, handleServiceWorkerMessage_fn, handleServiceWorker_fn;
|
|
14
|
-
import { _ as __vitePreload } from "./main.
|
|
14
|
+
import { _ as __vitePreload } from "./main.BcxEuVs0.js";
|
|
15
15
|
import { jsx, jsxs } from "react/jsx-runtime";
|
|
16
16
|
import { useState, useEffect, Suspense, lazy } from "react";
|
|
17
17
|
function _mergeNamespaces(n, m) {
|
|
@@ -97,51 +97,14 @@ const trimResultingState = (document) => {
|
|
|
97
97
|
});
|
|
98
98
|
return { ...document, operations: { global: global2, local } };
|
|
99
99
|
};
|
|
100
|
-
class CacheStorageManager {
|
|
101
|
-
constructor(cache) {
|
|
102
|
-
__publicField(this, "index", 0);
|
|
103
|
-
__publicField(this, "cache");
|
|
104
|
-
this.cache = cache;
|
|
105
|
-
}
|
|
106
|
-
createStorage() {
|
|
107
|
-
const index = this.index;
|
|
108
|
-
this.index += 1;
|
|
109
|
-
function buildKey(key) {
|
|
110
|
-
return `${index}-${key}`;
|
|
111
|
-
}
|
|
112
|
-
const storage = {
|
|
113
|
-
get: (key) => {
|
|
114
|
-
return this.cache.get(buildKey(key));
|
|
115
|
-
},
|
|
116
|
-
set: (key, value) => {
|
|
117
|
-
this.cache.set(buildKey(key), value);
|
|
118
|
-
return storage;
|
|
119
|
-
},
|
|
120
|
-
delete: (key) => {
|
|
121
|
-
return this.cache.delete(buildKey(key));
|
|
122
|
-
},
|
|
123
|
-
clear: () => {
|
|
124
|
-
this.cache.clear();
|
|
125
|
-
}
|
|
126
|
-
};
|
|
127
|
-
return storage;
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
100
|
class InMemoryCache {
|
|
131
|
-
constructor(
|
|
132
|
-
__publicField(this, "
|
|
133
|
-
__publicField(this, "
|
|
134
|
-
__publicField(this, "
|
|
135
|
-
__publicField(this, "idToDrive");
|
|
136
|
-
__publicField(this, "slugToDriveId");
|
|
137
|
-
this.cache = cache;
|
|
138
|
-
this.cacheStorageManager = new CacheStorageManager(cache);
|
|
139
|
-
this.idToDocument = this.cacheStorageManager.createStorage();
|
|
140
|
-
this.idToDrive = this.cacheStorageManager.createStorage();
|
|
141
|
-
this.slugToDriveId = this.cacheStorageManager.createStorage();
|
|
101
|
+
constructor() {
|
|
102
|
+
__publicField(this, "idTodocument", /* @__PURE__ */ new Map());
|
|
103
|
+
__publicField(this, "idToDrive", /* @__PURE__ */ new Map());
|
|
104
|
+
__publicField(this, "slugToDriveId", /* @__PURE__ */ new Map());
|
|
142
105
|
}
|
|
143
106
|
clear() {
|
|
144
|
-
this.
|
|
107
|
+
this.idTodocument.clear();
|
|
145
108
|
this.idToDrive.clear();
|
|
146
109
|
this.slugToDriveId.clear();
|
|
147
110
|
}
|
|
@@ -150,13 +113,13 @@ class InMemoryCache {
|
|
|
150
113
|
/////////////////////////////////////////////////////////////////////////////
|
|
151
114
|
async setDocument(documentId, document) {
|
|
152
115
|
const doc = trimResultingState(document);
|
|
153
|
-
this.
|
|
116
|
+
this.idTodocument.set(documentId, doc);
|
|
154
117
|
}
|
|
155
118
|
async getDocument(documentId) {
|
|
156
|
-
return this.
|
|
119
|
+
return this.idTodocument.get(documentId);
|
|
157
120
|
}
|
|
158
121
|
async deleteDocument(documentId) {
|
|
159
|
-
return this.
|
|
122
|
+
return this.idTodocument.delete(documentId);
|
|
160
123
|
}
|
|
161
124
|
async setDrive(driveId, drive) {
|
|
162
125
|
const doc = trimResultingState(drive);
|
|
@@ -170,14 +133,14 @@ class InMemoryCache {
|
|
|
170
133
|
if (!drive) {
|
|
171
134
|
return false;
|
|
172
135
|
}
|
|
173
|
-
const slug = drive.
|
|
136
|
+
const slug = drive.state.global.slug;
|
|
174
137
|
if (slug) {
|
|
175
138
|
this.slugToDriveId.delete(slug);
|
|
176
139
|
}
|
|
177
140
|
return this.idToDrive.delete(driveId);
|
|
178
141
|
}
|
|
179
142
|
async setDriveBySlug(slug, drive) {
|
|
180
|
-
const driveId = drive.id;
|
|
143
|
+
const driveId = drive.state.global.id;
|
|
181
144
|
this.slugToDriveId.set(slug, driveId);
|
|
182
145
|
this.setDrive(driveId, drive);
|
|
183
146
|
}
|
|
@@ -425,8 +388,8 @@ function isBE() {
|
|
|
425
388
|
return buf[0] === 254;
|
|
426
389
|
}
|
|
427
390
|
const FileSystemError = new Error("File system not available.");
|
|
428
|
-
function generateUUID() {
|
|
429
|
-
if (
|
|
391
|
+
function generateUUID$1() {
|
|
392
|
+
if (!crypto.randomUUID) {
|
|
430
393
|
throw new Error("generateUUID is not available in unsecure contexts.");
|
|
431
394
|
}
|
|
432
395
|
return crypto.randomUUID();
|
|
@@ -6814,7 +6777,7 @@ function loadStateOperation(oldDocument, newDocument) {
|
|
|
6814
6777
|
};
|
|
6815
6778
|
}
|
|
6816
6779
|
function generateId(method) {
|
|
6817
|
-
return generateUUID();
|
|
6780
|
+
return generateUUID$1();
|
|
6818
6781
|
}
|
|
6819
6782
|
function getUnixTimestamp(date) {
|
|
6820
6783
|
return (new Date(date).getTime() / 1e3).toFixed(0);
|
|
@@ -6977,7 +6940,6 @@ function processSkipOperation(document, action, customReducer, skipValue, reuseO
|
|
|
6977
6940
|
scopeState = resultingStateParser(lastRemainingOperation.resultingState);
|
|
6978
6941
|
} else {
|
|
6979
6942
|
const { state } = replayOperations(document.initialState, documentOperations, customReducer, void 0, void 0, void 0, void 0, {
|
|
6980
|
-
reuseHash: true,
|
|
6981
6943
|
reuseOperationResultingState,
|
|
6982
6944
|
operationResultingStateParser: resultingStateParser
|
|
6983
6945
|
});
|
|
@@ -7004,7 +6966,6 @@ function processUndoOperation(document, scope, customReducer, reuseOperationResu
|
|
|
7004
6966
|
const clearedOperations = [...documentOperations[scope]];
|
|
7005
6967
|
const diff = diffOperations(garbageCollect(sortedOperations), clearedOperations);
|
|
7006
6968
|
const doc = replayOperations(document.initialState, documentOperations, customReducer, void 0, void 0, void 0, void 0, {
|
|
7007
|
-
reuseHash: true,
|
|
7008
6969
|
reuseOperationResultingState,
|
|
7009
6970
|
operationResultingStateParser: resultingStateParser
|
|
7010
6971
|
});
|
|
@@ -7154,7 +7115,6 @@ function createReducer(stateReducer2, documentReducer = baseReducer) {
|
|
|
7154
7115
|
return reducer2;
|
|
7155
7116
|
}
|
|
7156
7117
|
function baseCreateExtendedState(initialState, createState2) {
|
|
7157
|
-
const id = (initialState == null ? void 0 : initialState.id) ?? generateUUID();
|
|
7158
7118
|
return {
|
|
7159
7119
|
name: "",
|
|
7160
7120
|
documentType: "",
|
|
@@ -7166,8 +7126,6 @@ function baseCreateExtendedState(initialState, createState2) {
|
|
|
7166
7126
|
lastModified: (/* @__PURE__ */ new Date()).toISOString(),
|
|
7167
7127
|
attachments: {},
|
|
7168
7128
|
...initialState,
|
|
7169
|
-
id,
|
|
7170
|
-
slug: (initialState == null ? void 0 : initialState.slug) ?? id,
|
|
7171
7129
|
state: (createState2 == null ? void 0 : createState2(initialState == null ? void 0 : initialState.state)) ?? ((initialState == null ? void 0 : initialState.state) ?? {
|
|
7172
7130
|
global: {},
|
|
7173
7131
|
local: {}
|
|
@@ -7186,6 +7144,10 @@ function baseCreateDocument(initialState, createState2) {
|
|
|
7186
7144
|
function hashDocumentStateForScope(document, scope = "global") {
|
|
7187
7145
|
return hash(cjsModule(document.state[scope] || ""));
|
|
7188
7146
|
}
|
|
7147
|
+
const hashKey = (date, randomLimit = 1e3) => {
|
|
7148
|
+
const random = Math.random() * randomLimit;
|
|
7149
|
+
return hash(`${(/* @__PURE__ */ new Date()).toISOString()}${random}`);
|
|
7150
|
+
};
|
|
7189
7151
|
function getDocumentLastModified(document) {
|
|
7190
7152
|
var _a2;
|
|
7191
7153
|
const sortedOperations = sortOperations(Object.values(document.operations).flat());
|
|
@@ -7234,9 +7196,6 @@ function replayDocument(initialState, operations, reducer2, dispatch, header, sk
|
|
|
7234
7196
|
operationsToReplay.push(...Object.values(operations).flat());
|
|
7235
7197
|
}
|
|
7236
7198
|
const document = baseCreateDocument(documentState);
|
|
7237
|
-
if (header == null ? void 0 : header.slug) {
|
|
7238
|
-
document.slug = header.slug;
|
|
7239
|
-
}
|
|
7240
7199
|
document.initialState = initialState;
|
|
7241
7200
|
document.operations = initialOperations;
|
|
7242
7201
|
let result = document;
|
|
@@ -7575,186 +7534,21 @@ function UpdateStateExampleInputSchema() {
|
|
|
7575
7534
|
newExample: z.string()
|
|
7576
7535
|
});
|
|
7577
7536
|
}
|
|
7578
|
-
var dist = {};
|
|
7579
|
-
var hasRequiredDist;
|
|
7580
|
-
function requireDist() {
|
|
7581
|
-
if (hasRequiredDist) return dist;
|
|
7582
|
-
hasRequiredDist = 1;
|
|
7583
|
-
(function(exports) {
|
|
7584
|
-
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
|
|
7585
|
-
function getDefaultExportFromCjs2(x) {
|
|
7586
|
-
return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, "default") ? x["default"] : x;
|
|
7587
|
-
}
|
|
7588
|
-
var browser = { exports: {} };
|
|
7589
|
-
var process2 = browser.exports = {};
|
|
7590
|
-
var cachedSetTimeout;
|
|
7591
|
-
var cachedClearTimeout;
|
|
7592
|
-
function defaultSetTimout() {
|
|
7593
|
-
throw new Error("setTimeout has not been defined");
|
|
7594
|
-
}
|
|
7595
|
-
function defaultClearTimeout() {
|
|
7596
|
-
throw new Error("clearTimeout has not been defined");
|
|
7597
|
-
}
|
|
7598
|
-
(function() {
|
|
7599
|
-
try {
|
|
7600
|
-
if (typeof setTimeout === "function") {
|
|
7601
|
-
cachedSetTimeout = setTimeout;
|
|
7602
|
-
} else {
|
|
7603
|
-
cachedSetTimeout = defaultSetTimout;
|
|
7604
|
-
}
|
|
7605
|
-
} catch (e) {
|
|
7606
|
-
cachedSetTimeout = defaultSetTimout;
|
|
7607
|
-
}
|
|
7608
|
-
try {
|
|
7609
|
-
if (typeof clearTimeout === "function") {
|
|
7610
|
-
cachedClearTimeout = clearTimeout;
|
|
7611
|
-
} else {
|
|
7612
|
-
cachedClearTimeout = defaultClearTimeout;
|
|
7613
|
-
}
|
|
7614
|
-
} catch (e) {
|
|
7615
|
-
cachedClearTimeout = defaultClearTimeout;
|
|
7616
|
-
}
|
|
7617
|
-
})();
|
|
7618
|
-
function runTimeout(fun) {
|
|
7619
|
-
if (cachedSetTimeout === setTimeout) {
|
|
7620
|
-
return setTimeout(fun, 0);
|
|
7621
|
-
}
|
|
7622
|
-
if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {
|
|
7623
|
-
cachedSetTimeout = setTimeout;
|
|
7624
|
-
return setTimeout(fun, 0);
|
|
7625
|
-
}
|
|
7626
|
-
try {
|
|
7627
|
-
return cachedSetTimeout(fun, 0);
|
|
7628
|
-
} catch (e) {
|
|
7629
|
-
try {
|
|
7630
|
-
return cachedSetTimeout.call(null, fun, 0);
|
|
7631
|
-
} catch (e2) {
|
|
7632
|
-
return cachedSetTimeout.call(this, fun, 0);
|
|
7633
|
-
}
|
|
7634
|
-
}
|
|
7635
|
-
}
|
|
7636
|
-
function runClearTimeout(marker) {
|
|
7637
|
-
if (cachedClearTimeout === clearTimeout) {
|
|
7638
|
-
return clearTimeout(marker);
|
|
7639
|
-
}
|
|
7640
|
-
if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {
|
|
7641
|
-
cachedClearTimeout = clearTimeout;
|
|
7642
|
-
return clearTimeout(marker);
|
|
7643
|
-
}
|
|
7644
|
-
try {
|
|
7645
|
-
return cachedClearTimeout(marker);
|
|
7646
|
-
} catch (e) {
|
|
7647
|
-
try {
|
|
7648
|
-
return cachedClearTimeout.call(null, marker);
|
|
7649
|
-
} catch (e2) {
|
|
7650
|
-
return cachedClearTimeout.call(this, marker);
|
|
7651
|
-
}
|
|
7652
|
-
}
|
|
7653
|
-
}
|
|
7654
|
-
var queue = [];
|
|
7655
|
-
var draining = false;
|
|
7656
|
-
var currentQueue;
|
|
7657
|
-
var queueIndex = -1;
|
|
7658
|
-
function cleanUpNextTick() {
|
|
7659
|
-
if (!draining || !currentQueue) {
|
|
7660
|
-
return;
|
|
7661
|
-
}
|
|
7662
|
-
draining = false;
|
|
7663
|
-
if (currentQueue.length) {
|
|
7664
|
-
queue = currentQueue.concat(queue);
|
|
7665
|
-
} else {
|
|
7666
|
-
queueIndex = -1;
|
|
7667
|
-
}
|
|
7668
|
-
if (queue.length) {
|
|
7669
|
-
drainQueue();
|
|
7670
|
-
}
|
|
7671
|
-
}
|
|
7672
|
-
function drainQueue() {
|
|
7673
|
-
if (draining) {
|
|
7674
|
-
return;
|
|
7675
|
-
}
|
|
7676
|
-
var timeout = runTimeout(cleanUpNextTick);
|
|
7677
|
-
draining = true;
|
|
7678
|
-
var len = queue.length;
|
|
7679
|
-
while (len) {
|
|
7680
|
-
currentQueue = queue;
|
|
7681
|
-
queue = [];
|
|
7682
|
-
while (++queueIndex < len) {
|
|
7683
|
-
if (currentQueue) {
|
|
7684
|
-
currentQueue[queueIndex].run();
|
|
7685
|
-
}
|
|
7686
|
-
}
|
|
7687
|
-
queueIndex = -1;
|
|
7688
|
-
len = queue.length;
|
|
7689
|
-
}
|
|
7690
|
-
currentQueue = null;
|
|
7691
|
-
draining = false;
|
|
7692
|
-
runClearTimeout(timeout);
|
|
7693
|
-
}
|
|
7694
|
-
process2.nextTick = function(fun) {
|
|
7695
|
-
var args = new Array(arguments.length - 1);
|
|
7696
|
-
if (arguments.length > 1) {
|
|
7697
|
-
for (var i = 1; i < arguments.length; i++) {
|
|
7698
|
-
args[i - 1] = arguments[i];
|
|
7699
|
-
}
|
|
7700
|
-
}
|
|
7701
|
-
queue.push(new Item(fun, args));
|
|
7702
|
-
if (queue.length === 1 && !draining) {
|
|
7703
|
-
runTimeout(drainQueue);
|
|
7704
|
-
}
|
|
7705
|
-
};
|
|
7706
|
-
function Item(fun, array) {
|
|
7707
|
-
this.fun = fun;
|
|
7708
|
-
this.array = array;
|
|
7709
|
-
}
|
|
7710
|
-
Item.prototype.run = function() {
|
|
7711
|
-
this.fun.apply(null, this.array);
|
|
7712
|
-
};
|
|
7713
|
-
process2.title = "browser";
|
|
7714
|
-
process2.browser = true;
|
|
7715
|
-
process2.env = {};
|
|
7716
|
-
process2.argv = [];
|
|
7717
|
-
process2.version = "";
|
|
7718
|
-
process2.versions = {};
|
|
7719
|
-
function noop2() {
|
|
7720
|
-
}
|
|
7721
|
-
process2.on = noop2;
|
|
7722
|
-
process2.addListener = noop2;
|
|
7723
|
-
process2.once = noop2;
|
|
7724
|
-
process2.off = noop2;
|
|
7725
|
-
process2.removeListener = noop2;
|
|
7726
|
-
process2.removeAllListeners = noop2;
|
|
7727
|
-
process2.emit = noop2;
|
|
7728
|
-
process2.prependListener = noop2;
|
|
7729
|
-
process2.prependOnceListener = noop2;
|
|
7730
|
-
process2.listeners = function(name2) {
|
|
7731
|
-
return [];
|
|
7732
|
-
};
|
|
7733
|
-
process2.binding = function(name2) {
|
|
7734
|
-
throw new Error("process.binding is not supported");
|
|
7735
|
-
};
|
|
7736
|
-
process2.cwd = function() {
|
|
7737
|
-
return "/";
|
|
7738
|
-
};
|
|
7739
|
-
process2.chdir = function(dir) {
|
|
7740
|
-
throw new Error("process.chdir is not supported");
|
|
7741
|
-
};
|
|
7742
|
-
process2.umask = function() {
|
|
7743
|
-
return 0;
|
|
7744
|
-
};
|
|
7745
|
-
var browserExports = browser.exports;
|
|
7746
|
-
const process$1 = /* @__PURE__ */ getDefaultExportFromCjs2(browserExports);
|
|
7747
|
-
exports.default = process$1;
|
|
7748
|
-
exports.process = process$1;
|
|
7749
|
-
})(dist);
|
|
7750
|
-
return dist;
|
|
7751
|
-
}
|
|
7752
|
-
var distExports = requireDist();
|
|
7753
|
-
const process = /* @__PURE__ */ getDefaultExportFromCjs(distExports);
|
|
7754
7537
|
function commonjsRequire(path) {
|
|
7755
7538
|
throw new Error('Could not dynamically require "' + path + '". Please configure the dynamicRequireTargets or/and ignoreDynamicRequires option of @rollup/plugin-commonjs appropriately for this require call to work.');
|
|
7756
7539
|
}
|
|
7757
7540
|
var jszip_min = { exports: {} };
|
|
7541
|
+
/*!
|
|
7542
|
+
|
|
7543
|
+
JSZip v3.10.1 - A JavaScript class for generating and reading zip files
|
|
7544
|
+
<http://stuartk.com/jszip>
|
|
7545
|
+
|
|
7546
|
+
(c) 2009-2016 Stuart Knightley <stuart [at] stuartk.com>
|
|
7547
|
+
Dual licenced under the MIT license or GPLv3. See https://raw.github.com/Stuk/jszip/main/LICENSE.markdown.
|
|
7548
|
+
|
|
7549
|
+
JSZip uses the library pako released under the MIT license :
|
|
7550
|
+
https://github.com/nodeca/pako/blob/main/LICENSE
|
|
7551
|
+
*/
|
|
7758
7552
|
var hasRequiredJszip_min;
|
|
7759
7553
|
function requireJszip_min() {
|
|
7760
7554
|
if (hasRequiredJszip_min) return jszip_min.exports;
|
|
@@ -10097,6 +9891,7 @@ const types = {
|
|
|
10097
9891
|
"application/dash+xml": ["mpd"],
|
|
10098
9892
|
"application/dash-patch+xml": ["mpp"],
|
|
10099
9893
|
"application/davmount+xml": ["davmount"],
|
|
9894
|
+
"application/dicom": ["dcm"],
|
|
10100
9895
|
"application/docbook+xml": ["dbk"],
|
|
10101
9896
|
"application/dssc+der": ["dssc"],
|
|
10102
9897
|
"application/dssc+xml": ["xdssc"],
|
|
@@ -10183,7 +9978,14 @@ const types = {
|
|
|
10183
9978
|
"application/oebps-package+xml": ["opf"],
|
|
10184
9979
|
"application/ogg": ["ogx"],
|
|
10185
9980
|
"application/omdoc+xml": ["omdoc"],
|
|
10186
|
-
"application/onenote": [
|
|
9981
|
+
"application/onenote": [
|
|
9982
|
+
"onetoc",
|
|
9983
|
+
"onetoc2",
|
|
9984
|
+
"onetmp",
|
|
9985
|
+
"onepkg",
|
|
9986
|
+
"one",
|
|
9987
|
+
"onea"
|
|
9988
|
+
],
|
|
10187
9989
|
"application/oxps": ["oxps"],
|
|
10188
9990
|
"application/p2p-overlay+xml": ["relo"],
|
|
10189
9991
|
"application/patch-ops-error+xml": ["xer"],
|
|
@@ -10279,6 +10081,7 @@ const types = {
|
|
|
10279
10081
|
"application/yang": ["yang"],
|
|
10280
10082
|
"application/yin+xml": ["yin"],
|
|
10281
10083
|
"application/zip": ["zip"],
|
|
10084
|
+
"application/zip+dotlottie": ["lottie"],
|
|
10282
10085
|
"audio/3gpp": ["*3gpp"],
|
|
10283
10086
|
"audio/aac": ["adts", "aac"],
|
|
10284
10087
|
"audio/adpcm": ["adp"],
|
|
@@ -10287,7 +10090,7 @@ const types = {
|
|
|
10287
10090
|
"audio/midi": ["mid", "midi", "kar", "rmi"],
|
|
10288
10091
|
"audio/mobile-xmf": ["mxmf"],
|
|
10289
10092
|
"audio/mp3": ["*mp3"],
|
|
10290
|
-
"audio/mp4": ["m4a", "mp4a"],
|
|
10093
|
+
"audio/mp4": ["m4a", "mp4a", "m4b"],
|
|
10291
10094
|
"audio/mpeg": ["mpga", "mp2", "mp2a", "mp3", "m2a", "m3a"],
|
|
10292
10095
|
"audio/ogg": ["oga", "ogg", "spx", "opus"],
|
|
10293
10096
|
"audio/s3m": ["s3m"],
|
|
@@ -10319,11 +10122,12 @@ const types = {
|
|
|
10319
10122
|
"image/heif": ["heif"],
|
|
10320
10123
|
"image/heif-sequence": ["heifs"],
|
|
10321
10124
|
"image/hej2k": ["hej2"],
|
|
10322
|
-
"image/hsj2": ["hsj2"],
|
|
10323
10125
|
"image/ief": ["ief"],
|
|
10126
|
+
"image/jaii": ["jaii"],
|
|
10127
|
+
"image/jais": ["jais"],
|
|
10324
10128
|
"image/jls": ["jls"],
|
|
10325
10129
|
"image/jp2": ["jp2", "jpg2"],
|
|
10326
|
-
"image/jpeg": ["
|
|
10130
|
+
"image/jpeg": ["jpg", "jpeg", "jpe"],
|
|
10327
10131
|
"image/jph": ["jph"],
|
|
10328
10132
|
"image/jphc": ["jhc"],
|
|
10329
10133
|
"image/jpm": ["jpm", "jpgm"],
|
|
@@ -10338,6 +10142,7 @@ const types = {
|
|
|
10338
10142
|
"image/jxss": ["jxss"],
|
|
10339
10143
|
"image/ktx": ["ktx"],
|
|
10340
10144
|
"image/ktx2": ["ktx2"],
|
|
10145
|
+
"image/pjpeg": ["jfif"],
|
|
10341
10146
|
"image/png": ["png"],
|
|
10342
10147
|
"image/sgi": ["sgi"],
|
|
10343
10148
|
"image/svg+xml": ["svg", "svgz"],
|
|
@@ -10351,7 +10156,7 @@ const types = {
|
|
|
10351
10156
|
"message/global-delivery-status": ["u8dsn"],
|
|
10352
10157
|
"message/global-disposition-notification": ["u8mdn"],
|
|
10353
10158
|
"message/global-headers": ["u8hdr"],
|
|
10354
|
-
"message/rfc822": ["eml", "mime"],
|
|
10159
|
+
"message/rfc822": ["eml", "mime", "mht", "mhtml"],
|
|
10355
10160
|
"model/3mf": ["3mf"],
|
|
10356
10161
|
"model/gltf+json": ["gltf"],
|
|
10357
10162
|
"model/gltf-binary": ["glb"],
|
|
@@ -10361,6 +10166,7 @@ const types = {
|
|
|
10361
10166
|
"model/mtl": ["mtl"],
|
|
10362
10167
|
"model/obj": ["obj"],
|
|
10363
10168
|
"model/prc": ["prc"],
|
|
10169
|
+
"model/step": ["step", "stp", "stpnc", "p21", "210"],
|
|
10364
10170
|
"model/step+xml": ["stpx"],
|
|
10365
10171
|
"model/step+zip": ["stpz"],
|
|
10366
10172
|
"model/step-xml+zip": ["stpxz"],
|
|
@@ -10466,8 +10272,8 @@ class Mime {
|
|
|
10466
10272
|
getType(path) {
|
|
10467
10273
|
if (typeof path !== "string")
|
|
10468
10274
|
return null;
|
|
10469
|
-
const last = path.replace(/^.*[/\\]
|
|
10470
|
-
const ext = last.replace(
|
|
10275
|
+
const last = path.replace(/^.*[/\\]/s, "").toLowerCase();
|
|
10276
|
+
const ext = last.replace(/^.*\./s, "").toLowerCase();
|
|
10471
10277
|
const hasPath = last.length < path.length;
|
|
10472
10278
|
const hasDot = ext.length < last.length - 1;
|
|
10473
10279
|
if (!hasDot && hasPath)
|
|
@@ -10529,10 +10335,8 @@ function validateOperations(operations) {
|
|
|
10529
10335
|
}
|
|
10530
10336
|
function createZip(document) {
|
|
10531
10337
|
const zip = new JSZip();
|
|
10532
|
-
const {
|
|
10338
|
+
const { name: name2, revision, documentType: documentType2, created, lastModified } = document;
|
|
10533
10339
|
const header = {
|
|
10534
|
-
id,
|
|
10535
|
-
slug,
|
|
10536
10340
|
name: name2,
|
|
10537
10341
|
revision,
|
|
10538
10342
|
documentType: documentType2,
|
|
@@ -10948,60 +10752,40 @@ const reducer$2 = {
|
|
|
10948
10752
|
state.triggers = state.triggers.filter((trigger) => trigger.id !== action.input.triggerId);
|
|
10949
10753
|
}
|
|
10950
10754
|
};
|
|
10951
|
-
|
|
10952
|
-
|
|
10953
|
-
|
|
10954
|
-
__publicField(this, "id");
|
|
10955
|
-
this.id = id;
|
|
10956
|
-
}
|
|
10957
|
-
}
|
|
10958
|
-
class OperationError extends Error {
|
|
10959
|
-
constructor(status, operation, message, cause) {
|
|
10960
|
-
super(message, { cause: cause ?? operation });
|
|
10961
|
-
__publicField(this, "status");
|
|
10962
|
-
__publicField(this, "operation");
|
|
10963
|
-
this.status = status;
|
|
10964
|
-
this.operation = operation;
|
|
10965
|
-
}
|
|
10966
|
-
}
|
|
10967
|
-
class ConflictOperationError extends OperationError {
|
|
10968
|
-
constructor(existingOperation, newOperation) {
|
|
10969
|
-
super("CONFLICT", newOperation, `Conflicting operation on index ${newOperation.index}`, { existingOperation, newOperation });
|
|
10970
|
-
}
|
|
10971
|
-
}
|
|
10972
|
-
class DocumentIdValidationError extends Error {
|
|
10973
|
-
constructor(documentId) {
|
|
10974
|
-
super(`Invalid document id: ${documentId}`);
|
|
10975
|
-
}
|
|
10755
|
+
const byteToHex = [];
|
|
10756
|
+
for (let i = 0; i < 256; ++i) {
|
|
10757
|
+
byteToHex.push((i + 256).toString(16).slice(1));
|
|
10976
10758
|
}
|
|
10977
|
-
|
|
10978
|
-
|
|
10979
|
-
super(`Invalid slug: ${slug}`);
|
|
10980
|
-
}
|
|
10759
|
+
function unsafeStringify(arr, offset = 0) {
|
|
10760
|
+
return (byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + "-" + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + "-" + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + "-" + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + "-" + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]).toLowerCase();
|
|
10981
10761
|
}
|
|
10982
|
-
|
|
10983
|
-
|
|
10984
|
-
|
|
10985
|
-
|
|
10986
|
-
|
|
10762
|
+
let getRandomValues;
|
|
10763
|
+
const rnds8 = new Uint8Array(16);
|
|
10764
|
+
function rng() {
|
|
10765
|
+
if (!getRandomValues) {
|
|
10766
|
+
if (typeof crypto === "undefined" || !crypto.getRandomValues) {
|
|
10767
|
+
throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");
|
|
10768
|
+
}
|
|
10769
|
+
getRandomValues = crypto.getRandomValues.bind(crypto);
|
|
10987
10770
|
}
|
|
10771
|
+
return getRandomValues(rnds8);
|
|
10988
10772
|
}
|
|
10989
|
-
|
|
10990
|
-
|
|
10991
|
-
|
|
10992
|
-
|
|
10993
|
-
|
|
10773
|
+
const randomUUID = typeof crypto !== "undefined" && crypto.randomUUID && crypto.randomUUID.bind(crypto);
|
|
10774
|
+
const native = { randomUUID };
|
|
10775
|
+
function v4(options, buf, offset) {
|
|
10776
|
+
var _a2;
|
|
10777
|
+
if (native.randomUUID && true && !options) {
|
|
10778
|
+
return native.randomUUID();
|
|
10994
10779
|
}
|
|
10995
|
-
}
|
|
10996
|
-
|
|
10997
|
-
|
|
10998
|
-
|
|
10999
|
-
__publicField(this, "syncUnitId");
|
|
11000
|
-
this.syncUnitId = syncUnitId;
|
|
10780
|
+
options = options || {};
|
|
10781
|
+
const rnds = options.random ?? ((_a2 = options.rng) == null ? void 0 : _a2.call(options)) ?? rng();
|
|
10782
|
+
if (rnds.length < 16) {
|
|
10783
|
+
throw new Error("Random bytes length must be >= 16");
|
|
11001
10784
|
}
|
|
10785
|
+
rnds[6] = rnds[6] & 15 | 64;
|
|
10786
|
+
rnds[8] = rnds[8] & 63 | 128;
|
|
10787
|
+
return unsafeStringify(rnds);
|
|
11002
10788
|
}
|
|
11003
|
-
const isValidDocumentId = (id) => id && id.length > 0 && /^[a-zA-Z0-9_-]+$/.test(id);
|
|
11004
|
-
const isValidSlug = (slug) => slug && slug.length > 0 && /^[a-zA-Z0-9_-]+$/.test(slug);
|
|
11005
10789
|
function isFileNode(node) {
|
|
11006
10790
|
return node.kind === "file";
|
|
11007
10791
|
}
|
|
@@ -11065,7 +10849,7 @@ function generateNodesCopy(src, idGenerator, nodes) {
|
|
|
11065
10849
|
function generateSynchronizationUnitId(nodes) {
|
|
11066
10850
|
let syncId = "";
|
|
11067
10851
|
while (!syncId || nodes.find((node) => isFileNode(node) && node.synchronizationUnits.find((unit) => unit.syncId === syncId))) {
|
|
11068
|
-
syncId =
|
|
10852
|
+
syncId = v4();
|
|
11069
10853
|
}
|
|
11070
10854
|
return syncId;
|
|
11071
10855
|
}
|
|
@@ -11143,9 +10927,6 @@ const reducer$1 = {
|
|
|
11143
10927
|
if (state.nodes.find((node) => node.id === action.input.id)) {
|
|
11144
10928
|
throw new Error(`Node with id ${action.input.id} already exists!`);
|
|
11145
10929
|
}
|
|
11146
|
-
if (!isValidDocumentId(action.input.id)) {
|
|
11147
|
-
throw new DocumentIdValidationError(action.input.id);
|
|
11148
|
-
}
|
|
11149
10930
|
const name2 = handleTargetNameCollisions({
|
|
11150
10931
|
nodes: state.nodes,
|
|
11151
10932
|
srcName: action.input.name,
|
|
@@ -11238,9 +11019,6 @@ const reducer$1 = {
|
|
|
11238
11019
|
if (!node) {
|
|
11239
11020
|
throw new Error(`Node with id ${action.input.srcId} not found`);
|
|
11240
11021
|
}
|
|
11241
|
-
if (!isValidDocumentId(action.input.targetId)) {
|
|
11242
|
-
throw new DocumentIdValidationError(action.input.targetId);
|
|
11243
|
-
}
|
|
11244
11022
|
const duplicatedNode = state.nodes.find((node2) => node2.id === action.input.targetId);
|
|
11245
11023
|
if (duplicatedNode) {
|
|
11246
11024
|
throw new Error(`Node with id ${action.input.targetId} already exists`);
|
|
@@ -11252,9 +11030,8 @@ const reducer$1 = {
|
|
|
11252
11030
|
});
|
|
11253
11031
|
const newNode = {
|
|
11254
11032
|
...node,
|
|
11255
|
-
id: action.input.targetId,
|
|
11256
|
-
slug: action.input.targetId,
|
|
11257
11033
|
name: name2,
|
|
11034
|
+
id: action.input.targetId,
|
|
11258
11035
|
parentFolder: action.input.targetParentFolder || null
|
|
11259
11036
|
};
|
|
11260
11037
|
const isFile = isFileNode(newNode);
|
|
@@ -11386,9 +11163,11 @@ const fileExtension = "phdd";
|
|
|
11386
11163
|
const documentType = "powerhouse/document-drive";
|
|
11387
11164
|
const documentModelName = "DocumentDrive";
|
|
11388
11165
|
const initialGlobalState = {
|
|
11166
|
+
id: "",
|
|
11389
11167
|
name: "",
|
|
11390
11168
|
nodes: [],
|
|
11391
|
-
icon: null
|
|
11169
|
+
icon: null,
|
|
11170
|
+
slug: null
|
|
11392
11171
|
};
|
|
11393
11172
|
const initialLocalState = {
|
|
11394
11173
|
listeners: [],
|
|
@@ -11649,7 +11428,8 @@ const driveDocumentModelModule = {
|
|
|
11649
11428
|
actions: { ...creators, ...actions },
|
|
11650
11429
|
utils: { ...documentModelUtils, ...customUtils }
|
|
11651
11430
|
};
|
|
11652
|
-
|
|
11431
|
+
var define_process_env_default = {};
|
|
11432
|
+
const LEVELS = {
|
|
11653
11433
|
verbose: 1,
|
|
11654
11434
|
debug: 2,
|
|
11655
11435
|
info: 3,
|
|
@@ -11657,10 +11437,6 @@ const LogLevels = {
|
|
|
11657
11437
|
error: 5,
|
|
11658
11438
|
silent: 6
|
|
11659
11439
|
};
|
|
11660
|
-
function isLogLevel(value) {
|
|
11661
|
-
return typeof value === "string" && value in LogLevels;
|
|
11662
|
-
}
|
|
11663
|
-
var define_process_env_default = {};
|
|
11664
11440
|
class ConsoleLogger {
|
|
11665
11441
|
constructor(tags, errorHandler2) {
|
|
11666
11442
|
__privateAdd(this, _ConsoleLogger_instances);
|
|
@@ -11680,10 +11456,6 @@ class ConsoleLogger {
|
|
|
11680
11456
|
return __privateGet(this, _levelString);
|
|
11681
11457
|
}
|
|
11682
11458
|
set level(level) {
|
|
11683
|
-
if (level !== "env" && !isLogLevel(level)) {
|
|
11684
|
-
throw new Error(`Invalid log level: ${JSON.stringify(level)}.
|
|
11685
|
-
Must be one of ${Object.keys(LogLevels).concat(["env"]).join(", ")}.`);
|
|
11686
|
-
}
|
|
11687
11459
|
__privateSet(this, _levelString, level);
|
|
11688
11460
|
}
|
|
11689
11461
|
get errorHandler() {
|
|
@@ -11696,31 +11468,31 @@ class ConsoleLogger {
|
|
|
11696
11468
|
return this.debug(...data);
|
|
11697
11469
|
}
|
|
11698
11470
|
verbose(...data) {
|
|
11699
|
-
if (__privateGet(this, _ConsoleLogger_instances, levelValue_get) >
|
|
11471
|
+
if (__privateGet(this, _ConsoleLogger_instances, levelValue_get) > LEVELS.verbose) {
|
|
11700
11472
|
return;
|
|
11701
11473
|
}
|
|
11702
11474
|
return this.debug(...data);
|
|
11703
11475
|
}
|
|
11704
11476
|
debug(...data) {
|
|
11705
|
-
if (__privateGet(this, _ConsoleLogger_instances, levelValue_get) >
|
|
11477
|
+
if (__privateGet(this, _ConsoleLogger_instances, levelValue_get) > LEVELS.debug) {
|
|
11706
11478
|
return;
|
|
11707
11479
|
}
|
|
11708
11480
|
return console.debug(...[...__privateGet(this, _tags), ...data]);
|
|
11709
11481
|
}
|
|
11710
11482
|
info(...data) {
|
|
11711
|
-
if (__privateGet(this, _ConsoleLogger_instances, levelValue_get) >
|
|
11483
|
+
if (__privateGet(this, _ConsoleLogger_instances, levelValue_get) > LEVELS.info) {
|
|
11712
11484
|
return;
|
|
11713
11485
|
}
|
|
11714
11486
|
return console.info(...[...__privateGet(this, _tags), ...data]);
|
|
11715
11487
|
}
|
|
11716
11488
|
warn(...data) {
|
|
11717
|
-
if (__privateGet(this, _ConsoleLogger_instances, levelValue_get) >
|
|
11489
|
+
if (__privateGet(this, _ConsoleLogger_instances, levelValue_get) > LEVELS.warn) {
|
|
11718
11490
|
return;
|
|
11719
11491
|
}
|
|
11720
11492
|
return console.warn(...[...__privateGet(this, _tags), ...data]);
|
|
11721
11493
|
}
|
|
11722
11494
|
error(...data) {
|
|
11723
|
-
if (__privateGet(this, _ConsoleLogger_instances, levelValue_get) >
|
|
11495
|
+
if (__privateGet(this, _ConsoleLogger_instances, levelValue_get) > LEVELS.error) {
|
|
11724
11496
|
return;
|
|
11725
11497
|
}
|
|
11726
11498
|
if (__privateGet(this, _errorHandler)) {
|
|
@@ -11735,16 +11507,16 @@ _errorHandler = new WeakMap();
|
|
|
11735
11507
|
_ConsoleLogger_instances = new WeakSet();
|
|
11736
11508
|
levelValue_get = function() {
|
|
11737
11509
|
if (__privateGet(this, _levelString) === "env") {
|
|
11738
|
-
const envLevel = typeof process !== "undefined"
|
|
11510
|
+
const envLevel = typeof process !== "undefined" ? define_process_env_default.LOG_LEVEL : void 0;
|
|
11739
11511
|
if (!envLevel) {
|
|
11740
|
-
return
|
|
11512
|
+
return LEVELS.debug;
|
|
11741
11513
|
}
|
|
11742
|
-
if (!(envLevel in
|
|
11743
|
-
return
|
|
11514
|
+
if (!(envLevel in LEVELS)) {
|
|
11515
|
+
return LEVELS.debug;
|
|
11744
11516
|
}
|
|
11745
|
-
return
|
|
11517
|
+
return LEVELS[envLevel];
|
|
11746
11518
|
}
|
|
11747
|
-
return
|
|
11519
|
+
return LEVELS[__privateGet(this, _levelString)];
|
|
11748
11520
|
};
|
|
11749
11521
|
const loggerInstance = new ConsoleLogger();
|
|
11750
11522
|
let logLevel = "env";
|
|
@@ -11766,6 +11538,48 @@ const childLogger = (tags) => {
|
|
|
11766
11538
|
logger2.errorHandler = errorHandler;
|
|
11767
11539
|
return logger2;
|
|
11768
11540
|
};
|
|
11541
|
+
class DocumentModelNotFoundError extends Error {
|
|
11542
|
+
constructor(id, cause) {
|
|
11543
|
+
super(`Document model "${id}" not found`, { cause });
|
|
11544
|
+
__publicField(this, "id");
|
|
11545
|
+
this.id = id;
|
|
11546
|
+
}
|
|
11547
|
+
}
|
|
11548
|
+
class OperationError extends Error {
|
|
11549
|
+
constructor(status, operation, message, cause) {
|
|
11550
|
+
super(message, { cause: cause ?? operation });
|
|
11551
|
+
__publicField(this, "status");
|
|
11552
|
+
__publicField(this, "operation");
|
|
11553
|
+
this.status = status;
|
|
11554
|
+
this.operation = operation;
|
|
11555
|
+
}
|
|
11556
|
+
}
|
|
11557
|
+
class ConflictOperationError extends OperationError {
|
|
11558
|
+
constructor(existingOperation, newOperation) {
|
|
11559
|
+
super("CONFLICT", newOperation, `Conflicting operation on index ${newOperation.index}`, { existingOperation, newOperation });
|
|
11560
|
+
}
|
|
11561
|
+
}
|
|
11562
|
+
class DocumentAlreadyExistsError extends Error {
|
|
11563
|
+
constructor(documentId) {
|
|
11564
|
+
super(`Document with id ${documentId} already exists`);
|
|
11565
|
+
__publicField(this, "documentId");
|
|
11566
|
+
this.documentId = documentId;
|
|
11567
|
+
}
|
|
11568
|
+
}
|
|
11569
|
+
class DocumentNotFoundError extends Error {
|
|
11570
|
+
constructor(documentId) {
|
|
11571
|
+
super(`Document with id ${documentId} not found`);
|
|
11572
|
+
__publicField(this, "documentId");
|
|
11573
|
+
this.documentId = documentId;
|
|
11574
|
+
}
|
|
11575
|
+
}
|
|
11576
|
+
class SynchronizationUnitNotFoundError extends Error {
|
|
11577
|
+
constructor(message, syncUnitId) {
|
|
11578
|
+
super(message);
|
|
11579
|
+
__publicField(this, "syncUnitId");
|
|
11580
|
+
this.syncUnitId = syncUnitId;
|
|
11581
|
+
}
|
|
11582
|
+
}
|
|
11769
11583
|
var RunAsap;
|
|
11770
11584
|
(function(RunAsap2) {
|
|
11771
11585
|
RunAsap2.useMessageChannel = (() => {
|
|
@@ -11905,6 +11719,9 @@ function mergeOperations(currentOperations, newOperations) {
|
|
|
11905
11719
|
return { ...acc, [curr.scope]: [...existingOperations, curr] };
|
|
11906
11720
|
}, currentOperations);
|
|
11907
11721
|
}
|
|
11722
|
+
function generateUUID() {
|
|
11723
|
+
return generateId();
|
|
11724
|
+
}
|
|
11908
11725
|
function isBefore(dateA, dateB) {
|
|
11909
11726
|
return new Date(dateA) < new Date(dateB);
|
|
11910
11727
|
}
|
|
@@ -12005,7 +11822,7 @@ class BaseQueueManager {
|
|
|
12005
11822
|
if (!this.delegate) {
|
|
12006
11823
|
throw new Error("No server delegate defined");
|
|
12007
11824
|
}
|
|
12008
|
-
const jobId =
|
|
11825
|
+
const jobId = generateUUID();
|
|
12009
11826
|
const queue = this.getQueue(job.driveId, job.documentId);
|
|
12010
11827
|
if (await queue.isDeleted()) {
|
|
12011
11828
|
throw new Error("Queue is deleted");
|
|
@@ -22344,18 +22161,14 @@ async function fetchDocument(url, documentId, documentModelModule) {
|
|
|
22344
22161
|
local: []
|
|
22345
22162
|
},
|
|
22346
22163
|
attachments: {},
|
|
22347
|
-
initialState: {
|
|
22348
|
-
|
|
22349
|
-
|
|
22350
|
-
|
|
22351
|
-
|
|
22352
|
-
|
|
22353
|
-
|
|
22354
|
-
|
|
22355
|
-
}),
|
|
22356
|
-
id: result.document.id,
|
|
22357
|
-
slug: result.document.slug
|
|
22358
|
-
},
|
|
22164
|
+
initialState: utils.createExtendedState({
|
|
22165
|
+
// TODO: getDocument should return all the initial state fields
|
|
22166
|
+
created: result.document.created,
|
|
22167
|
+
lastModified: result.document.created,
|
|
22168
|
+
state: utils.createState({
|
|
22169
|
+
global: result.document.initialState.state.global
|
|
22170
|
+
})
|
|
22171
|
+
}),
|
|
22359
22172
|
clipboard: []
|
|
22360
22173
|
} : null;
|
|
22361
22174
|
return {
|
|
@@ -22410,13 +22223,7 @@ class ReadModeService {
|
|
|
22410
22223
|
return document;
|
|
22411
22224
|
}
|
|
22412
22225
|
async addReadDrive(url, options) {
|
|
22413
|
-
|
|
22414
|
-
if (options == null ? void 0 : options.expectedDriveInfo) {
|
|
22415
|
-
id = options.expectedDriveInfo.id;
|
|
22416
|
-
} else {
|
|
22417
|
-
const drive = await requestPublicDrive(url);
|
|
22418
|
-
id = drive.id;
|
|
22419
|
-
}
|
|
22226
|
+
const { id } = (options == null ? void 0 : options.expectedDriveInfo) ?? await requestPublicDrive(url);
|
|
22420
22227
|
const result = await __privateMethod(this, _ReadModeService_instances, fetchDrive_fn).call(this, id, url);
|
|
22421
22228
|
if (result instanceof Error) {
|
|
22422
22229
|
throw result;
|
|
@@ -22439,7 +22246,7 @@ class ReadModeService {
|
|
|
22439
22246
|
return Promise.resolve(result ? { ...result.drive, readContext: result.context } : new ReadDriveNotFoundError(id));
|
|
22440
22247
|
}
|
|
22441
22248
|
async getReadDriveBySlug(slug) {
|
|
22442
|
-
const readDrive = [...__privateGet(this, _drives).values()].find(({ drive }) => drive.slug === slug);
|
|
22249
|
+
const readDrive = [...__privateGet(this, _drives).values()].find(({ drive }) => drive.state.global.slug === slug);
|
|
22443
22250
|
return Promise.resolve(readDrive ? { ...readDrive.drive, readContext: readDrive.context } : new ReadDriveSlugNotFoundError(slug));
|
|
22444
22251
|
}
|
|
22445
22252
|
getReadDriveContext(id) {
|
|
@@ -22578,8 +22385,8 @@ class DefaultDrivesManager {
|
|
|
22578
22385
|
}
|
|
22579
22386
|
async preserveDrivesById(driveIdsToPreserve, drives, removeStrategy = "detach") {
|
|
22580
22387
|
const getAllDrives = drives.map((driveId) => this.server.getDrive(driveId));
|
|
22581
|
-
const drivesToRemove = (await Promise.all(getAllDrives)).filter((drive) => drive.state.local.listeners.length > 0 || drive.state.local.triggers.length > 0).filter((drive) => !driveIdsToPreserve.includes(drive.id));
|
|
22582
|
-
const driveIds = drivesToRemove.map((drive) => drive.id);
|
|
22388
|
+
const drivesToRemove = (await Promise.all(getAllDrives)).filter((drive) => drive.state.local.listeners.length > 0 || drive.state.local.triggers.length > 0).filter((drive) => !driveIdsToPreserve.includes(drive.state.global.id));
|
|
22389
|
+
const driveIds = drivesToRemove.map((drive) => drive.state.global.id);
|
|
22583
22390
|
if (removeStrategy === "detach") {
|
|
22584
22391
|
await this.detachDrivesById(driveIds);
|
|
22585
22392
|
} else {
|
|
@@ -22627,7 +22434,7 @@ class DefaultDrivesManager {
|
|
|
22627
22434
|
case "remove-all": {
|
|
22628
22435
|
const getDrives = driveids.map((driveId) => this.server.getDrive(driveId));
|
|
22629
22436
|
const drives = await Promise.all(getDrives);
|
|
22630
|
-
const drivesToRemove = drives.filter((drive) => drive.state.local.listeners.length > 0 || drive.state.local.triggers.length > 0).map((drive) => drive.id);
|
|
22437
|
+
const drivesToRemove = drives.filter((drive) => drive.state.local.listeners.length > 0 || drive.state.local.triggers.length > 0).map((drive) => drive.state.global.id);
|
|
22631
22438
|
await this.removeDrivesById(drivesToRemove);
|
|
22632
22439
|
break;
|
|
22633
22440
|
}
|
|
@@ -22904,7 +22711,7 @@ class PullResponderTransmitter {
|
|
|
22904
22711
|
static async executePull(driveId, trigger, onStrandUpdate, onError, onRevisions, onAcknowledge) {
|
|
22905
22712
|
var _a2, _b;
|
|
22906
22713
|
staticLogger().verbose(`executePull(driveId: ${driveId}), trigger:`, trigger);
|
|
22907
|
-
staticLogger().
|
|
22714
|
+
staticLogger().info(`[SYNC DEBUG] PullResponderTransmitter.executePull starting for drive: ${driveId}, listenerId: ${trigger.data.listenerId}`);
|
|
22908
22715
|
const { url } = trigger.data;
|
|
22909
22716
|
let strands;
|
|
22910
22717
|
let error;
|
|
@@ -23068,7 +22875,7 @@ class PullResponderTransmitter {
|
|
|
23068
22875
|
};
|
|
23069
22876
|
const listenerId = await PullResponderTransmitter.registerPullResponder(driveId, url, filter);
|
|
23070
22877
|
const pullTrigger = {
|
|
23071
|
-
id:
|
|
22878
|
+
id: generateUUID(),
|
|
23072
22879
|
type: "PullResponder",
|
|
23073
22880
|
driveId,
|
|
23074
22881
|
filter,
|
|
@@ -23501,7 +23308,7 @@ class BaseDocumentDriveServer {
|
|
|
23501
23308
|
async _initializeDrive(driveId) {
|
|
23502
23309
|
var _a2, _b, _c;
|
|
23503
23310
|
const drive = await this.getDrive(driveId);
|
|
23504
|
-
this.logger.verbose(`[SYNC DEBUG] Initializing drive ${driveId} with slug "${drive.slug}"`);
|
|
23311
|
+
this.logger.verbose(`[SYNC DEBUG] Initializing drive ${driveId} with slug "${drive.state.global.slug}"`);
|
|
23505
23312
|
await this.synchronizationManager.initializeDriveSyncStatus(driveId, drive);
|
|
23506
23313
|
if (this.shouldSyncRemoteDrive(drive)) {
|
|
23507
23314
|
this.logger.verbose(`[SYNC DEBUG] Starting sync for remote drive ${driveId}`);
|
|
@@ -23515,7 +23322,7 @@ class BaseDocumentDriveServer {
|
|
|
23515
23322
|
this.logger.verbose(`[SYNC DEBUG] Created SwitchboardPush transmitter with URL: ${zodListener.callInfo.data || "none"}`);
|
|
23516
23323
|
await this.listenerManager.setListener(driveId, {
|
|
23517
23324
|
block: zodListener.block,
|
|
23518
|
-
driveId: drive.id,
|
|
23325
|
+
driveId: drive.state.global.id,
|
|
23519
23326
|
filter: {
|
|
23520
23327
|
branch: zodListener.filter.branch ?? [],
|
|
23521
23328
|
documentId: zodListener.filter.documentId ?? [],
|
|
@@ -23577,25 +23384,25 @@ class BaseDocumentDriveServer {
|
|
|
23577
23384
|
return [...this.documentModelModules];
|
|
23578
23385
|
}
|
|
23579
23386
|
async addDrive(input, preferredEditor) {
|
|
23387
|
+
const id = input.global.id || generateUUID();
|
|
23388
|
+
if (!id) {
|
|
23389
|
+
throw new Error("Invalid Drive Id");
|
|
23390
|
+
}
|
|
23391
|
+
const drives = await this.legacyStorage.getDrives();
|
|
23392
|
+
if (drives.includes(id)) {
|
|
23393
|
+
throw new DocumentAlreadyExistsError(id);
|
|
23394
|
+
}
|
|
23580
23395
|
const document = createDocument({
|
|
23581
|
-
|
|
23582
|
-
slug: input.slug,
|
|
23583
|
-
state: {
|
|
23584
|
-
global: {
|
|
23585
|
-
icon: input.global.icon ?? null,
|
|
23586
|
-
name: input.global.name
|
|
23587
|
-
},
|
|
23588
|
-
local: input.local
|
|
23589
|
-
}
|
|
23396
|
+
state: input
|
|
23590
23397
|
});
|
|
23591
23398
|
document.meta = {
|
|
23592
23399
|
preferredEditor
|
|
23593
23400
|
};
|
|
23594
|
-
await this.
|
|
23595
|
-
if (input.
|
|
23596
|
-
await this.cache.deleteDriveBySlug(input.slug);
|
|
23401
|
+
await this.legacyStorage.createDrive(id, document);
|
|
23402
|
+
if (input.global.slug) {
|
|
23403
|
+
await this.cache.deleteDriveBySlug(input.global.slug);
|
|
23597
23404
|
}
|
|
23598
|
-
await this._initializeDrive(
|
|
23405
|
+
await this._initializeDrive(id);
|
|
23599
23406
|
this.eventEmitter.emit("driveAdded", document);
|
|
23600
23407
|
return document;
|
|
23601
23408
|
}
|
|
@@ -23607,11 +23414,11 @@ class BaseDocumentDriveServer {
|
|
|
23607
23414
|
pullInterval
|
|
23608
23415
|
});
|
|
23609
23416
|
return await this.addDrive({
|
|
23610
|
-
id,
|
|
23611
|
-
slug,
|
|
23612
23417
|
global: {
|
|
23418
|
+
id,
|
|
23613
23419
|
name: name2,
|
|
23614
|
-
|
|
23420
|
+
slug,
|
|
23421
|
+
icon: icon ?? null
|
|
23615
23422
|
},
|
|
23616
23423
|
local: {
|
|
23617
23424
|
triggers: [...triggers, pullTrigger],
|
|
@@ -23626,7 +23433,7 @@ class BaseDocumentDriveServer {
|
|
|
23626
23433
|
this.stopSyncRemoteDrive(driveId),
|
|
23627
23434
|
this.listenerManager.removeDrive(driveId),
|
|
23628
23435
|
this.cache.deleteDrive(driveId),
|
|
23629
|
-
this.
|
|
23436
|
+
this.legacyStorage.deleteDrive(driveId)
|
|
23630
23437
|
]);
|
|
23631
23438
|
this.eventEmitter.emit("driveDeleted", driveId);
|
|
23632
23439
|
result.forEach((r) => {
|
|
@@ -23635,16 +23442,8 @@ class BaseDocumentDriveServer {
|
|
|
23635
23442
|
}
|
|
23636
23443
|
});
|
|
23637
23444
|
}
|
|
23638
|
-
|
|
23639
|
-
|
|
23640
|
-
const drives = [];
|
|
23641
|
-
let cursor;
|
|
23642
|
-
do {
|
|
23643
|
-
const { documents, nextCursor } = await this.documentStorage.findByType("powerhouse/document-drive", 100, cursor);
|
|
23644
|
-
drives.push(...documents);
|
|
23645
|
-
cursor = nextCursor;
|
|
23646
|
-
} while (cursor);
|
|
23647
|
-
return drives;
|
|
23445
|
+
getDrives() {
|
|
23446
|
+
return this.legacyStorage.getDrives();
|
|
23648
23447
|
}
|
|
23649
23448
|
async getDrive(driveId, options) {
|
|
23650
23449
|
let document;
|
|
@@ -23718,13 +23517,8 @@ class BaseDocumentDriveServer {
|
|
|
23718
23517
|
state = doc.state;
|
|
23719
23518
|
}
|
|
23720
23519
|
const document = input.document ?? this.getDocumentModelModule(input.documentType).utils.createDocument();
|
|
23721
|
-
if (input.id && input.id.length > 0) {
|
|
23722
|
-
document.id = input.id;
|
|
23723
|
-
}
|
|
23724
23520
|
const documentStorage = {
|
|
23725
|
-
id: document.id,
|
|
23726
23521
|
name: document.name,
|
|
23727
|
-
slug: document.slug,
|
|
23728
23522
|
revision: document.revision,
|
|
23729
23523
|
documentType: document.documentType,
|
|
23730
23524
|
created: document.created,
|
|
@@ -23734,7 +23528,7 @@ class BaseDocumentDriveServer {
|
|
|
23734
23528
|
clipboard: [],
|
|
23735
23529
|
state: state ?? document.state
|
|
23736
23530
|
};
|
|
23737
|
-
await this.documentStorage.create(documentStorage);
|
|
23531
|
+
await this.documentStorage.create(input.id, documentStorage);
|
|
23738
23532
|
try {
|
|
23739
23533
|
await this.documentStorage.addChild(driveId, input.id);
|
|
23740
23534
|
} catch (e) {
|
|
@@ -23873,18 +23667,12 @@ class BaseDocumentDriveServer {
|
|
|
23873
23667
|
handler = () => this.deleteDocument(driveId, signal.input.id);
|
|
23874
23668
|
break;
|
|
23875
23669
|
case "COPY_CHILD_DOCUMENT":
|
|
23876
|
-
handler = () => this.getDocument(driveId, signal.input.id).then((documentToCopy) => {
|
|
23877
|
-
|
|
23878
|
-
|
|
23879
|
-
|
|
23880
|
-
|
|
23881
|
-
|
|
23882
|
-
id: signal.input.newId,
|
|
23883
|
-
documentType: documentToCopy.documentType,
|
|
23884
|
-
document: doc,
|
|
23885
|
-
synchronizationUnits: signal.input.synchronizationUnits
|
|
23886
|
-
});
|
|
23887
|
-
});
|
|
23670
|
+
handler = () => this.getDocument(driveId, signal.input.id).then((documentToCopy) => this.createDocument(driveId, {
|
|
23671
|
+
id: signal.input.newId,
|
|
23672
|
+
documentType: documentToCopy.documentType,
|
|
23673
|
+
document: documentToCopy,
|
|
23674
|
+
synchronizationUnits: signal.input.synchronizationUnits
|
|
23675
|
+
}));
|
|
23888
23676
|
break;
|
|
23889
23677
|
}
|
|
23890
23678
|
if (handler) {
|
|
@@ -24141,6 +23929,13 @@ class BaseDocumentDriveServer {
|
|
|
24141
23929
|
addDriveOperation(driveId, operation, options) {
|
|
24142
23930
|
return this.addDriveOperations(driveId, [operation], options);
|
|
24143
23931
|
}
|
|
23932
|
+
async clearStorage() {
|
|
23933
|
+
var _a2, _b;
|
|
23934
|
+
for (const drive of await this.getDrives()) {
|
|
23935
|
+
await this.deleteDrive(drive);
|
|
23936
|
+
}
|
|
23937
|
+
await ((_b = (_a2 = this.legacyStorage).clearStorage) == null ? void 0 : _b.call(_a2));
|
|
23938
|
+
}
|
|
24144
23939
|
async _addDriveOperations(driveId, callback) {
|
|
24145
23940
|
if (!this.legacyStorage.addDriveOperationsWithTransaction) {
|
|
24146
23941
|
const documentStorage = await this.documentStorage.get(driveId);
|
|
@@ -24415,32 +24210,17 @@ class MemoryStorage {
|
|
|
24415
24210
|
exists(documentId) {
|
|
24416
24211
|
return Promise.resolve(!!this.documents[documentId]);
|
|
24417
24212
|
}
|
|
24418
|
-
|
|
24419
|
-
|
|
24420
|
-
|
|
24421
|
-
throw new DocumentIdValidationError(documentId);
|
|
24422
|
-
}
|
|
24423
|
-
if (this.documents[documentId]) {
|
|
24424
|
-
throw new DocumentAlreadyExistsError(documentId);
|
|
24425
|
-
}
|
|
24426
|
-
const slug = document.slug.length > 0 ? document.slug : documentId;
|
|
24427
|
-
if (!isValidSlug(slug)) {
|
|
24428
|
-
throw new DocumentSlugValidationError(slug);
|
|
24429
|
-
}
|
|
24430
|
-
if (slug && this.slugToDocumentId[slug]) {
|
|
24431
|
-
throw new DocumentAlreadyExistsError(documentId);
|
|
24432
|
-
}
|
|
24433
|
-
document.slug = slug;
|
|
24213
|
+
// TODO: this should throw an error if the document already exists.
|
|
24214
|
+
create(documentId, document) {
|
|
24215
|
+
var _a2;
|
|
24434
24216
|
this.documents[documentId] = document;
|
|
24217
|
+
const slug = (_a2 = document.initialState.state.global) == null ? void 0 : _a2.slug;
|
|
24435
24218
|
if (slug) {
|
|
24436
24219
|
if (this.slugToDocumentId[slug]) {
|
|
24437
|
-
throw new
|
|
24220
|
+
throw new Error(`Document with slug ${slug} already exists`);
|
|
24438
24221
|
}
|
|
24439
24222
|
this.slugToDocumentId[slug] = documentId;
|
|
24440
24223
|
}
|
|
24441
|
-
if (document.documentType === "powerhouse/document-drive") {
|
|
24442
|
-
this.updateDriveManifest(documentId, { documentIds: /* @__PURE__ */ new Set() });
|
|
24443
|
-
}
|
|
24444
24224
|
return Promise.resolve();
|
|
24445
24225
|
}
|
|
24446
24226
|
get(documentId) {
|
|
@@ -24457,56 +24237,20 @@ class MemoryStorage {
|
|
|
24457
24237
|
}
|
|
24458
24238
|
return this.get(documentId);
|
|
24459
24239
|
}
|
|
24460
|
-
async findByType(documentModelType, limit = 100, cursor) {
|
|
24461
|
-
const documentsAndIds = Object.entries(this.documents).filter(([_, doc]) => doc.documentType === documentModelType).map(([id, doc]) => ({
|
|
24462
|
-
id,
|
|
24463
|
-
document: doc
|
|
24464
|
-
}));
|
|
24465
|
-
documentsAndIds.sort((a, b) => {
|
|
24466
|
-
const aDate = new Date(a.document.created);
|
|
24467
|
-
const bDate = new Date(b.document.created);
|
|
24468
|
-
if (aDate.getTime() === bDate.getTime()) {
|
|
24469
|
-
const aId = a.id;
|
|
24470
|
-
const bId = b.id;
|
|
24471
|
-
return aId.localeCompare(bId);
|
|
24472
|
-
}
|
|
24473
|
-
return aDate.getTime() - bDate.getTime();
|
|
24474
|
-
});
|
|
24475
|
-
let startIndex = 0;
|
|
24476
|
-
if (cursor) {
|
|
24477
|
-
const index = documentsAndIds.findIndex(({ id }) => id === cursor);
|
|
24478
|
-
if (index !== -1) {
|
|
24479
|
-
startIndex = index;
|
|
24480
|
-
}
|
|
24481
|
-
}
|
|
24482
|
-
const endIndex = Math.min(startIndex + limit, documentsAndIds.length);
|
|
24483
|
-
let nextCursor;
|
|
24484
|
-
if (endIndex < documentsAndIds.length) {
|
|
24485
|
-
nextCursor = documentsAndIds[endIndex].id;
|
|
24486
|
-
}
|
|
24487
|
-
return {
|
|
24488
|
-
documents: documentsAndIds.slice(startIndex, endIndex).map(({ id }) => id),
|
|
24489
|
-
nextCursor
|
|
24490
|
-
};
|
|
24491
|
-
}
|
|
24492
24240
|
async delete(documentId) {
|
|
24241
|
+
var _a2;
|
|
24493
24242
|
const document = this.documents[documentId];
|
|
24494
24243
|
if (document) {
|
|
24495
|
-
const slug = document.
|
|
24244
|
+
const slug = (_a2 = document.initialState.state.global) == null ? void 0 : _a2.slug;
|
|
24496
24245
|
if (slug && this.slugToDocumentId[slug] === documentId) {
|
|
24497
24246
|
delete this.slugToDocumentId[slug];
|
|
24498
24247
|
}
|
|
24499
24248
|
}
|
|
24500
|
-
const
|
|
24501
|
-
for (const
|
|
24502
|
-
|
|
24503
|
-
|
|
24504
|
-
|
|
24505
|
-
for (const child of children) {
|
|
24506
|
-
const childParents = await this.getParents(child);
|
|
24507
|
-
if (childParents.length === 1) {
|
|
24508
|
-
await this.delete(child);
|
|
24509
|
-
}
|
|
24249
|
+
const drives = await this.getDrives();
|
|
24250
|
+
for (const driveId of drives) {
|
|
24251
|
+
if (driveId === documentId)
|
|
24252
|
+
continue;
|
|
24253
|
+
await this.removeChild(driveId, documentId);
|
|
24510
24254
|
}
|
|
24511
24255
|
delete this.driveManifests[documentId];
|
|
24512
24256
|
if (this.documents[documentId]) {
|
|
@@ -24540,26 +24284,14 @@ class MemoryStorage {
|
|
|
24540
24284
|
const manifest = this.getManifest(parentId);
|
|
24541
24285
|
return [...manifest.documentIds];
|
|
24542
24286
|
}
|
|
24543
|
-
async getParents(childId) {
|
|
24544
|
-
const parents = [];
|
|
24545
|
-
for (const [driveId, manifest] of Object.entries(this.driveManifests)) {
|
|
24546
|
-
if (manifest.documentIds.has(childId)) {
|
|
24547
|
-
parents.push(driveId);
|
|
24548
|
-
}
|
|
24549
|
-
}
|
|
24550
|
-
return parents;
|
|
24551
|
-
}
|
|
24552
24287
|
////////////////////////////////
|
|
24553
|
-
//
|
|
24288
|
+
// IDriveStorage
|
|
24554
24289
|
////////////////////////////////
|
|
24555
|
-
async
|
|
24290
|
+
async clearStorage() {
|
|
24556
24291
|
this.documents = {};
|
|
24557
24292
|
this.driveManifests = {};
|
|
24558
24293
|
this.slugToDocumentId = {};
|
|
24559
24294
|
}
|
|
24560
|
-
////////////////////////////////
|
|
24561
|
-
// IDriveStorage
|
|
24562
|
-
////////////////////////////////
|
|
24563
24295
|
async addDocumentOperations(drive, id, operations, header) {
|
|
24564
24296
|
const document = await this.get(id);
|
|
24565
24297
|
if (!document) {
|
|
@@ -24572,6 +24304,13 @@ class MemoryStorage {
|
|
|
24572
24304
|
operations: mergedOperations
|
|
24573
24305
|
};
|
|
24574
24306
|
}
|
|
24307
|
+
async getDrives() {
|
|
24308
|
+
return Object.keys(this.driveManifests);
|
|
24309
|
+
}
|
|
24310
|
+
async createDrive(id, drive) {
|
|
24311
|
+
await this.create(id, drive);
|
|
24312
|
+
this.updateDriveManifest(id, { documentIds: /* @__PURE__ */ new Set() });
|
|
24313
|
+
}
|
|
24575
24314
|
async addDriveOperations(id, operations, header) {
|
|
24576
24315
|
const drive = await this.get(id);
|
|
24577
24316
|
const mergedOperations = mergeOperations(drive.operations, operations);
|
|
@@ -24581,6 +24320,31 @@ class MemoryStorage {
|
|
|
24581
24320
|
operations: mergedOperations
|
|
24582
24321
|
};
|
|
24583
24322
|
}
|
|
24323
|
+
async deleteDrive(id) {
|
|
24324
|
+
const manifest = this.getManifest(id);
|
|
24325
|
+
const drives = await this.getDrives();
|
|
24326
|
+
await Promise.all([...manifest.documentIds].map((docId) => {
|
|
24327
|
+
var _a2;
|
|
24328
|
+
for (const driveId of drives) {
|
|
24329
|
+
if (driveId === id) {
|
|
24330
|
+
continue;
|
|
24331
|
+
}
|
|
24332
|
+
const manifest2 = this.getManifest(driveId);
|
|
24333
|
+
if (manifest2.documentIds.has(docId)) {
|
|
24334
|
+
return;
|
|
24335
|
+
}
|
|
24336
|
+
}
|
|
24337
|
+
const document = this.documents[docId];
|
|
24338
|
+
if (document) {
|
|
24339
|
+
const slug = (_a2 = document.initialState.state.global) == null ? void 0 : _a2.slug;
|
|
24340
|
+
if (slug && this.slugToDocumentId[slug] === docId) {
|
|
24341
|
+
delete this.slugToDocumentId[slug];
|
|
24342
|
+
}
|
|
24343
|
+
}
|
|
24344
|
+
delete this.documents[docId];
|
|
24345
|
+
}));
|
|
24346
|
+
await this.delete(id);
|
|
24347
|
+
}
|
|
24584
24348
|
async getSynchronizationUnitsRevision(units) {
|
|
24585
24349
|
const results = await Promise.allSettled(units.map(async (unit) => {
|
|
24586
24350
|
try {
|
|
@@ -25783,9 +25547,6 @@ function Syncing(props) {
|
|
|
25783
25547
|
function Tabler(props) {
|
|
25784
25548
|
return jsxs("svg", { ...props, width: "18", height: "18", viewBox: "0 0 18 18", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: [jsx("path", { d: "M4.5 9V7.5C4.5 6.30653 4.97411 5.16193 5.81802 4.31802C6.66193 3.47411 7.80653 3 9 3C10.1935 3 11.3381 3.47411 12.182 4.31802C13.0259 5.16193 13.5 6.30653 13.5 7.5V9M3 13.5C3 13.8978 3.15804 14.2794 3.43934 14.5607C3.72064 14.842 4.10218 15 4.5 15C4.89782 15 5.27936 14.842 5.56066 14.5607C5.84196 14.2794 6 13.8978 6 13.5C6 13.1022 5.84196 12.7206 5.56066 12.4393C5.27936 12.158 4.89782 12 4.5 12C4.10218 12 3.72064 12.158 3.43934 12.4393C3.15804 12.7206 3 13.1022 3 13.5ZM12 13.5C12 13.8978 12.158 14.2794 12.4393 14.5607C12.7206 14.842 13.1022 15 13.5 15C13.8978 15 14.2794 14.842 14.5607 14.5607C14.842 14.2794 15 13.8978 15 13.5C15 13.1022 14.842 12.7206 14.5607 12.4393C14.2794 12.158 13.8978 12 13.5 12C13.1022 12 12.7206 12.158 12.4393 12.4393C12.158 12.7206 12 13.1022 12 13.5Z", stroke: "currentcolor", strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round" }), jsx("path", { d: "M11.25 6.75L13.5 9L15.75 6.75", stroke: "currentcolor", strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round" })] });
|
|
25785
25549
|
}
|
|
25786
|
-
function TimelineCaret(props) {
|
|
25787
|
-
return jsx("svg", { ...props, width: "10", height: "7", viewBox: "0 0 10 7", fill: "currentcolor", children: jsx("path", { d: "M0.539174 0.830403L0.539396 0.830693L4.81717 6.41675L0.539174 0.830403ZM0.539174 0.830403C0.492941 0.770121 0.486776 0.69618 0.524599 0.622069C0.562768 0.547277 0.632849 0.5 0.721373 0.5L9.27711 0.5C9.36895 0.5 9.44336 0.552912 9.47789 0.620069C9.51177 0.686686 9.50789 0.767089 9.45938 0.830307L9.45889 0.83095M0.539174 0.830403L9.45889 0.83095M9.45889 0.83095C9.05222 1.36269 7.09357 3.91999 5.94678 5.41729C5.588 5.88573 5.30868 6.25042 5.18122 6.41687M9.45889 0.83095L5.18122 6.41687M5.18122 6.41687C5.1428 6.46691 5.07824 6.5 4.99924 6.5M5.18122 6.41687L4.99924 6.5M4.99924 6.5C4.92023 6.5 4.85567 6.46691 4.81726 6.41687L4.99924 6.5Z", fill: "currentcolor", stroke: "currentcolor" }) });
|
|
25788
|
-
}
|
|
25789
25550
|
function Timeline(props) {
|
|
25790
25551
|
return jsxs("svg", { ...props, width: "16", height: "16", viewBox: "0 0 16 16", fill: "currentcolor", children: [jsx("rect", { width: "16", height: "16", fill: "url(#pattern0_1256_1508)" }), jsxs("defs", { children: [jsx("pattern", { id: "pattern0_1256_1508", patternContentUnits: "objectBoundingBox", width: "1", height: "1", children: jsx("use", { href: "#image0_1256_1508", transform: "scale(0.00195312)" }) }), jsx("image", { id: "image0_1256_1508", width: "512", height: "512", preserveAspectRatio: "none", href: "" })] })] });
|
|
25791
25552
|
}
|
|
@@ -25926,7 +25687,6 @@ const iconComponents = {
|
|
|
25926
25687
|
Synced,
|
|
25927
25688
|
Syncing,
|
|
25928
25689
|
Tabler,
|
|
25929
|
-
TimelineCaret,
|
|
25930
25690
|
Timeline,
|
|
25931
25691
|
TrashFill,
|
|
25932
25692
|
Trash,
|
|
@@ -25989,12 +25749,7 @@ const ADD_TRIGGER = "ADD_TRIGGER";
|
|
|
25989
25749
|
const ADD_INVALID_TRIGGER = "ADD_INVALID_TRIGGER";
|
|
25990
25750
|
const defaultDriveOptions = [NEW_FOLDER, RENAME, SETTINGS];
|
|
25991
25751
|
const defaultFileOptions = [RENAME, DELETE, DUPLICATE];
|
|
25992
|
-
const defaultFolderOptions = [
|
|
25993
|
-
NEW_FOLDER,
|
|
25994
|
-
RENAME,
|
|
25995
|
-
DELETE,
|
|
25996
|
-
DUPLICATE
|
|
25997
|
-
];
|
|
25752
|
+
const defaultFolderOptions = [RENAME, DELETE, DUPLICATE];
|
|
25998
25753
|
const debugNodeOptions = [
|
|
25999
25754
|
ADD_TRIGGER,
|
|
26000
25755
|
REMOVE_TRIGGER,
|
|
@@ -26074,7 +25829,7 @@ const nodeOptionsMap = {
|
|
|
26074
25829
|
};
|
|
26075
25830
|
const name = "@powerhousedao/connect";
|
|
26076
25831
|
const productName = "Powerhouse-Connect";
|
|
26077
|
-
const version$1 = "1.
|
|
25832
|
+
const version$1 = "1.1.0";
|
|
26078
25833
|
const description = "Powerhouse Connect";
|
|
26079
25834
|
const main = "./dist/index.html";
|
|
26080
25835
|
const type = "module";
|
|
@@ -26085,8 +25840,8 @@ const author = "acaldas@powerhouse.inc";
|
|
|
26085
25840
|
const repository = { "type": "git", "url": "git+https://github.com/powerhouse-inc/document-model-electron.git" };
|
|
26086
25841
|
const bugs = { "url": "https://github.com/powerhouse-inc/document-model-electron/issues" };
|
|
26087
25842
|
const homepage = "https://github.com/powerhouse-inc/document-model-electron#readme";
|
|
26088
|
-
const scripts = { "build:tsc": "tsc --build", "start": "electron-forge start", "package": "electron-forge package", "make": "PH_CONNECT_BASE_HREF=./ electron-forge make", "make:mac": "PH_CONNECT_BASE_HREF=./ electron-forge make -p darwin", "make:linux": "PH_CONNECT_BASE_HREF=./ electron-forge make -p linux", "make:windows": "PH_CONNECT_BASE_HREF=./ electron-forge make -p win32", "publish:electron": "electron-forge publish", "prepublishOnly": "npm run build", "lint": "eslint .", "lint:fix": "eslint --fix .", "lint:nx": "eslint --quiet --fix .", "format": 'prettier --write "**/*.+(js|ts|jsx|tsx|json)"', "dev": "vite -c vite.renderer.config.mts", "dev:nocache": "rm -rf node_modules/.vite && rm -rf node_modules/.cache && npm run dev", "prebuild": "
|
|
26089
|
-
const devDependencies = { "@electron-forge/cli": "^6.1.1", "@electron-forge/maker-deb": "^6.1.1", "@electron-forge/maker-rpm": "^6.1.1", "@electron-forge/maker-squirrel": "^6.1.1", "@electron-forge/maker-zip": "^6.1.1", "@electron-forge/plugin-vite": "^6.1.1", "@electron-forge/publisher-electron-release-server": "^6.2.1", "@electron-forge/publisher-github": "^7.2.0", "@electron-forge/shared-types": "^7.7.0", "@playwright/test": "^1.41.2", "@powerhousedao/builder-tools": "workspace:*", "@powerhousedao/common": "workspace:*", "@powerhousedao/config": "workspace:*", "@powerhousedao/design-system": "workspace:*", "@powerhousedao/
|
|
25843
|
+
const scripts = { "build:tsc": "tsc --build", "start": "electron-forge start", "package": "electron-forge package", "make": "PH_CONNECT_BASE_HREF=./ electron-forge make", "make:mac": "PH_CONNECT_BASE_HREF=./ electron-forge make -p darwin", "make:linux": "PH_CONNECT_BASE_HREF=./ electron-forge make -p linux", "make:windows": "PH_CONNECT_BASE_HREF=./ electron-forge make -p win32", "publish:electron": "electron-forge publish", "prepublishOnly": "npm run build", "lint": "eslint .", "lint:fix": "eslint --fix .", "lint:nx": "eslint --quiet --fix .", "format": 'prettier --write "**/*.+(js|ts|jsx|tsx|json)"', "dev": "vite -c vite.renderer.config.mts", "dev:nocache": "rm -rf node_modules/.vite && rm -rf node_modules/.cache && npm run dev", "prebuild": "tsc --build --noEmit", "build": "NODE_OPTIONS=--max-old-space-size=6144 vite build -c vite.renderer.config.mts", "preview:web": "vite preview -c vite.renderer.config.mts", "e2e": "playwright test", "cy:open": "cypress open", "build:service-worker": "tsc --build ./tsconfig.sw.json", "clean": "rimraf dist", "clean:node_modules": "rimraf node_modules" };
|
|
25844
|
+
const devDependencies = { "@electron-forge/cli": "^6.1.1", "@electron-forge/maker-deb": "^6.1.1", "@electron-forge/maker-rpm": "^6.1.1", "@electron-forge/maker-squirrel": "^6.1.1", "@electron-forge/maker-zip": "^6.1.1", "@electron-forge/plugin-vite": "^6.1.1", "@electron-forge/publisher-electron-release-server": "^6.2.1", "@electron-forge/publisher-github": "^7.2.0", "@electron-forge/shared-types": "^7.7.0", "@playwright/test": "^1.41.2", "@powerhousedao/builder-tools": "workspace:*", "@powerhousedao/common": "workspace:*", "@powerhousedao/config": "workspace:*", "@powerhousedao/design-system": "workspace:*", "@powerhousedao/reactor-browser": "workspace:*", "@powerhousedao/scalars": "workspace:*", "@rollup/plugin-node-resolve": "^15.2.3", "@sentry/browser": "^9.1.0", "@sentry/react": "^7.109.0", "@sentry/vite-plugin": "^2.23.0", "@tailwindcss/vite": "^4.1.4", "@tanstack/react-virtual": "^3.8.1", "@types/node": "^22.13.10", "@types/react": "^18.2.79", "@types/react-dom": "^18.2.18", "@types/uuid": "^9.0.7", "@types/wicg-file-system-access": "^2020.9.6", "@vitejs/plugin-basic-ssl": "^2.0.0", "@vitejs/plugin-react": "^4.4.1", "asar": "^3.2.0", "did-key-creator": "^1.2.0", "document-drive": "workspace:*", "document-model": "workspace:*", "electron": "30.0.0", "electron-is-dev": "^3.0.1", "electron-playwright-helpers": "^1.7.1", "electron-squirrel-startup": "^1.0.0", "electron-store": "^8.1.0", "esbuild": "^0.24.0", "graphql": "^16.8.1", "graphql-request": "^6.1.0", "i18next": "^23.7.6", "jotai": "^2.1.0", "jotai-effect": "^1.1.6", "localforage": "^1.10.0", "lz-string": "^1.5.0", "playwright": "^1.41.2", "playwright-core": "^1.41.2", "react": "^18.2.0", "react-dom": "^18.2.0", "react-error-boundary": "^4.0.11", "react-hotkeys-hook": "^4.5.0", "react-i18next": "^13.5.0", "react-router-dom": "^6.11.2", "tailwind-merge": "^3.0.2", "tailwindcss": "^4.1.4", "uuid": "^9.0.1", "viem": "^2.8.13", "vite": "^6.3.3", "vite-envs": "^4.6.0", "vite-plugin-html": "^3.2.2", "vite-plugin-node-polyfills": "^0.23.0", "vite-plugin-svgr": "^4.3.0", "vite-tsconfig-paths": "^5.1.4", "xvfb-maybe": "^0.2.1" };
|
|
26090
25845
|
const optionalDependencies = { "@esbuild/linux-x64": "^0.21.4", "@rollup/rollup-linux-x64-musl": "4.14.3" };
|
|
26091
25846
|
const packageJson = {
|
|
26092
25847
|
name,
|
|
@@ -26127,15 +25882,13 @@ const PH_CONNECT_SENTRY_ENV = window.__VITE_ENVS.PH_CONNECT_SENTRY_ENV || "dev";
|
|
|
26127
25882
|
const PH_CONNECT_SENTRY_TRACING_ENABLED = window.__VITE_ENVS.PH_CONNECT_SENTRY_TRACING_ENABLED || "false";
|
|
26128
25883
|
const GA_TRACKING_ID = window.__VITE_ENVS.PH_CONNECT_GA_TRACKING_ID;
|
|
26129
25884
|
const PH_CONNECT_CLI_VERSION = window.__VITE_ENVS.PH_CONNECT_CLI_VERSION || void 0;
|
|
26130
|
-
|
|
26131
|
-
|
|
26132
|
-
logger$1.debug(`Setting log level to ${window.__VITE_ENVS.LOG_LEVEL}.`);
|
|
25885
|
+
setLogLevel(window.__VITE_ENVS.LOG_LEVEL);
|
|
25886
|
+
logger$1.info(`Setting log level to ${window.__VITE_ENVS.LOG_LEVEL}.`);
|
|
26133
25887
|
const connectConfig = {
|
|
26134
25888
|
appVersion: APP_VERSION,
|
|
26135
25889
|
studioMode: PH_CONNECT_STUDIO_MODE.toString() === "true",
|
|
26136
25890
|
warnOutdatedApp: WARN_OUTDATED_APP === "true",
|
|
26137
25891
|
routerBasename: PH_CONNECT_ROUTER_BASENAME,
|
|
26138
|
-
analyticsDatabaseName: `${PH_CONNECT_ROUTER_BASENAME}:analytics`,
|
|
26139
25892
|
sentry: {
|
|
26140
25893
|
dsn: PH_CONNECT_SENTRY_DSN,
|
|
26141
25894
|
env: PH_CONNECT_SENTRY_ENV,
|
|
@@ -26229,7 +25982,6 @@ DriveSections.filter(
|
|
|
26229
25982
|
};
|
|
26230
25983
|
});
|
|
26231
25984
|
var lzString = { exports: {} };
|
|
26232
|
-
lzString.exports;
|
|
26233
25985
|
var hasRequiredLzString;
|
|
26234
25986
|
function requireLzString() {
|
|
26235
25987
|
if (hasRequiredLzString) return lzString.exports;
|
|
@@ -28870,9 +28622,6 @@ const _BrowserStorage = class _BrowserStorage {
|
|
|
28870
28622
|
name: namespace ? `${namespace}:${_BrowserStorage.DBName}` : _BrowserStorage.DBName
|
|
28871
28623
|
}));
|
|
28872
28624
|
}
|
|
28873
|
-
////////////////////////////////
|
|
28874
|
-
// IDocumentAdminStorage
|
|
28875
|
-
////////////////////////////////
|
|
28876
28625
|
async clear() {
|
|
28877
28626
|
const db = await this.db;
|
|
28878
28627
|
await db.clear();
|
|
@@ -28885,35 +28634,19 @@ const _BrowserStorage = class _BrowserStorage {
|
|
|
28885
28634
|
const document = await db.getItem(this.buildDocumentKey(documentId));
|
|
28886
28635
|
return !!document;
|
|
28887
28636
|
}
|
|
28888
|
-
|
|
28889
|
-
|
|
28890
|
-
|
|
28891
|
-
throw new DocumentIdValidationError(documentId);
|
|
28892
|
-
}
|
|
28637
|
+
// TODO: this should throw an error if the document already exists.
|
|
28638
|
+
async create(documentId, document) {
|
|
28639
|
+
var _a2;
|
|
28893
28640
|
const db = await this.db;
|
|
28894
|
-
if (await this.exists(documentId)) {
|
|
28895
|
-
throw new DocumentAlreadyExistsError(documentId);
|
|
28896
|
-
}
|
|
28897
|
-
const slug = document.slug.length > 0 ? document.slug : documentId;
|
|
28898
|
-
if (!isValidSlug(slug)) {
|
|
28899
|
-
throw new DocumentSlugValidationError(slug);
|
|
28900
|
-
}
|
|
28901
|
-
const slugManifest = await this.getSlugManifest();
|
|
28902
|
-
if (slugManifest.slugToId[slug]) {
|
|
28903
|
-
throw new DocumentAlreadyExistsError(documentId);
|
|
28904
|
-
}
|
|
28905
|
-
document.slug = slug;
|
|
28906
28641
|
await db.setItem(this.buildDocumentKey(documentId), document);
|
|
28642
|
+
const slug = ((_a2 = document.initialState.state.global) == null ? void 0 : _a2.slug) ?? documentId;
|
|
28907
28643
|
if (slug) {
|
|
28908
|
-
const
|
|
28909
|
-
if (
|
|
28644
|
+
const slugManifest = await this.getSlugManifest();
|
|
28645
|
+
if (slugManifest.slugToId[slug]) {
|
|
28910
28646
|
throw new Error(`Document with slug ${slug} already exists`);
|
|
28911
28647
|
}
|
|
28912
|
-
|
|
28913
|
-
await this.updateSlugManifest(
|
|
28914
|
-
}
|
|
28915
|
-
if (document.documentType === "powerhouse/document-drive") {
|
|
28916
|
-
this.updateDriveManifest(documentId, { documentIds: [] });
|
|
28648
|
+
slugManifest.slugToId[slug] = documentId;
|
|
28649
|
+
await this.updateSlugManifest(slugManifest);
|
|
28917
28650
|
}
|
|
28918
28651
|
}
|
|
28919
28652
|
async get(documentId) {
|
|
@@ -28932,56 +28665,15 @@ const _BrowserStorage = class _BrowserStorage {
|
|
|
28932
28665
|
}
|
|
28933
28666
|
return this.get(documentId);
|
|
28934
28667
|
}
|
|
28935
|
-
async findByType(documentModelType, limit = 100, cursor) {
|
|
28936
|
-
const db = await this.db;
|
|
28937
|
-
const keys = await db.keys();
|
|
28938
|
-
const documentKeys = keys.filter((key) => key.startsWith(`${_BrowserStorage.DOCUMENT_KEY}${_BrowserStorage.SEP}`));
|
|
28939
|
-
const documentsAndIds = [];
|
|
28940
|
-
for (const key of documentKeys) {
|
|
28941
|
-
const documentId = key.slice(_BrowserStorage.DOCUMENT_KEY.length + _BrowserStorage.SEP.length);
|
|
28942
|
-
try {
|
|
28943
|
-
const document = await db.getItem(key);
|
|
28944
|
-
if (!document || document.documentType !== documentModelType) {
|
|
28945
|
-
continue;
|
|
28946
|
-
}
|
|
28947
|
-
documentsAndIds.push({ id: documentId, document });
|
|
28948
|
-
} catch (error) {
|
|
28949
|
-
continue;
|
|
28950
|
-
}
|
|
28951
|
-
}
|
|
28952
|
-
documentsAndIds.sort((a, b) => {
|
|
28953
|
-
const aDate = new Date(a.document.created);
|
|
28954
|
-
const bDate = new Date(b.document.created);
|
|
28955
|
-
if (aDate.getTime() === bDate.getTime()) {
|
|
28956
|
-
return a.id.localeCompare(b.id);
|
|
28957
|
-
}
|
|
28958
|
-
return aDate.getTime() - bDate.getTime();
|
|
28959
|
-
});
|
|
28960
|
-
let startIndex = 0;
|
|
28961
|
-
if (cursor) {
|
|
28962
|
-
const index = documentsAndIds.findIndex(({ id }) => id === cursor);
|
|
28963
|
-
if (index !== -1) {
|
|
28964
|
-
startIndex = index;
|
|
28965
|
-
}
|
|
28966
|
-
}
|
|
28967
|
-
const endIndex = Math.min(startIndex + limit, documentsAndIds.length);
|
|
28968
|
-
let nextCursor;
|
|
28969
|
-
if (endIndex < documentsAndIds.length) {
|
|
28970
|
-
nextCursor = documentsAndIds[endIndex].id;
|
|
28971
|
-
}
|
|
28972
|
-
return {
|
|
28973
|
-
documents: documentsAndIds.slice(startIndex, endIndex).map(({ id }) => id),
|
|
28974
|
-
nextCursor
|
|
28975
|
-
};
|
|
28976
|
-
}
|
|
28977
28668
|
async delete(documentId) {
|
|
28669
|
+
var _a2;
|
|
28978
28670
|
const db = await this.db;
|
|
28979
28671
|
const document = await db.getItem(this.buildDocumentKey(documentId));
|
|
28980
28672
|
if (!document) {
|
|
28981
28673
|
return false;
|
|
28982
28674
|
}
|
|
28983
|
-
const slug = document.slug.length > 0 ? document.slug : documentId;
|
|
28984
28675
|
try {
|
|
28676
|
+
const slug = (_a2 = document.initialState.state.global) == null ? void 0 : _a2.slug;
|
|
28985
28677
|
if (slug) {
|
|
28986
28678
|
const slugManifest = await this.getSlugManifest();
|
|
28987
28679
|
if (slugManifest.slugToId[slug] === documentId) {
|
|
@@ -28991,16 +28683,11 @@ const _BrowserStorage = class _BrowserStorage {
|
|
|
28991
28683
|
}
|
|
28992
28684
|
} catch (error) {
|
|
28993
28685
|
}
|
|
28994
|
-
const
|
|
28995
|
-
for (const
|
|
28996
|
-
|
|
28997
|
-
|
|
28998
|
-
|
|
28999
|
-
for (const child of children) {
|
|
29000
|
-
const childParents = await this.getParents(child);
|
|
29001
|
-
if (childParents.length === 1 && childParents[0] === documentId) {
|
|
29002
|
-
await this.delete(child);
|
|
29003
|
-
}
|
|
28686
|
+
const drives = await this.getDrives();
|
|
28687
|
+
for (const driveId of drives) {
|
|
28688
|
+
if (driveId === documentId)
|
|
28689
|
+
continue;
|
|
28690
|
+
await this.removeChild(driveId, documentId);
|
|
29004
28691
|
}
|
|
29005
28692
|
await db.removeItem(this.buildManifestKey(documentId));
|
|
29006
28693
|
await db.removeItem(this.buildDocumentKey(documentId));
|
|
@@ -29034,20 +28721,6 @@ const _BrowserStorage = class _BrowserStorage {
|
|
|
29034
28721
|
const manifest = await this.getManifest(parentId);
|
|
29035
28722
|
return manifest.documentIds;
|
|
29036
28723
|
}
|
|
29037
|
-
async getParents(childId) {
|
|
29038
|
-
const db = await this.db;
|
|
29039
|
-
const keys = await db.keys();
|
|
29040
|
-
const parents = [];
|
|
29041
|
-
const manifestKeys = keys.filter((key) => key.startsWith(`${_BrowserStorage.MANIFEST_KEY}${_BrowserStorage.SEP}`));
|
|
29042
|
-
for (const key of manifestKeys) {
|
|
29043
|
-
const driveId = key.slice(_BrowserStorage.MANIFEST_KEY.length + _BrowserStorage.SEP.length);
|
|
29044
|
-
const manifest = await this.getManifest(driveId);
|
|
29045
|
-
if (manifest.documentIds.includes(childId)) {
|
|
29046
|
-
parents.push(driveId);
|
|
29047
|
-
}
|
|
29048
|
-
}
|
|
29049
|
-
return parents;
|
|
29050
|
-
}
|
|
29051
28724
|
////////////////////////////////
|
|
29052
28725
|
// IDriveStorage
|
|
29053
28726
|
////////////////////////////////
|
|
@@ -29069,6 +28742,9 @@ const _BrowserStorage = class _BrowserStorage {
|
|
|
29069
28742
|
const db = await this.db;
|
|
29070
28743
|
await db.setItem(_BrowserStorage.SLUG_MANIFEST_KEY, manifest);
|
|
29071
28744
|
}
|
|
28745
|
+
async clearStorage() {
|
|
28746
|
+
return (await this.db).clear();
|
|
28747
|
+
}
|
|
29072
28748
|
async addDocumentOperations(drive, id, operations, header) {
|
|
29073
28749
|
const document = await this.get(id);
|
|
29074
28750
|
if (!document) {
|
|
@@ -29082,6 +28758,20 @@ const _BrowserStorage = class _BrowserStorage {
|
|
|
29082
28758
|
operations: mergedOperations
|
|
29083
28759
|
});
|
|
29084
28760
|
}
|
|
28761
|
+
async getDrives() {
|
|
28762
|
+
const db = await this.db;
|
|
28763
|
+
const keys = await db.keys();
|
|
28764
|
+
return keys.filter((key) => key.startsWith(_BrowserStorage.MANIFEST_KEY)).map((key) => key.slice(_BrowserStorage.MANIFEST_KEY.length + _BrowserStorage.SEP.length));
|
|
28765
|
+
}
|
|
28766
|
+
async createDrive(id, drive) {
|
|
28767
|
+
await this.create(id, drive);
|
|
28768
|
+
await this.updateDriveManifest(id, { documentIds: [] });
|
|
28769
|
+
}
|
|
28770
|
+
async deleteDrive(id) {
|
|
28771
|
+
const documents = await this.getChildren(id);
|
|
28772
|
+
await Promise.all(documents.map((doc) => this.delete(doc)));
|
|
28773
|
+
await this.delete(id);
|
|
28774
|
+
}
|
|
29085
28775
|
async addDriveOperations(id, operations, header) {
|
|
29086
28776
|
const drive = await this.get(id);
|
|
29087
28777
|
const mergedOperations = mergeOperations(drive.operations, operations);
|
|
@@ -29122,16 +28812,12 @@ const _BrowserStorage = class _BrowserStorage {
|
|
|
29122
28812
|
}
|
|
29123
28813
|
// migrates all stored operations from legacy signature to signatures array
|
|
29124
28814
|
async migrateOperationSignatures() {
|
|
29125
|
-
|
|
29126
|
-
|
|
29127
|
-
|
|
29128
|
-
|
|
29129
|
-
|
|
29130
|
-
|
|
29131
|
-
await Promise.all(documents.map(async (docId) => this.migrateDocument(drive, docId)));
|
|
29132
|
-
}
|
|
29133
|
-
cursor = nextCursor;
|
|
29134
|
-
} while (cursor);
|
|
28815
|
+
const drives = await this.getDrives();
|
|
28816
|
+
for (const drive of drives) {
|
|
28817
|
+
await this.migrateDrive(drive);
|
|
28818
|
+
const documents = await this.getChildren(drive);
|
|
28819
|
+
await Promise.all(documents.map(async (docId) => this.migrateDocument(drive, docId)));
|
|
28820
|
+
}
|
|
29135
28821
|
}
|
|
29136
28822
|
async migrateDrive(driveId) {
|
|
29137
28823
|
const drive = await this.get(driveId);
|
|
@@ -29205,11 +28891,8 @@ const getReactorDefaultDrivesConfig = () => {
|
|
|
29205
28891
|
}
|
|
29206
28892
|
};
|
|
29207
28893
|
};
|
|
29208
|
-
function
|
|
29209
|
-
return new BrowserStorage(routerBasename);
|
|
29210
|
-
}
|
|
29211
|
-
function createBrowserDocumentDriveServer(documentModels, storage) {
|
|
29212
|
-
return new ReactorBuilder(documentModels).withStorage(storage).withCache(new InMemoryCache()).withQueueManager(new BaseQueueManager(1, 10)).withOptions({ ...getReactorDefaultDrivesConfig() }).build();
|
|
28894
|
+
function createBrowserDocumentDriveServer(documentModels, routerBasename) {
|
|
28895
|
+
return new ReactorBuilder(documentModels).withStorage(new BrowserStorage(routerBasename)).withCache(new InMemoryCache()).withQueueManager(new BaseQueueManager(1, 10)).withOptions({ ...getReactorDefaultDrivesConfig() }).build();
|
|
29213
28896
|
}
|
|
29214
28897
|
const VERSION_CHECK_INTERVAL = parseInt(window.__VITE_ENVS.PH_CONNECT_VERSION_CHECK_INTERVAL) || 60 * 60 * 1e3;
|
|
29215
28898
|
const basePath = connectConfig.routerBasename;
|
|
@@ -31768,14 +31451,14 @@ if (window.__VITE_ENVS.MODE === "development") {
|
|
|
31768
31451
|
} else {
|
|
31769
31452
|
serviceWorkerManager.registerServiceWorker(false);
|
|
31770
31453
|
}
|
|
31771
|
-
const App = lazy(() => __vitePreload(() => import("./app-
|
|
31454
|
+
const App = lazy(() => __vitePreload(() => import("./app-SJyv410V.js").then((n) => n.a_), true ? __vite__mapDeps([0,1,2]) : void 0));
|
|
31772
31455
|
const AppLoader = /* @__PURE__ */ jsx(Suspense, { children: /* @__PURE__ */ jsx(App, {}) });
|
|
31773
31456
|
const appLoader = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
|
31774
31457
|
__proto__: null,
|
|
31775
31458
|
default: AppLoader
|
|
31776
31459
|
}, Symbol.toStringTag, { value: "Module" }));
|
|
31777
31460
|
export {
|
|
31778
|
-
|
|
31461
|
+
getDefaultExportFromCjs as $,
|
|
31779
31462
|
AddStateExampleInputSchema as A,
|
|
31780
31463
|
SetModuleDescriptionInputSchema as B,
|
|
31781
31464
|
SetModuleNameInputSchema as C,
|
|
@@ -31802,148 +31485,148 @@ export {
|
|
|
31802
31485
|
baseLoadFromFile as X,
|
|
31803
31486
|
baseLoadFromInput as Y,
|
|
31804
31487
|
pascalCase as Z,
|
|
31805
|
-
|
|
31488
|
+
Icon as _,
|
|
31806
31489
|
createReducer as a,
|
|
31807
|
-
|
|
31808
|
-
|
|
31809
|
-
|
|
31810
|
-
|
|
31490
|
+
DELETE as a$,
|
|
31491
|
+
LOCAL as a0,
|
|
31492
|
+
commonjsGlobal as a1,
|
|
31493
|
+
PUBLIC as a2,
|
|
31811
31494
|
SWITCHBOARD as a3,
|
|
31812
|
-
|
|
31813
|
-
|
|
31814
|
-
|
|
31815
|
-
|
|
31495
|
+
locationInfoByLocation as a4,
|
|
31496
|
+
sharingTypeOptions as a5,
|
|
31497
|
+
objectType as a6,
|
|
31498
|
+
recordType as a7,
|
|
31816
31499
|
stringType as a8,
|
|
31817
|
-
|
|
31818
|
-
|
|
31819
|
-
|
|
31820
|
-
|
|
31821
|
-
|
|
31822
|
-
|
|
31823
|
-
|
|
31824
|
-
|
|
31825
|
-
|
|
31826
|
-
|
|
31827
|
-
|
|
31828
|
-
|
|
31829
|
-
|
|
31830
|
-
|
|
31831
|
-
|
|
31832
|
-
|
|
31833
|
-
|
|
31834
|
-
|
|
31835
|
-
|
|
31836
|
-
|
|
31837
|
-
|
|
31838
|
-
|
|
31839
|
-
|
|
31840
|
-
|
|
31841
|
-
|
|
31842
|
-
|
|
31843
|
-
|
|
31844
|
-
|
|
31845
|
-
|
|
31846
|
-
|
|
31847
|
-
|
|
31500
|
+
capitalCase as a9,
|
|
31501
|
+
moveNode as aA,
|
|
31502
|
+
generateNodesCopy as aB,
|
|
31503
|
+
copyNode as aC,
|
|
31504
|
+
createState as aD,
|
|
31505
|
+
setDriveName as aE,
|
|
31506
|
+
setAvailableOffline as aF,
|
|
31507
|
+
setSharingType as aG,
|
|
31508
|
+
SynchronizationUnitNotFoundError as aH,
|
|
31509
|
+
removeTrigger as aI,
|
|
31510
|
+
generateUUID as aJ,
|
|
31511
|
+
PullResponderTransmitter as aK,
|
|
31512
|
+
addTrigger as aL,
|
|
31513
|
+
ReadDriveNotFoundError as aM,
|
|
31514
|
+
openUrl as aN,
|
|
31515
|
+
getNodeOptions as aO,
|
|
31516
|
+
DRIVE as aP,
|
|
31517
|
+
FOLDER as aQ,
|
|
31518
|
+
requestPublicDrive as aR,
|
|
31519
|
+
serviceWorkerManager as aS,
|
|
31520
|
+
packageJson as aT,
|
|
31521
|
+
t as aU,
|
|
31522
|
+
gql as aV,
|
|
31523
|
+
request as aW,
|
|
31524
|
+
getDimensions as aX,
|
|
31525
|
+
READ as aY,
|
|
31526
|
+
nodeOptionsMap as aZ,
|
|
31527
|
+
defaultFileOptions as a_,
|
|
31528
|
+
CLOUD as aa,
|
|
31529
|
+
createZip as ab,
|
|
31530
|
+
logger$1 as ac,
|
|
31848
31531
|
LZString as ad,
|
|
31849
31532
|
buildSignedOperation as ae,
|
|
31850
|
-
|
|
31851
|
-
|
|
31533
|
+
getI18n as af,
|
|
31534
|
+
getDefaults as ag,
|
|
31852
31535
|
connectConfig as ah,
|
|
31853
31536
|
hashDocumentStateForScope as ai,
|
|
31854
31537
|
getAugmentedNamespace as aj,
|
|
31855
|
-
|
|
31856
|
-
|
|
31857
|
-
|
|
31858
|
-
|
|
31859
|
-
|
|
31860
|
-
|
|
31861
|
-
|
|
31862
|
-
|
|
31863
|
-
|
|
31864
|
-
|
|
31865
|
-
|
|
31866
|
-
|
|
31867
|
-
|
|
31868
|
-
|
|
31869
|
-
|
|
31870
|
-
|
|
31538
|
+
setErrorHandler as ak,
|
|
31539
|
+
driveDocumentModelModule as al,
|
|
31540
|
+
createBrowserDocumentDriveServer as am,
|
|
31541
|
+
hashKey as an,
|
|
31542
|
+
childLogger as ao,
|
|
31543
|
+
reducer as ap,
|
|
31544
|
+
isDocumentDrive as aq,
|
|
31545
|
+
generateAddNodeAction as ar,
|
|
31546
|
+
isFileNode as as,
|
|
31547
|
+
uploadDocumentOperations as at,
|
|
31548
|
+
updateFile as au,
|
|
31549
|
+
addFolder as av,
|
|
31550
|
+
isFolderNode as aw,
|
|
31551
|
+
deleteNode as ax,
|
|
31552
|
+
updateNode as ay,
|
|
31553
|
+
FILE as az,
|
|
31871
31554
|
SetStateSchemaInputSchema as b,
|
|
31872
|
-
|
|
31873
|
-
|
|
31874
|
-
|
|
31875
|
-
|
|
31876
|
-
|
|
31877
|
-
|
|
31878
|
-
|
|
31879
|
-
|
|
31880
|
-
|
|
31881
|
-
|
|
31882
|
-
|
|
31883
|
-
|
|
31884
|
-
|
|
31885
|
-
|
|
31886
|
-
|
|
31887
|
-
|
|
31888
|
-
|
|
31889
|
-
|
|
31890
|
-
|
|
31891
|
-
|
|
31892
|
-
|
|
31893
|
-
|
|
31894
|
-
|
|
31895
|
-
|
|
31896
|
-
|
|
31897
|
-
|
|
31898
|
-
|
|
31899
|
-
|
|
31900
|
-
|
|
31901
|
-
|
|
31902
|
-
|
|
31903
|
-
|
|
31904
|
-
|
|
31905
|
-
|
|
31906
|
-
|
|
31907
|
-
|
|
31908
|
-
|
|
31909
|
-
|
|
31910
|
-
|
|
31911
|
-
|
|
31912
|
-
|
|
31913
|
-
|
|
31914
|
-
|
|
31915
|
-
|
|
31916
|
-
|
|
31917
|
-
|
|
31918
|
-
|
|
31919
|
-
|
|
31920
|
-
|
|
31921
|
-
|
|
31922
|
-
|
|
31923
|
-
|
|
31924
|
-
|
|
31925
|
-
|
|
31926
|
-
|
|
31927
|
-
|
|
31928
|
-
|
|
31929
|
-
|
|
31930
|
-
|
|
31931
|
-
|
|
31932
|
-
|
|
31933
|
-
|
|
31934
|
-
|
|
31935
|
-
|
|
31555
|
+
TypeNameMetaFieldDef as b$,
|
|
31556
|
+
RENAME as b0,
|
|
31557
|
+
WRITE as b1,
|
|
31558
|
+
DUPLICATE as b2,
|
|
31559
|
+
defaultFolderOptions as b3,
|
|
31560
|
+
garbageCollect as b4,
|
|
31561
|
+
sortOperations as b5,
|
|
31562
|
+
UI_NODE as b6,
|
|
31563
|
+
generateId as b7,
|
|
31564
|
+
undo as b8,
|
|
31565
|
+
redo as b9,
|
|
31566
|
+
GraphQLInt as bA,
|
|
31567
|
+
GraphQLDirective as bB,
|
|
31568
|
+
GraphQLObjectType as bC,
|
|
31569
|
+
GraphQLInterfaceType as bD,
|
|
31570
|
+
GraphQLUnionType as bE,
|
|
31571
|
+
GraphQLInputObjectType as bF,
|
|
31572
|
+
GraphQLEnumType as bG,
|
|
31573
|
+
isListType as bH,
|
|
31574
|
+
GraphQLList as bI,
|
|
31575
|
+
isNonNullType as bJ,
|
|
31576
|
+
GraphQLNonNull as bK,
|
|
31577
|
+
isNamedType as bL,
|
|
31578
|
+
getNullableType as bM,
|
|
31579
|
+
isLeafType as bN,
|
|
31580
|
+
GraphQLSchema as bO,
|
|
31581
|
+
buildSchema as bP,
|
|
31582
|
+
buildASTSchema as bQ,
|
|
31583
|
+
parse as bR,
|
|
31584
|
+
validate as bS,
|
|
31585
|
+
visit as bT,
|
|
31586
|
+
extendSchema as bU,
|
|
31587
|
+
snakeCase as bV,
|
|
31588
|
+
constantCase as bW,
|
|
31589
|
+
isAbstractType as bX,
|
|
31590
|
+
BREAK as bY,
|
|
31591
|
+
SchemaMetaFieldDef as bZ,
|
|
31592
|
+
TypeMetaFieldDef as b_,
|
|
31593
|
+
useDocumentDispatch as ba,
|
|
31594
|
+
inspect as bb,
|
|
31595
|
+
GraphQLError as bc,
|
|
31596
|
+
getNamedType as bd,
|
|
31597
|
+
invariant as be,
|
|
31598
|
+
isInputObjectType as bf,
|
|
31599
|
+
isScalarType as bg,
|
|
31600
|
+
isObjectType as bh,
|
|
31601
|
+
isInterfaceType as bi,
|
|
31602
|
+
isUnionType as bj,
|
|
31603
|
+
isEnumType as bk,
|
|
31604
|
+
print as bl,
|
|
31605
|
+
isPrintableAsBlockString as bm,
|
|
31606
|
+
Kind as bn,
|
|
31607
|
+
astFromValue as bo,
|
|
31608
|
+
DEFAULT_DEPRECATION_REASON as bp,
|
|
31609
|
+
isSpecifiedDirective as bq,
|
|
31610
|
+
isSpecifiedScalarType as br,
|
|
31611
|
+
isIntrospectionType as bs,
|
|
31612
|
+
z as bt,
|
|
31613
|
+
GraphQLScalarType as bu,
|
|
31614
|
+
specifiedRules as bv,
|
|
31615
|
+
GraphQLID as bw,
|
|
31616
|
+
GraphQLBoolean as bx,
|
|
31617
|
+
GraphQLString as by,
|
|
31618
|
+
GraphQLFloat as bz,
|
|
31936
31619
|
createAction as c,
|
|
31937
|
-
|
|
31938
|
-
|
|
31939
|
-
|
|
31940
|
-
|
|
31941
|
-
|
|
31942
|
-
|
|
31943
|
-
|
|
31944
|
-
|
|
31945
|
-
|
|
31946
|
-
|
|
31620
|
+
isCompositeType as c0,
|
|
31621
|
+
isOutputType as c1,
|
|
31622
|
+
isInputType as c2,
|
|
31623
|
+
assertAbstractType as c3,
|
|
31624
|
+
doTypesOverlap as c4,
|
|
31625
|
+
DirectiveLocation as c5,
|
|
31626
|
+
NoUnusedFragmentsRule as c6,
|
|
31627
|
+
ExecutableDefinitionsRule as c7,
|
|
31628
|
+
validateSchema as c8,
|
|
31629
|
+
sentenceCase as c9,
|
|
31947
31630
|
appLoader as ca,
|
|
31948
31631
|
ReorderModuleOperationsInputSchema as d,
|
|
31949
31632
|
DeleteOperationInputSchema as e,
|
|
@@ -31969,4 +31652,3 @@ export {
|
|
|
31969
31652
|
ReorderModulesInputSchema as y,
|
|
31970
31653
|
DeleteModuleInputSchema as z
|
|
31971
31654
|
};
|
|
31972
|
-
//# sourceMappingURL=app-loader-CmEZOj3m.js.map
|