@powerhousedao/connect 1.0.20-staging.0 → 1.0.21-dev.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.
Files changed (37) hide show
  1. package/dist/.env +1 -1
  2. package/dist/assets/{app-CHg8X-P4.js → app-5pzhkdPA.js} +8654 -3164
  3. package/dist/assets/app-5pzhkdPA.js.map +1 -0
  4. package/dist/assets/{app-CDOWlDp2.css → app-CmlD3Pwe.css} +119 -1
  5. package/dist/assets/{app-loader-CiloKGGQ.js → app-loader-DMIJ7HEl.js} +638 -313
  6. package/dist/assets/app-loader-DMIJ7HEl.js.map +1 -0
  7. package/dist/assets/{app-loader-DiF8OhX3.css → app-loader-DaCxVT0x.css} +134 -0
  8. package/dist/assets/browser-C3ZBRkVS.js +27234 -0
  9. package/dist/assets/browser-C3ZBRkVS.js.map +1 -0
  10. package/dist/assets/{ccip-C-Jzbxlb.js → ccip-B3SqXqYN.js} +4 -3
  11. package/dist/assets/ccip-B3SqXqYN.js.map +1 -0
  12. package/dist/assets/{content-C4Gl8-G7.js → content-CS3pyItT.js} +1051 -374
  13. package/dist/assets/content-CS3pyItT.js.map +1 -0
  14. package/dist/assets/{index-DVfa98VO.js → index-BMVX6QN3.js} +4 -3
  15. package/dist/assets/index-BMVX6QN3.js.map +1 -0
  16. package/dist/assets/{index-rfn9ysdE.js → index-CS_ENEm9.js} +7 -6
  17. package/dist/assets/index-CS_ENEm9.js.map +1 -0
  18. package/dist/assets/{index-BfCxYW7L.js → index-CTQoMeBS.js} +21 -15
  19. package/dist/assets/index-CTQoMeBS.js.map +1 -0
  20. package/dist/assets/index-CgD_N1bp.js +208 -0
  21. package/dist/assets/index-CgD_N1bp.js.map +1 -0
  22. package/dist/assets/{main.DPjT2_kL.js → main.D_01qktv.js} +2 -1
  23. package/dist/assets/main.D_01qktv.js.map +1 -0
  24. package/dist/assets/reactor-analytics-Byaaas4F.js +44 -0
  25. package/dist/assets/reactor-analytics-Byaaas4F.js.map +1 -0
  26. package/dist/assets/router-BMJPZDcx.js +1585 -0
  27. package/dist/assets/router-BMJPZDcx.js.map +1 -0
  28. package/dist/assets/{style-Ce3V83BE.css → style-BPUyhu8E.css} +3 -0
  29. package/dist/external-packages.js +1 -0
  30. package/dist/external-packages.js.map +1 -0
  31. package/dist/hmr.js +1 -0
  32. package/dist/hmr.js.map +1 -0
  33. package/dist/index.html +1 -1
  34. package/dist/service-worker.js +1 -0
  35. package/dist/service-worker.js.map +1 -0
  36. package/dist/vite-envs.sh +1 -1
  37. package/package.json +10 -9
@@ -1,4 +1,4 @@
1
- const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/app-CHg8X-P4.js","assets/main.DPjT2_kL.js","assets/app-CDOWlDp2.css"])))=>i.map(i=>d[i]);
1
+ const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/app-5pzhkdPA.js","assets/main.D_01qktv.js","assets/app-CmlD3Pwe.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.DPjT2_kL.js";
14
+ import { _ as __vitePreload } from "./main.D_01qktv.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,14 +97,51 @@ 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
+ }
100
130
  class InMemoryCache {
101
- constructor() {
102
- __publicField(this, "idTodocument", /* @__PURE__ */ new Map());
103
- __publicField(this, "idToDrive", /* @__PURE__ */ new Map());
104
- __publicField(this, "slugToDriveId", /* @__PURE__ */ new Map());
131
+ constructor(cache = /* @__PURE__ */ new Map()) {
132
+ __publicField(this, "cache");
133
+ __publicField(this, "cacheStorageManager");
134
+ __publicField(this, "idToDocument");
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();
105
142
  }
106
143
  clear() {
107
- this.idTodocument.clear();
144
+ this.idToDocument.clear();
108
145
  this.idToDrive.clear();
109
146
  this.slugToDriveId.clear();
110
147
  }
@@ -113,13 +150,13 @@ class InMemoryCache {
113
150
  /////////////////////////////////////////////////////////////////////////////
114
151
  async setDocument(documentId, document) {
115
152
  const doc = trimResultingState(document);
116
- this.idTodocument.set(documentId, doc);
153
+ this.idToDocument.set(documentId, doc);
117
154
  }
118
155
  async getDocument(documentId) {
119
- return this.idTodocument.get(documentId);
156
+ return this.idToDocument.get(documentId);
120
157
  }
121
158
  async deleteDocument(documentId) {
122
- return this.idTodocument.delete(documentId);
159
+ return this.idToDocument.delete(documentId);
123
160
  }
124
161
  async setDrive(driveId, drive) {
125
162
  const doc = trimResultingState(drive);
@@ -133,7 +170,7 @@ class InMemoryCache {
133
170
  if (!drive) {
134
171
  return false;
135
172
  }
136
- const slug = drive.state.global.slug;
173
+ const slug = drive.slug.length > 0 ? drive.slug : driveId;
137
174
  if (slug) {
138
175
  this.slugToDriveId.delete(slug);
139
176
  }
@@ -7117,6 +7154,7 @@ function createReducer(stateReducer2, documentReducer = baseReducer) {
7117
7154
  function baseCreateExtendedState(initialState, createState2) {
7118
7155
  return {
7119
7156
  name: "",
7157
+ slug: "",
7120
7158
  documentType: "",
7121
7159
  revision: {
7122
7160
  global: 0,
@@ -7144,10 +7182,6 @@ function baseCreateDocument(initialState, createState2) {
7144
7182
  function hashDocumentStateForScope(document, scope = "global") {
7145
7183
  return hash(cjsModule(document.state[scope] || ""));
7146
7184
  }
7147
- const hashKey = (date, randomLimit = 1e3) => {
7148
- const random = Math.random() * randomLimit;
7149
- return hash(`${(/* @__PURE__ */ new Date()).toISOString()}${random}`);
7150
- };
7151
7185
  function getDocumentLastModified(document) {
7152
7186
  var _a2;
7153
7187
  const sortedOperations = sortOperations(Object.values(document.operations).flat());
@@ -7534,21 +7568,186 @@ function UpdateStateExampleInputSchema() {
7534
7568
  newExample: z.string()
7535
7569
  });
7536
7570
  }
7571
+ var dist = {};
7572
+ var hasRequiredDist;
7573
+ function requireDist() {
7574
+ if (hasRequiredDist) return dist;
7575
+ hasRequiredDist = 1;
7576
+ (function(exports) {
7577
+ Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
7578
+ function getDefaultExportFromCjs2(x) {
7579
+ return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, "default") ? x["default"] : x;
7580
+ }
7581
+ var browser = { exports: {} };
7582
+ var process2 = browser.exports = {};
7583
+ var cachedSetTimeout;
7584
+ var cachedClearTimeout;
7585
+ function defaultSetTimout() {
7586
+ throw new Error("setTimeout has not been defined");
7587
+ }
7588
+ function defaultClearTimeout() {
7589
+ throw new Error("clearTimeout has not been defined");
7590
+ }
7591
+ (function() {
7592
+ try {
7593
+ if (typeof setTimeout === "function") {
7594
+ cachedSetTimeout = setTimeout;
7595
+ } else {
7596
+ cachedSetTimeout = defaultSetTimout;
7597
+ }
7598
+ } catch (e) {
7599
+ cachedSetTimeout = defaultSetTimout;
7600
+ }
7601
+ try {
7602
+ if (typeof clearTimeout === "function") {
7603
+ cachedClearTimeout = clearTimeout;
7604
+ } else {
7605
+ cachedClearTimeout = defaultClearTimeout;
7606
+ }
7607
+ } catch (e) {
7608
+ cachedClearTimeout = defaultClearTimeout;
7609
+ }
7610
+ })();
7611
+ function runTimeout(fun) {
7612
+ if (cachedSetTimeout === setTimeout) {
7613
+ return setTimeout(fun, 0);
7614
+ }
7615
+ if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {
7616
+ cachedSetTimeout = setTimeout;
7617
+ return setTimeout(fun, 0);
7618
+ }
7619
+ try {
7620
+ return cachedSetTimeout(fun, 0);
7621
+ } catch (e) {
7622
+ try {
7623
+ return cachedSetTimeout.call(null, fun, 0);
7624
+ } catch (e2) {
7625
+ return cachedSetTimeout.call(this, fun, 0);
7626
+ }
7627
+ }
7628
+ }
7629
+ function runClearTimeout(marker) {
7630
+ if (cachedClearTimeout === clearTimeout) {
7631
+ return clearTimeout(marker);
7632
+ }
7633
+ if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {
7634
+ cachedClearTimeout = clearTimeout;
7635
+ return clearTimeout(marker);
7636
+ }
7637
+ try {
7638
+ return cachedClearTimeout(marker);
7639
+ } catch (e) {
7640
+ try {
7641
+ return cachedClearTimeout.call(null, marker);
7642
+ } catch (e2) {
7643
+ return cachedClearTimeout.call(this, marker);
7644
+ }
7645
+ }
7646
+ }
7647
+ var queue = [];
7648
+ var draining = false;
7649
+ var currentQueue;
7650
+ var queueIndex = -1;
7651
+ function cleanUpNextTick() {
7652
+ if (!draining || !currentQueue) {
7653
+ return;
7654
+ }
7655
+ draining = false;
7656
+ if (currentQueue.length) {
7657
+ queue = currentQueue.concat(queue);
7658
+ } else {
7659
+ queueIndex = -1;
7660
+ }
7661
+ if (queue.length) {
7662
+ drainQueue();
7663
+ }
7664
+ }
7665
+ function drainQueue() {
7666
+ if (draining) {
7667
+ return;
7668
+ }
7669
+ var timeout = runTimeout(cleanUpNextTick);
7670
+ draining = true;
7671
+ var len = queue.length;
7672
+ while (len) {
7673
+ currentQueue = queue;
7674
+ queue = [];
7675
+ while (++queueIndex < len) {
7676
+ if (currentQueue) {
7677
+ currentQueue[queueIndex].run();
7678
+ }
7679
+ }
7680
+ queueIndex = -1;
7681
+ len = queue.length;
7682
+ }
7683
+ currentQueue = null;
7684
+ draining = false;
7685
+ runClearTimeout(timeout);
7686
+ }
7687
+ process2.nextTick = function(fun) {
7688
+ var args = new Array(arguments.length - 1);
7689
+ if (arguments.length > 1) {
7690
+ for (var i = 1; i < arguments.length; i++) {
7691
+ args[i - 1] = arguments[i];
7692
+ }
7693
+ }
7694
+ queue.push(new Item(fun, args));
7695
+ if (queue.length === 1 && !draining) {
7696
+ runTimeout(drainQueue);
7697
+ }
7698
+ };
7699
+ function Item(fun, array) {
7700
+ this.fun = fun;
7701
+ this.array = array;
7702
+ }
7703
+ Item.prototype.run = function() {
7704
+ this.fun.apply(null, this.array);
7705
+ };
7706
+ process2.title = "browser";
7707
+ process2.browser = true;
7708
+ process2.env = {};
7709
+ process2.argv = [];
7710
+ process2.version = "";
7711
+ process2.versions = {};
7712
+ function noop2() {
7713
+ }
7714
+ process2.on = noop2;
7715
+ process2.addListener = noop2;
7716
+ process2.once = noop2;
7717
+ process2.off = noop2;
7718
+ process2.removeListener = noop2;
7719
+ process2.removeAllListeners = noop2;
7720
+ process2.emit = noop2;
7721
+ process2.prependListener = noop2;
7722
+ process2.prependOnceListener = noop2;
7723
+ process2.listeners = function(name2) {
7724
+ return [];
7725
+ };
7726
+ process2.binding = function(name2) {
7727
+ throw new Error("process.binding is not supported");
7728
+ };
7729
+ process2.cwd = function() {
7730
+ return "/";
7731
+ };
7732
+ process2.chdir = function(dir) {
7733
+ throw new Error("process.chdir is not supported");
7734
+ };
7735
+ process2.umask = function() {
7736
+ return 0;
7737
+ };
7738
+ var browserExports = browser.exports;
7739
+ const process$1 = /* @__PURE__ */ getDefaultExportFromCjs2(browserExports);
7740
+ exports.default = process$1;
7741
+ exports.process = process$1;
7742
+ })(dist);
7743
+ return dist;
7744
+ }
7745
+ var distExports = requireDist();
7746
+ const process = /* @__PURE__ */ getDefaultExportFromCjs(distExports);
7537
7747
  function commonjsRequire(path) {
7538
7748
  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.');
7539
7749
  }
7540
7750
  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
- */
7552
7751
  var hasRequiredJszip_min;
7553
7752
  function requireJszip_min() {
7554
7753
  if (hasRequiredJszip_min) return jszip_min.exports;
@@ -10323,9 +10522,10 @@ function validateOperations(operations) {
10323
10522
  }
10324
10523
  function createZip(document) {
10325
10524
  const zip = new JSZip();
10326
- const { name: name2, revision, documentType: documentType2, created, lastModified } = document;
10525
+ const { name: name2, slug, revision, documentType: documentType2, created, lastModified } = document;
10327
10526
  const header = {
10328
10527
  name: name2,
10528
+ slug,
10329
10529
  revision,
10330
10530
  documentType: documentType2,
10331
10531
  created,
@@ -10740,6 +10940,60 @@ const reducer$2 = {
10740
10940
  state.triggers = state.triggers.filter((trigger) => trigger.id !== action.input.triggerId);
10741
10941
  }
10742
10942
  };
10943
+ class DocumentModelNotFoundError extends Error {
10944
+ constructor(id, cause) {
10945
+ super(`Document model "${id}" not found`, { cause });
10946
+ __publicField(this, "id");
10947
+ this.id = id;
10948
+ }
10949
+ }
10950
+ class OperationError extends Error {
10951
+ constructor(status, operation, message, cause) {
10952
+ super(message, { cause: cause ?? operation });
10953
+ __publicField(this, "status");
10954
+ __publicField(this, "operation");
10955
+ this.status = status;
10956
+ this.operation = operation;
10957
+ }
10958
+ }
10959
+ class ConflictOperationError extends OperationError {
10960
+ constructor(existingOperation, newOperation) {
10961
+ super("CONFLICT", newOperation, `Conflicting operation on index ${newOperation.index}`, { existingOperation, newOperation });
10962
+ }
10963
+ }
10964
+ class DocumentIdValidationError extends Error {
10965
+ constructor(documentId) {
10966
+ super(`Invalid document id: ${documentId}`);
10967
+ }
10968
+ }
10969
+ class DocumentSlugValidationError extends Error {
10970
+ constructor(slug) {
10971
+ super(`Invalid slug: ${slug}`);
10972
+ }
10973
+ }
10974
+ class DocumentAlreadyExistsError extends Error {
10975
+ constructor(documentId) {
10976
+ super(`Document with id ${documentId} uses id or slug that already exists`);
10977
+ __publicField(this, "documentId");
10978
+ this.documentId = documentId;
10979
+ }
10980
+ }
10981
+ class DocumentNotFoundError extends Error {
10982
+ constructor(documentId) {
10983
+ super(`Document with id ${documentId} not found`);
10984
+ __publicField(this, "documentId");
10985
+ this.documentId = documentId;
10986
+ }
10987
+ }
10988
+ class SynchronizationUnitNotFoundError extends Error {
10989
+ constructor(message, syncUnitId) {
10990
+ super(message);
10991
+ __publicField(this, "syncUnitId");
10992
+ this.syncUnitId = syncUnitId;
10993
+ }
10994
+ }
10995
+ const isValidDocumentId = (id) => /^[a-zA-Z0-9_-]+$/.test(id);
10996
+ const isValidSlug = (slug) => /^[a-zA-Z0-9_-]+$/.test(slug);
10743
10997
  const byteToHex = [];
10744
10998
  for (let i = 0; i < 256; ++i) {
10745
10999
  byteToHex.push((i + 256).toString(16).slice(1));
@@ -10915,6 +11169,9 @@ const reducer$1 = {
10915
11169
  if (state.nodes.find((node) => node.id === action.input.id)) {
10916
11170
  throw new Error(`Node with id ${action.input.id} already exists!`);
10917
11171
  }
11172
+ if (!isValidDocumentId(action.input.id)) {
11173
+ throw new DocumentIdValidationError(action.input.id);
11174
+ }
10918
11175
  const name2 = handleTargetNameCollisions({
10919
11176
  nodes: state.nodes,
10920
11177
  srcName: action.input.name,
@@ -11007,6 +11264,9 @@ const reducer$1 = {
11007
11264
  if (!node) {
11008
11265
  throw new Error(`Node with id ${action.input.srcId} not found`);
11009
11266
  }
11267
+ if (!isValidDocumentId(action.input.targetId)) {
11268
+ throw new DocumentIdValidationError(action.input.targetId);
11269
+ }
11010
11270
  const duplicatedNode = state.nodes.find((node2) => node2.id === action.input.targetId);
11011
11271
  if (duplicatedNode) {
11012
11272
  throw new Error(`Node with id ${action.input.targetId} already exists`);
@@ -11154,8 +11414,7 @@ const initialGlobalState = {
11154
11414
  id: "",
11155
11415
  name: "",
11156
11416
  nodes: [],
11157
- icon: null,
11158
- slug: null
11417
+ icon: null
11159
11418
  };
11160
11419
  const initialLocalState = {
11161
11420
  listeners: [],
@@ -11495,7 +11754,7 @@ _errorHandler = new WeakMap();
11495
11754
  _ConsoleLogger_instances = new WeakSet();
11496
11755
  levelValue_get = function() {
11497
11756
  if (__privateGet(this, _levelString) === "env") {
11498
- const envLevel = typeof process !== "undefined" ? define_process_env_default.LOG_LEVEL : void 0;
11757
+ const envLevel = typeof process !== "undefined" && "env" in process ? define_process_env_default.LOG_LEVEL : void 0;
11499
11758
  if (!envLevel) {
11500
11759
  return LEVELS.debug;
11501
11760
  }
@@ -11526,48 +11785,6 @@ const childLogger = (tags) => {
11526
11785
  logger2.errorHandler = errorHandler;
11527
11786
  return logger2;
11528
11787
  };
11529
- class DocumentModelNotFoundError extends Error {
11530
- constructor(id, cause) {
11531
- super(`Document model "${id}" not found`, { cause });
11532
- __publicField(this, "id");
11533
- this.id = id;
11534
- }
11535
- }
11536
- class OperationError extends Error {
11537
- constructor(status, operation, message, cause) {
11538
- super(message, { cause: cause ?? operation });
11539
- __publicField(this, "status");
11540
- __publicField(this, "operation");
11541
- this.status = status;
11542
- this.operation = operation;
11543
- }
11544
- }
11545
- class ConflictOperationError extends OperationError {
11546
- constructor(existingOperation, newOperation) {
11547
- super("CONFLICT", newOperation, `Conflicting operation on index ${newOperation.index}`, { existingOperation, newOperation });
11548
- }
11549
- }
11550
- class DocumentAlreadyExistsError extends Error {
11551
- constructor(documentId) {
11552
- super(`Document with id ${documentId} already exists`);
11553
- __publicField(this, "documentId");
11554
- this.documentId = documentId;
11555
- }
11556
- }
11557
- class DocumentNotFoundError extends Error {
11558
- constructor(documentId) {
11559
- super(`Document with id ${documentId} not found`);
11560
- __publicField(this, "documentId");
11561
- this.documentId = documentId;
11562
- }
11563
- }
11564
- class SynchronizationUnitNotFoundError extends Error {
11565
- constructor(message, syncUnitId) {
11566
- super(message);
11567
- __publicField(this, "syncUnitId");
11568
- this.syncUnitId = syncUnitId;
11569
- }
11570
- }
11571
11788
  var RunAsap;
11572
11789
  (function(RunAsap2) {
11573
11790
  RunAsap2.useMessageChannel = (() => {
@@ -22234,7 +22451,7 @@ class ReadModeService {
22234
22451
  return Promise.resolve(result ? { ...result.drive, readContext: result.context } : new ReadDriveNotFoundError(id));
22235
22452
  }
22236
22453
  async getReadDriveBySlug(slug) {
22237
- const readDrive = [...__privateGet(this, _drives).values()].find(({ drive }) => drive.state.global.slug === slug);
22454
+ const readDrive = [...__privateGet(this, _drives).values()].find(({ drive }) => drive.slug === slug);
22238
22455
  return Promise.resolve(readDrive ? { ...readDrive.drive, readContext: readDrive.context } : new ReadDriveSlugNotFoundError(slug));
22239
22456
  }
22240
22457
  getReadDriveContext(id) {
@@ -23296,7 +23513,7 @@ class BaseDocumentDriveServer {
23296
23513
  async _initializeDrive(driveId) {
23297
23514
  var _a2, _b, _c;
23298
23515
  const drive = await this.getDrive(driveId);
23299
- this.logger.verbose(`[SYNC DEBUG] Initializing drive ${driveId} with slug "${drive.state.global.slug}"`);
23516
+ this.logger.verbose(`[SYNC DEBUG] Initializing drive ${driveId} with slug "${drive.slug}"`);
23300
23517
  await this.synchronizationManager.initializeDriveSyncStatus(driveId, drive);
23301
23518
  if (this.shouldSyncRemoteDrive(drive)) {
23302
23519
  this.logger.verbose(`[SYNC DEBUG] Starting sync for remote drive ${driveId}`);
@@ -23376,19 +23593,18 @@ class BaseDocumentDriveServer {
23376
23593
  if (!id) {
23377
23594
  throw new Error("Invalid Drive Id");
23378
23595
  }
23379
- const drives = await this.legacyStorage.getDrives();
23380
- if (drives.includes(id)) {
23381
- throw new DocumentAlreadyExistsError(id);
23382
- }
23383
23596
  const document = createDocument({
23384
23597
  state: input
23385
23598
  });
23599
+ if (input.slug && input.slug.length > 0) {
23600
+ document.slug = input.slug;
23601
+ }
23386
23602
  document.meta = {
23387
23603
  preferredEditor
23388
23604
  };
23389
- await this.legacyStorage.createDrive(id, document);
23390
- if (input.global.slug) {
23391
- await this.cache.deleteDriveBySlug(input.global.slug);
23605
+ await this.documentStorage.create(id, document);
23606
+ if (input.slug && input.slug.length > 0) {
23607
+ await this.cache.deleteDriveBySlug(input.slug);
23392
23608
  }
23393
23609
  await this._initializeDrive(id);
23394
23610
  this.eventEmitter.emit("driveAdded", document);
@@ -23402,10 +23618,10 @@ class BaseDocumentDriveServer {
23402
23618
  pullInterval
23403
23619
  });
23404
23620
  return await this.addDrive({
23621
+ slug,
23405
23622
  global: {
23406
23623
  id,
23407
23624
  name: name2,
23408
- slug,
23409
23625
  icon: icon ?? null
23410
23626
  },
23411
23627
  local: {
@@ -23421,16 +23637,25 @@ class BaseDocumentDriveServer {
23421
23637
  this.stopSyncRemoteDrive(driveId),
23422
23638
  this.listenerManager.removeDrive(driveId),
23423
23639
  this.cache.deleteDrive(driveId),
23424
- this.legacyStorage.deleteDrive(driveId)
23640
+ this.documentStorage.delete(driveId)
23425
23641
  ]);
23642
+ this.eventEmitter.emit("driveDeleted", driveId);
23426
23643
  result.forEach((r) => {
23427
23644
  if (r.status === "rejected") {
23428
23645
  throw r.reason;
23429
23646
  }
23430
23647
  });
23431
23648
  }
23432
- getDrives() {
23433
- return this.legacyStorage.getDrives();
23649
+ // TODO: paginate
23650
+ async getDrives() {
23651
+ const drives = [];
23652
+ let cursor;
23653
+ do {
23654
+ const { documents, nextCursor } = await this.documentStorage.findByType("powerhouse/document-drive", 100, cursor);
23655
+ drives.push(...documents);
23656
+ cursor = nextCursor;
23657
+ } while (cursor);
23658
+ return drives;
23434
23659
  }
23435
23660
  async getDrive(driveId, options) {
23436
23661
  let document;
@@ -23506,6 +23731,7 @@ class BaseDocumentDriveServer {
23506
23731
  const document = input.document ?? this.getDocumentModelModule(input.documentType).utils.createDocument();
23507
23732
  const documentStorage = {
23508
23733
  name: document.name,
23734
+ slug: document.slug,
23509
23735
  revision: document.revision,
23510
23736
  documentType: document.documentType,
23511
23737
  created: document.created,
@@ -23916,13 +24142,6 @@ class BaseDocumentDriveServer {
23916
24142
  addDriveOperation(driveId, operation, options) {
23917
24143
  return this.addDriveOperations(driveId, [operation], options);
23918
24144
  }
23919
- async clearStorage() {
23920
- var _a2, _b;
23921
- for (const drive of await this.getDrives()) {
23922
- await this.deleteDrive(drive);
23923
- }
23924
- await ((_b = (_a2 = this.legacyStorage).clearStorage) == null ? void 0 : _b.call(_a2));
23925
- }
23926
24145
  async _addDriveOperations(driveId, callback) {
23927
24146
  if (!this.legacyStorage.addDriveOperationsWithTransaction) {
23928
24147
  const documentStorage = await this.documentStorage.get(driveId);
@@ -24197,17 +24416,30 @@ class MemoryStorage {
24197
24416
  exists(documentId) {
24198
24417
  return Promise.resolve(!!this.documents[documentId]);
24199
24418
  }
24200
- // TODO: this should throw an error if the document already exists.
24201
24419
  create(documentId, document) {
24202
- var _a2;
24420
+ if (!isValidDocumentId(documentId)) {
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
+ }
24203
24433
  this.documents[documentId] = document;
24204
- const slug = (_a2 = document.initialState.state.global) == null ? void 0 : _a2.slug;
24205
24434
  if (slug) {
24206
24435
  if (this.slugToDocumentId[slug]) {
24207
- throw new Error(`Document with slug ${slug} already exists`);
24436
+ throw new DocumentAlreadyExistsError(documentId);
24208
24437
  }
24209
24438
  this.slugToDocumentId[slug] = documentId;
24210
24439
  }
24440
+ if (document.documentType === "powerhouse/document-drive") {
24441
+ this.updateDriveManifest(documentId, { documentIds: /* @__PURE__ */ new Set() });
24442
+ }
24211
24443
  return Promise.resolve();
24212
24444
  }
24213
24445
  get(documentId) {
@@ -24224,20 +24456,56 @@ class MemoryStorage {
24224
24456
  }
24225
24457
  return this.get(documentId);
24226
24458
  }
24459
+ async findByType(documentModelType, limit = 100, cursor) {
24460
+ const documentsAndIds = Object.entries(this.documents).filter(([_, doc]) => doc.documentType === documentModelType).map(([id, doc]) => ({
24461
+ id,
24462
+ document: doc
24463
+ }));
24464
+ documentsAndIds.sort((a, b) => {
24465
+ const aDate = new Date(a.document.created);
24466
+ const bDate = new Date(b.document.created);
24467
+ if (aDate.getTime() === bDate.getTime()) {
24468
+ const aId = a.id;
24469
+ const bId = b.id;
24470
+ return aId.localeCompare(bId);
24471
+ }
24472
+ return aDate.getTime() - bDate.getTime();
24473
+ });
24474
+ let startIndex = 0;
24475
+ if (cursor) {
24476
+ const index = documentsAndIds.findIndex(({ id }) => id === cursor);
24477
+ if (index !== -1) {
24478
+ startIndex = index;
24479
+ }
24480
+ }
24481
+ const endIndex = Math.min(startIndex + limit, documentsAndIds.length);
24482
+ let nextCursor;
24483
+ if (endIndex < documentsAndIds.length) {
24484
+ nextCursor = documentsAndIds[endIndex].id;
24485
+ }
24486
+ return {
24487
+ documents: documentsAndIds.slice(startIndex, endIndex).map(({ id }) => id),
24488
+ nextCursor
24489
+ };
24490
+ }
24227
24491
  async delete(documentId) {
24228
- var _a2;
24229
24492
  const document = this.documents[documentId];
24230
24493
  if (document) {
24231
- const slug = (_a2 = document.initialState.state.global) == null ? void 0 : _a2.slug;
24494
+ const slug = document.slug.length > 0 ? document.slug : documentId;
24232
24495
  if (slug && this.slugToDocumentId[slug] === documentId) {
24233
24496
  delete this.slugToDocumentId[slug];
24234
24497
  }
24235
24498
  }
24236
- const drives = await this.getDrives();
24237
- for (const driveId of drives) {
24238
- if (driveId === documentId)
24239
- continue;
24240
- await this.removeChild(driveId, documentId);
24499
+ const parents = await this.getParents(documentId);
24500
+ for (const parent of parents) {
24501
+ await this.removeChild(parent, documentId);
24502
+ }
24503
+ const children = await this.getChildren(documentId);
24504
+ for (const child of children) {
24505
+ const childParents = await this.getParents(child);
24506
+ if (childParents.length === 1) {
24507
+ await this.delete(child);
24508
+ }
24241
24509
  }
24242
24510
  delete this.driveManifests[documentId];
24243
24511
  if (this.documents[documentId]) {
@@ -24271,14 +24539,26 @@ class MemoryStorage {
24271
24539
  const manifest = this.getManifest(parentId);
24272
24540
  return [...manifest.documentIds];
24273
24541
  }
24542
+ async getParents(childId) {
24543
+ const parents = [];
24544
+ for (const [driveId, manifest] of Object.entries(this.driveManifests)) {
24545
+ if (manifest.documentIds.has(childId)) {
24546
+ parents.push(driveId);
24547
+ }
24548
+ }
24549
+ return parents;
24550
+ }
24274
24551
  ////////////////////////////////
24275
- // IDriveStorage
24552
+ // IDocumentAdminStorage
24276
24553
  ////////////////////////////////
24277
- async clearStorage() {
24554
+ async clear() {
24278
24555
  this.documents = {};
24279
24556
  this.driveManifests = {};
24280
24557
  this.slugToDocumentId = {};
24281
24558
  }
24559
+ ////////////////////////////////
24560
+ // IDriveStorage
24561
+ ////////////////////////////////
24282
24562
  async addDocumentOperations(drive, id, operations, header) {
24283
24563
  const document = await this.get(id);
24284
24564
  if (!document) {
@@ -24291,13 +24571,6 @@ class MemoryStorage {
24291
24571
  operations: mergedOperations
24292
24572
  };
24293
24573
  }
24294
- async getDrives() {
24295
- return Object.keys(this.driveManifests);
24296
- }
24297
- async createDrive(id, drive) {
24298
- await this.create(id, drive);
24299
- this.updateDriveManifest(id, { documentIds: /* @__PURE__ */ new Set() });
24300
- }
24301
24574
  async addDriveOperations(id, operations, header) {
24302
24575
  const drive = await this.get(id);
24303
24576
  const mergedOperations = mergeOperations(drive.operations, operations);
@@ -24307,32 +24580,6 @@ class MemoryStorage {
24307
24580
  operations: mergedOperations
24308
24581
  };
24309
24582
  }
24310
- async deleteDrive(id) {
24311
- const manifest = this.getManifest(id);
24312
- const drives = await this.getDrives();
24313
- await Promise.all([...manifest.documentIds].map((docId) => {
24314
- var _a2;
24315
- for (const driveId of drives) {
24316
- if (driveId === id) {
24317
- continue;
24318
- }
24319
- const manifest2 = this.getManifest(driveId);
24320
- if (manifest2.documentIds.has(docId)) {
24321
- return;
24322
- }
24323
- }
24324
- const document = this.documents[docId];
24325
- if (document) {
24326
- const slug = (_a2 = document.initialState.state.global) == null ? void 0 : _a2.slug;
24327
- if (slug && this.slugToDocumentId[slug] === docId) {
24328
- delete this.slugToDocumentId[slug];
24329
- }
24330
- }
24331
- delete this.documents[docId];
24332
- }));
24333
- delete this.driveManifests[id];
24334
- delete this.documents[id];
24335
- }
24336
24583
  async getSynchronizationUnitsRevision(units) {
24337
24584
  const results = await Promise.allSettled(units.map(async (unit) => {
24338
24585
  try {
@@ -25535,6 +25782,9 @@ function Syncing(props) {
25535
25782
  function Tabler(props) {
25536
25783
  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" })] });
25537
25784
  }
25785
+ function TimelineCaret(props) {
25786
+ 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" }) });
25787
+ }
25538
25788
  function Timeline(props) {
25539
25789
  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: "" })] })] });
25540
25790
  }
@@ -25675,6 +25925,7 @@ const iconComponents = {
25675
25925
  Synced,
25676
25926
  Syncing,
25677
25927
  Tabler,
25928
+ TimelineCaret,
25678
25929
  Timeline,
25679
25930
  TrashFill,
25680
25931
  Trash,
@@ -25737,7 +25988,12 @@ const ADD_TRIGGER = "ADD_TRIGGER";
25737
25988
  const ADD_INVALID_TRIGGER = "ADD_INVALID_TRIGGER";
25738
25989
  const defaultDriveOptions = [NEW_FOLDER, RENAME, SETTINGS];
25739
25990
  const defaultFileOptions = [RENAME, DELETE, DUPLICATE];
25740
- const defaultFolderOptions = [RENAME, DELETE, DUPLICATE];
25991
+ const defaultFolderOptions = [
25992
+ NEW_FOLDER,
25993
+ RENAME,
25994
+ DELETE,
25995
+ DUPLICATE
25996
+ ];
25741
25997
  const debugNodeOptions = [
25742
25998
  ADD_TRIGGER,
25743
25999
  REMOVE_TRIGGER,
@@ -25817,7 +26073,7 @@ const nodeOptionsMap = {
25817
26073
  };
25818
26074
  const name = "@powerhousedao/connect";
25819
26075
  const productName = "Powerhouse-Connect";
25820
- const version$1 = "1.0.20-staging.0";
26076
+ const version$1 = "1.0.21-dev.0";
25821
26077
  const description = "Powerhouse Connect";
25822
26078
  const main = "./dist/index.html";
25823
26079
  const type = "module";
@@ -25829,7 +26085,7 @@ const repository = { "type": "git", "url": "git+https://github.com/powerhouse-in
25829
26085
  const bugs = { "url": "https://github.com/powerhouse-inc/document-model-electron/issues" };
25830
26086
  const homepage = "https://github.com/powerhouse-inc/document-model-electron#readme";
25831
26087
  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" };
25832
- 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.22.2", "@tailwindcss/vite": "^4.0.9", "@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": "^1.2.0", "@vitejs/plugin-react": "^4.2.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.0.9", "uuid": "^9.0.1", "viem": "^2.8.13", "vite": "^6.2.2", "vite-envs": "^4.4.11", "vite-plugin-html": "^3.2.2", "vite-plugin-node-polyfills": "^0.23.0", "vite-plugin-svgr": "^4.2.0", "vite-tsconfig-paths": "^4.3.2", "xvfb-maybe": "^0.2.1" };
26088
+ 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/diff-analyzer": "^0.0.0-dev.4", "@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.22.2", "@tailwindcss/vite": "^4.0.9", "@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": "^1.2.0", "@vitejs/plugin-react": "^4.2.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.0.9", "uuid": "^9.0.1", "viem": "^2.8.13", "vite": "^6.2.2", "vite-envs": "^4.4.11", "vite-plugin-html": "^3.2.2", "vite-plugin-node-polyfills": "^0.23.0", "vite-plugin-svgr": "^4.2.0", "vite-tsconfig-paths": "^4.3.2", "xvfb-maybe": "^0.2.1" };
25833
26089
  const optionalDependencies = { "@esbuild/linux-x64": "^0.21.4", "@rollup/rollup-linux-x64-musl": "4.14.3" };
25834
26090
  const packageJson = {
25835
26091
  name,
@@ -28610,6 +28866,9 @@ const _BrowserStorage = class _BrowserStorage {
28610
28866
  name: namespace ? `${namespace}:${_BrowserStorage.DBName}` : _BrowserStorage.DBName
28611
28867
  }));
28612
28868
  }
28869
+ ////////////////////////////////
28870
+ // IDocumentAdminStorage
28871
+ ////////////////////////////////
28613
28872
  async clear() {
28614
28873
  const db = await this.db;
28615
28874
  await db.clear();
@@ -28622,12 +28881,25 @@ const _BrowserStorage = class _BrowserStorage {
28622
28881
  const document = await db.getItem(this.buildDocumentKey(documentId));
28623
28882
  return !!document;
28624
28883
  }
28625
- // TODO: this should throw an error if the document already exists.
28626
28884
  async create(documentId, document) {
28627
- var _a2;
28885
+ if (!isValidDocumentId(documentId)) {
28886
+ throw new DocumentIdValidationError(documentId);
28887
+ }
28628
28888
  const db = await this.db;
28889
+ if (await this.exists(documentId)) {
28890
+ throw new DocumentAlreadyExistsError(documentId);
28891
+ }
28892
+ const slug = document.slug.length > 0 ? document.slug : documentId;
28893
+ if (!isValidSlug(slug)) {
28894
+ throw new DocumentSlugValidationError(slug);
28895
+ }
28896
+ if (slug) {
28897
+ const slugManifest = await this.getSlugManifest();
28898
+ if (slugManifest.slugToId[slug]) {
28899
+ throw new DocumentAlreadyExistsError(documentId);
28900
+ }
28901
+ }
28629
28902
  await db.setItem(this.buildDocumentKey(documentId), document);
28630
- const slug = ((_a2 = document.initialState.state.global) == null ? void 0 : _a2.slug) ?? documentId;
28631
28903
  if (slug) {
28632
28904
  const slugManifest = await this.getSlugManifest();
28633
28905
  if (slugManifest.slugToId[slug]) {
@@ -28636,6 +28908,9 @@ const _BrowserStorage = class _BrowserStorage {
28636
28908
  slugManifest.slugToId[slug] = documentId;
28637
28909
  await this.updateSlugManifest(slugManifest);
28638
28910
  }
28911
+ if (document.documentType === "powerhouse/document-drive") {
28912
+ this.updateDriveManifest(documentId, { documentIds: [] });
28913
+ }
28639
28914
  }
28640
28915
  async get(documentId) {
28641
28916
  const db = await this.db;
@@ -28653,15 +28928,56 @@ const _BrowserStorage = class _BrowserStorage {
28653
28928
  }
28654
28929
  return this.get(documentId);
28655
28930
  }
28931
+ async findByType(documentModelType, limit = 100, cursor) {
28932
+ const db = await this.db;
28933
+ const keys = await db.keys();
28934
+ const documentKeys = keys.filter((key) => key.startsWith(`${_BrowserStorage.DOCUMENT_KEY}${_BrowserStorage.SEP}`));
28935
+ const documentsAndIds = [];
28936
+ for (const key of documentKeys) {
28937
+ const documentId = key.slice(_BrowserStorage.DOCUMENT_KEY.length + _BrowserStorage.SEP.length);
28938
+ try {
28939
+ const document = await db.getItem(key);
28940
+ if (!document || document.documentType !== documentModelType) {
28941
+ continue;
28942
+ }
28943
+ documentsAndIds.push({ id: documentId, document });
28944
+ } catch (error) {
28945
+ continue;
28946
+ }
28947
+ }
28948
+ documentsAndIds.sort((a, b) => {
28949
+ const aDate = new Date(a.document.created);
28950
+ const bDate = new Date(b.document.created);
28951
+ if (aDate.getTime() === bDate.getTime()) {
28952
+ return a.id.localeCompare(b.id);
28953
+ }
28954
+ return aDate.getTime() - bDate.getTime();
28955
+ });
28956
+ let startIndex = 0;
28957
+ if (cursor) {
28958
+ const index = documentsAndIds.findIndex(({ id }) => id === cursor);
28959
+ if (index !== -1) {
28960
+ startIndex = index;
28961
+ }
28962
+ }
28963
+ const endIndex = Math.min(startIndex + limit, documentsAndIds.length);
28964
+ let nextCursor;
28965
+ if (endIndex < documentsAndIds.length) {
28966
+ nextCursor = documentsAndIds[endIndex].id;
28967
+ }
28968
+ return {
28969
+ documents: documentsAndIds.slice(startIndex, endIndex).map(({ id }) => id),
28970
+ nextCursor
28971
+ };
28972
+ }
28656
28973
  async delete(documentId) {
28657
- var _a2;
28658
28974
  const db = await this.db;
28659
28975
  const document = await db.getItem(this.buildDocumentKey(documentId));
28660
28976
  if (!document) {
28661
28977
  return false;
28662
28978
  }
28979
+ const slug = document.slug.length > 0 ? document.slug : documentId;
28663
28980
  try {
28664
- const slug = (_a2 = document.initialState.state.global) == null ? void 0 : _a2.slug;
28665
28981
  if (slug) {
28666
28982
  const slugManifest = await this.getSlugManifest();
28667
28983
  if (slugManifest.slugToId[slug] === documentId) {
@@ -28671,11 +28987,16 @@ const _BrowserStorage = class _BrowserStorage {
28671
28987
  }
28672
28988
  } catch (error) {
28673
28989
  }
28674
- const drives = await this.getDrives();
28675
- for (const driveId of drives) {
28676
- if (driveId === documentId)
28677
- continue;
28678
- await this.removeChild(driveId, documentId);
28990
+ const parents = await this.getParents(documentId);
28991
+ for (const parent of parents) {
28992
+ await this.removeChild(parent, documentId);
28993
+ }
28994
+ const children = await this.getChildren(documentId);
28995
+ for (const child of children) {
28996
+ const childParents = await this.getParents(child);
28997
+ if (childParents.length === 1 && childParents[0] === documentId) {
28998
+ await this.delete(child);
28999
+ }
28679
29000
  }
28680
29001
  await db.removeItem(this.buildManifestKey(documentId));
28681
29002
  await db.removeItem(this.buildDocumentKey(documentId));
@@ -28709,6 +29030,20 @@ const _BrowserStorage = class _BrowserStorage {
28709
29030
  const manifest = await this.getManifest(parentId);
28710
29031
  return manifest.documentIds;
28711
29032
  }
29033
+ async getParents(childId) {
29034
+ const db = await this.db;
29035
+ const keys = await db.keys();
29036
+ const parents = [];
29037
+ const manifestKeys = keys.filter((key) => key.startsWith(`${_BrowserStorage.MANIFEST_KEY}${_BrowserStorage.SEP}`));
29038
+ for (const key of manifestKeys) {
29039
+ const driveId = key.slice(_BrowserStorage.MANIFEST_KEY.length + _BrowserStorage.SEP.length);
29040
+ const manifest = await this.getManifest(driveId);
29041
+ if (manifest.documentIds.includes(childId)) {
29042
+ parents.push(driveId);
29043
+ }
29044
+ }
29045
+ return parents;
29046
+ }
28712
29047
  ////////////////////////////////
28713
29048
  // IDriveStorage
28714
29049
  ////////////////////////////////
@@ -28730,9 +29065,6 @@ const _BrowserStorage = class _BrowserStorage {
28730
29065
  const db = await this.db;
28731
29066
  await db.setItem(_BrowserStorage.SLUG_MANIFEST_KEY, manifest);
28732
29067
  }
28733
- async clearStorage() {
28734
- return (await this.db).clear();
28735
- }
28736
29068
  async addDocumentOperations(drive, id, operations, header) {
28737
29069
  const document = await this.get(id);
28738
29070
  if (!document) {
@@ -28746,22 +29078,6 @@ const _BrowserStorage = class _BrowserStorage {
28746
29078
  operations: mergedOperations
28747
29079
  });
28748
29080
  }
28749
- async getDrives() {
28750
- const db = await this.db;
28751
- const keys = await db.keys();
28752
- return keys.filter((key) => key.startsWith(_BrowserStorage.MANIFEST_KEY)).map((key) => key.slice(_BrowserStorage.MANIFEST_KEY.length + _BrowserStorage.SEP.length));
28753
- }
28754
- async createDrive(id, drive) {
28755
- await this.create(id, drive);
28756
- await this.updateDriveManifest(id, { documentIds: [] });
28757
- }
28758
- async deleteDrive(id) {
28759
- const documents = await this.getChildren(id);
28760
- await Promise.all(documents.map((doc) => this.delete(doc)));
28761
- const db = await this.db;
28762
- await db.removeItem(this.buildManifestKey(id));
28763
- return db.removeItem(this.buildDocumentKey(id));
28764
- }
28765
29081
  async addDriveOperations(id, operations, header) {
28766
29082
  const drive = await this.get(id);
28767
29083
  const mergedOperations = mergeOperations(drive.operations, operations);
@@ -28802,12 +29118,16 @@ const _BrowserStorage = class _BrowserStorage {
28802
29118
  }
28803
29119
  // migrates all stored operations from legacy signature to signatures array
28804
29120
  async migrateOperationSignatures() {
28805
- const drives = await this.getDrives();
28806
- for (const drive of drives) {
28807
- await this.migrateDrive(drive);
28808
- const documents = await this.getChildren(drive);
28809
- await Promise.all(documents.map(async (docId) => this.migrateDocument(drive, docId)));
28810
- }
29121
+ let cursor;
29122
+ do {
29123
+ const { documents: drives, nextCursor } = await this.findByType("powerhouse/document-drive", 100, cursor);
29124
+ for (const drive of drives) {
29125
+ await this.migrateDrive(drive);
29126
+ const documents = await this.getChildren(drive);
29127
+ await Promise.all(documents.map(async (docId) => this.migrateDocument(drive, docId)));
29128
+ }
29129
+ cursor = nextCursor;
29130
+ } while (cursor);
28811
29131
  }
28812
29132
  async migrateDrive(driveId) {
28813
29133
  const drive = await this.get(driveId);
@@ -28881,8 +29201,11 @@ const getReactorDefaultDrivesConfig = () => {
28881
29201
  }
28882
29202
  };
28883
29203
  };
28884
- function createBrowserDocumentDriveServer(documentModels, routerBasename) {
28885
- return new ReactorBuilder(documentModels).withStorage(new BrowserStorage(routerBasename)).withCache(new InMemoryCache()).withQueueManager(new BaseQueueManager(1, 10)).withOptions({ ...getReactorDefaultDrivesConfig() }).build();
29204
+ function createBrowserStorage(routerBasename) {
29205
+ return new BrowserStorage(routerBasename);
29206
+ }
29207
+ function createBrowserDocumentDriveServer(documentModels, storage) {
29208
+ return new ReactorBuilder(documentModels).withStorage(storage).withCache(new InMemoryCache()).withQueueManager(new BaseQueueManager(1, 10)).withOptions({ ...getReactorDefaultDrivesConfig() }).build();
28886
29209
  }
28887
29210
  const VERSION_CHECK_INTERVAL = parseInt(window.__VITE_ENVS.PH_CONNECT_VERSION_CHECK_INTERVAL) || 60 * 60 * 1e3;
28888
29211
  const basePath = connectConfig.routerBasename;
@@ -31441,14 +31764,14 @@ if (window.__VITE_ENVS.MODE === "development") {
31441
31764
  } else {
31442
31765
  serviceWorkerManager.registerServiceWorker(false);
31443
31766
  }
31444
- const App = lazy(() => __vitePreload(() => import("./app-CHg8X-P4.js").then((n) => n.aY), true ? __vite__mapDeps([0,1,2]) : void 0));
31767
+ const App = lazy(() => __vitePreload(() => import("./app-5pzhkdPA.js").then((n) => n.bu), true ? __vite__mapDeps([0,1,2]) : void 0));
31445
31768
  const AppLoader = /* @__PURE__ */ jsx(Suspense, { children: /* @__PURE__ */ jsx(App, {}) });
31446
31769
  const appLoader = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
31447
31770
  __proto__: null,
31448
31771
  default: AppLoader
31449
31772
  }, Symbol.toStringTag, { value: "Module" }));
31450
31773
  export {
31451
- getDefaultExportFromCjs as $,
31774
+ Icon as $,
31452
31775
  AddStateExampleInputSchema as A,
31453
31776
  SetModuleDescriptionInputSchema as B,
31454
31777
  SetModuleNameInputSchema as C,
@@ -31475,49 +31798,49 @@ export {
31475
31798
  baseLoadFromFile as X,
31476
31799
  baseLoadFromInput as Y,
31477
31800
  pascalCase as Z,
31478
- Icon as _,
31801
+ logger$1 as _,
31479
31802
  createReducer as a,
31480
- DELETE as a$,
31481
- LOCAL as a0,
31482
- commonjsGlobal as a1,
31483
- PUBLIC as a2,
31484
- SWITCHBOARD as a3,
31485
- locationInfoByLocation as a4,
31486
- sharingTypeOptions as a5,
31487
- objectType as a6,
31488
- recordType as a7,
31489
- stringType as a8,
31490
- capitalCase as a9,
31491
- moveNode as aA,
31492
- generateNodesCopy as aB,
31493
- copyNode as aC,
31494
- createState as aD,
31495
- setDriveName as aE,
31496
- setAvailableOffline as aF,
31497
- setSharingType as aG,
31498
- SynchronizationUnitNotFoundError as aH,
31499
- removeTrigger as aI,
31500
- generateUUID as aJ,
31501
- PullResponderTransmitter as aK,
31502
- addTrigger as aL,
31503
- ReadDriveNotFoundError as aM,
31504
- openUrl as aN,
31505
- getNodeOptions as aO,
31506
- DRIVE as aP,
31507
- FOLDER as aQ,
31508
- requestPublicDrive as aR,
31509
- serviceWorkerManager as aS,
31510
- packageJson as aT,
31511
- t as aU,
31512
- gql as aV,
31513
- request as aW,
31514
- getDimensions as aX,
31515
- READ as aY,
31516
- nodeOptionsMap as aZ,
31517
- defaultFileOptions as a_,
31518
- CLOUD as aa,
31519
- createZip as ab,
31520
- logger$1 as ac,
31803
+ getNamedType as a$,
31804
+ getDefaultExportFromCjs as a0,
31805
+ LOCAL as a1,
31806
+ commonjsGlobal as a2,
31807
+ PUBLIC as a3,
31808
+ SWITCHBOARD as a4,
31809
+ locationInfoByLocation as a5,
31810
+ sharingTypeOptions as a6,
31811
+ objectType as a7,
31812
+ recordType as a8,
31813
+ stringType as a9,
31814
+ updateNode as aA,
31815
+ FILE as aB,
31816
+ moveNode as aC,
31817
+ generateNodesCopy as aD,
31818
+ copyNode as aE,
31819
+ createState as aF,
31820
+ setDriveName as aG,
31821
+ setAvailableOffline as aH,
31822
+ setSharingType as aI,
31823
+ SynchronizationUnitNotFoundError as aJ,
31824
+ removeTrigger as aK,
31825
+ generateUUID as aL,
31826
+ PullResponderTransmitter as aM,
31827
+ addTrigger as aN,
31828
+ ReadDriveNotFoundError as aO,
31829
+ openUrl as aP,
31830
+ getNodeOptions as aQ,
31831
+ DRIVE as aR,
31832
+ FOLDER as aS,
31833
+ requestPublicDrive as aT,
31834
+ serviceWorkerManager as aU,
31835
+ packageJson as aV,
31836
+ t as aW,
31837
+ gql as aX,
31838
+ request as aY,
31839
+ inspect as aZ,
31840
+ GraphQLError as a_,
31841
+ capitalCase as aa,
31842
+ CLOUD as ab,
31843
+ createZip as ac,
31521
31844
  LZString as ad,
31522
31845
  buildSignedOperation as ae,
31523
31846
  getI18n as af,
@@ -31525,99 +31848,100 @@ export {
31525
31848
  connectConfig as ah,
31526
31849
  hashDocumentStateForScope as ai,
31527
31850
  getAugmentedNamespace as aj,
31528
- setErrorHandler as ak,
31529
- driveDocumentModelModule as al,
31530
- createBrowserDocumentDriveServer as am,
31531
- hashKey as an,
31532
- childLogger as ao,
31533
- reducer as ap,
31534
- isDocumentDrive as aq,
31535
- generateAddNodeAction as ar,
31536
- isFileNode as as,
31537
- uploadDocumentOperations as at,
31538
- updateFile as au,
31539
- addFolder as av,
31540
- isFolderNode as aw,
31541
- deleteNode as ax,
31542
- updateNode as ay,
31543
- FILE as az,
31851
+ process as ak,
31852
+ setErrorHandler as al,
31853
+ driveDocumentModelModule as am,
31854
+ createBrowserStorage as an,
31855
+ createBrowserDocumentDriveServer as ao,
31856
+ generateId as ap,
31857
+ childLogger as aq,
31858
+ reducer as ar,
31859
+ isDocumentDrive as as,
31860
+ generateAddNodeAction as at,
31861
+ isFileNode as au,
31862
+ uploadDocumentOperations as av,
31863
+ updateFile as aw,
31864
+ addFolder as ax,
31865
+ isFolderNode as ay,
31866
+ deleteNode as az,
31544
31867
  SetStateSchemaInputSchema as b,
31545
- GraphQLFloat as b$,
31546
- RENAME as b0,
31547
- WRITE as b1,
31548
- DUPLICATE as b2,
31549
- defaultFolderOptions as b3,
31550
- garbageCollect as b4,
31551
- sortOperations as b5,
31552
- UI_NODE as b6,
31553
- generateId as b7,
31554
- undo as b8,
31555
- redo as b9,
31556
- isListType as bA,
31557
- snakeCase as bB,
31558
- constantCase as bC,
31559
- isAbstractType as bD,
31560
- BREAK as bE,
31561
- GraphQLInputObjectType as bF,
31562
- GraphQLList as bG,
31563
- GraphQLEnumType as bH,
31564
- GraphQLObjectType as bI,
31565
- GraphQLInterfaceType as bJ,
31566
- SchemaMetaFieldDef as bK,
31567
- TypeMetaFieldDef as bL,
31568
- TypeNameMetaFieldDef as bM,
31569
- isCompositeType as bN,
31570
- isOutputType as bO,
31571
- isInputType as bP,
31572
- GraphQLBoolean as bQ,
31573
- assertAbstractType as bR,
31574
- doTypesOverlap as bS,
31575
- DirectiveLocation as bT,
31576
- specifiedRules as bU,
31577
- NoUnusedFragmentsRule as bV,
31578
- ExecutableDefinitionsRule as bW,
31579
- validate as bX,
31580
- validateSchema as bY,
31581
- GraphQLID as bZ,
31582
- GraphQLString as b_,
31583
- useDocumentDispatch as ba,
31584
- inspect as bb,
31585
- GraphQLError as bc,
31586
- getNamedType as bd,
31587
- invariant as be,
31588
- isInputObjectType as bf,
31589
- isScalarType as bg,
31590
- isObjectType as bh,
31591
- isInterfaceType as bi,
31592
- isUnionType as bj,
31593
- isEnumType as bk,
31594
- print as bl,
31595
- isPrintableAsBlockString as bm,
31596
- Kind as bn,
31597
- astFromValue as bo,
31598
- DEFAULT_DEPRECATION_REASON as bp,
31599
- isSpecifiedDirective as bq,
31600
- isSpecifiedScalarType as br,
31601
- isIntrospectionType as bs,
31602
- z as bt,
31603
- GraphQLScalarType as bu,
31604
- parse as bv,
31605
- visit as bw,
31606
- buildASTSchema as bx,
31607
- extendSchema as by,
31608
- getNullableType as bz,
31868
+ defaultFileOptions as b$,
31869
+ invariant as b0,
31870
+ isInputObjectType as b1,
31871
+ isScalarType as b2,
31872
+ isObjectType as b3,
31873
+ isInterfaceType as b4,
31874
+ isUnionType as b5,
31875
+ isEnumType as b6,
31876
+ print as b7,
31877
+ isPrintableAsBlockString as b8,
31878
+ Kind as b9,
31879
+ isOutputType as bA,
31880
+ isInputType as bB,
31881
+ GraphQLBoolean as bC,
31882
+ assertAbstractType as bD,
31883
+ doTypesOverlap as bE,
31884
+ DirectiveLocation as bF,
31885
+ specifiedRules as bG,
31886
+ NoUnusedFragmentsRule as bH,
31887
+ ExecutableDefinitionsRule as bI,
31888
+ validate as bJ,
31889
+ validateSchema as bK,
31890
+ GraphQLID as bL,
31891
+ GraphQLString as bM,
31892
+ GraphQLFloat as bN,
31893
+ GraphQLInt as bO,
31894
+ GraphQLDirective as bP,
31895
+ GraphQLUnionType as bQ,
31896
+ isNonNullType as bR,
31897
+ GraphQLNonNull as bS,
31898
+ isNamedType as bT,
31899
+ isLeafType as bU,
31900
+ GraphQLSchema as bV,
31901
+ buildSchema as bW,
31902
+ sentenceCase as bX,
31903
+ getDimensions as bY,
31904
+ READ as bZ,
31905
+ nodeOptionsMap as b_,
31906
+ astFromValue as ba,
31907
+ DEFAULT_DEPRECATION_REASON as bb,
31908
+ isSpecifiedDirective as bc,
31909
+ isSpecifiedScalarType as bd,
31910
+ isIntrospectionType as be,
31911
+ z as bf,
31912
+ GraphQLScalarType as bg,
31913
+ parse as bh,
31914
+ visit as bi,
31915
+ buildASTSchema as bj,
31916
+ extendSchema as bk,
31917
+ getNullableType as bl,
31918
+ isListType as bm,
31919
+ snakeCase as bn,
31920
+ constantCase as bo,
31921
+ isAbstractType as bp,
31922
+ BREAK as bq,
31923
+ GraphQLInputObjectType as br,
31924
+ GraphQLList as bs,
31925
+ GraphQLEnumType as bt,
31926
+ GraphQLObjectType as bu,
31927
+ GraphQLInterfaceType as bv,
31928
+ SchemaMetaFieldDef as bw,
31929
+ TypeMetaFieldDef as bx,
31930
+ TypeNameMetaFieldDef as by,
31931
+ isCompositeType as bz,
31609
31932
  createAction as c,
31610
- GraphQLInt as c0,
31611
- GraphQLDirective as c1,
31612
- GraphQLUnionType as c2,
31613
- isNonNullType as c3,
31614
- GraphQLNonNull as c4,
31615
- isNamedType as c5,
31616
- isLeafType as c6,
31617
- GraphQLSchema as c7,
31618
- buildSchema as c8,
31619
- sentenceCase as c9,
31620
- appLoader as ca,
31933
+ DELETE as c0,
31934
+ RENAME as c1,
31935
+ WRITE as c2,
31936
+ DUPLICATE as c3,
31937
+ defaultFolderOptions as c4,
31938
+ garbageCollect as c5,
31939
+ sortOperations as c6,
31940
+ UI_NODE as c7,
31941
+ undo as c8,
31942
+ redo as c9,
31943
+ useDocumentDispatch as ca,
31944
+ appLoader as cb,
31621
31945
  ReorderModuleOperationsInputSchema as d,
31622
31946
  DeleteOperationInputSchema as e,
31623
31947
  SetOperationReducerInputSchema as f,
@@ -31642,3 +31966,4 @@ export {
31642
31966
  ReorderModulesInputSchema as y,
31643
31967
  DeleteModuleInputSchema as z
31644
31968
  };
31969
+ //# sourceMappingURL=app-loader-DMIJ7HEl.js.map