sliftutils 0.10.0 → 0.12.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 (77) hide show
  1. package/.gitignore +38 -0
  2. package/assets/icon128.png +0 -0
  3. package/assets/icon16.png +0 -0
  4. package/assets/icon48.png +0 -0
  5. package/build-electron/assets/icon128.png +0 -0
  6. package/build-electron/assets/icon16.png +0 -0
  7. package/build-electron/assets/icon48.png +0 -0
  8. package/build-electron/electron/electronIndex.html +12 -0
  9. package/build-electron/electronMain.js +5185 -0
  10. package/build-electron/electronRenderer.js +20852 -0
  11. package/build-extension/assets/icon128.png +0 -0
  12. package/build-extension/assets/icon16.png +0 -0
  13. package/build-extension/assets/icon48.png +0 -0
  14. package/build-extension/extBackground.js +5246 -0
  15. package/build-extension/extContentScript.js +5243 -0
  16. package/build-extension/manifest.json +29 -0
  17. package/build-nodejs/server.js +198610 -0
  18. package/build-web/assets/icon128.png +0 -0
  19. package/build-web/assets/icon16.png +0 -0
  20. package/build-web/assets/icon48.png +0 -0
  21. package/build-web/browser.js +199266 -0
  22. package/build-web/web/index.html +32 -0
  23. package/builders/dist/electronBuild.ts.cache +105 -0
  24. package/builders/dist/extensionBuild.ts.cache +146 -0
  25. package/builders/dist/generateIndexDts.ts.cache +74 -0
  26. package/builders/dist/hotReload.ts.cache +93 -0
  27. package/builders/dist/nodeJSBuild.ts.cache +29 -0
  28. package/builders/dist/watch.ts.cache +163 -0
  29. package/builders/dist/webBuild.ts.cache +81 -0
  30. package/builders/generateIndexDts.ts +1 -1
  31. package/bundler/dist/bundleEntry.ts.cache +48 -0
  32. package/bundler/dist/bundleEntryCaller.ts.cache +18 -0
  33. package/bundler/dist/bundleRequire.ts.cache +246 -0
  34. package/bundler/dist/bundleWrapper.ts.cache +101 -0
  35. package/bundler/dist/bundler.ts.cache +66 -0
  36. package/bundler/dist/sourceMaps.ts.cache +210 -0
  37. package/dist/electronMain.ts.cache +27 -0
  38. package/dist/electronRenderer.tsx.cache +62 -0
  39. package/electron/dist/electronMain.ts.cache +26 -0
  40. package/electron/dist/electronRenderer.tsx.cache +64 -0
  41. package/extension/dist/extBackground.ts.cache +20 -0
  42. package/extension/dist/extContentScript.ts.cache +17 -0
  43. package/index.d.ts +478 -0
  44. package/misc/dist/environment.ts.cache +50 -0
  45. package/misc/dist/fs.ts.cache +29 -0
  46. package/nodejs/dist/exampleFile.ts.cache +11 -0
  47. package/nodejs/dist/server.ts.cache +15 -0
  48. package/package.json +5 -1
  49. package/render-utils/dist/observer.tsx.cache +33 -0
  50. package/storage/CachedStorage.d.ts +2 -0
  51. package/storage/DelayedStorage.d.ts +14 -0
  52. package/storage/DiskCollection.d.ts +99 -0
  53. package/storage/FileFolderAPI.d.ts +71 -0
  54. package/storage/IStorage.d.ts +38 -0
  55. package/storage/IndexedDBFileFolderAPI.d.ts +6 -0
  56. package/storage/JSONStorage.d.ts +16 -0
  57. package/storage/PendingManager.d.ts +6 -0
  58. package/storage/PendingStorage.d.ts +18 -0
  59. package/storage/PrivateFileSystemStorage.d.ts +23 -0
  60. package/storage/StorageObservable.d.ts +32 -0
  61. package/storage/TransactionStorage.d.ts +46 -0
  62. package/storage/dist/CachedStorage.ts.cache +31 -0
  63. package/storage/dist/DelayedStorage.ts.cache +35 -0
  64. package/storage/dist/DiskCollection.ts.cache +241 -0
  65. package/storage/dist/FileFolderAPI.tsx.cache +345 -0
  66. package/storage/dist/IndexedDBFileFolderAPI.ts.cache +142 -0
  67. package/storage/dist/JSONStorage.ts.cache +38 -0
  68. package/storage/dist/PendingManager.tsx.cache +73 -0
  69. package/storage/dist/PendingStorage.ts.cache +49 -0
  70. package/storage/dist/PrivateFileSystemStorage.ts.cache +178 -0
  71. package/storage/dist/StorageObservable.ts.cache +120 -0
  72. package/storage/dist/TransactionStorage.ts.cache +421 -0
  73. package/storage/dist/fileSystemPointer.ts.cache +77 -0
  74. package/storage/fileSystemPointer.d.ts +11 -0
  75. package/tsconfig.declarations.json +3 -1
  76. package/web/dist/browser.tsx.cache +66 -0
  77. package/yarn.lock +1752 -0
@@ -0,0 +1,73 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __importDefault = (this && this.__importDefault) || function (mod) {
9
+ return (mod && mod.__esModule && mod.default) ? mod : { "default": mod };
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true , configurable: true});
12
+ //exports.PendingDisplay = exports.hasPending = exports.setPending = void 0;
13
+ const misc_1 = require("socket-function/src/misc");
14
+ const mobxTyped_1 = require("../misc/mobxTyped");
15
+ const preact_1 = __importDefault(require("preact"));
16
+ const typesafecss_1 = require("typesafecss");
17
+ const observer_1 = require("../misc/observer");
18
+ const format_1 = require("socket-function/src/formatting/format");
19
+ let watchState = (0, mobxTyped_1.observable)({
20
+ pending: {}
21
+ });
22
+ let pendingLastSets = new Map();
23
+ let pendingCache = new Map();
24
+ // "" clears the pending value
25
+ function setPending(group, message) {
26
+ pendingCache.set(group, message);
27
+ void setPendingBase();
28
+ }
29
+ exports.setPending = setPending;
30
+ function hasPending() {
31
+ return Object.keys(watchState.pending).length > 0;
32
+ }
33
+ exports.hasPending = hasPending;
34
+ // NOTE: This not only prevents render overload, but also means any pending that are < this
35
+ // delay don't show up (which is useful to reduce unnecessary pending messages).
36
+ const setPendingBase = (0, misc_1.throttleFunction)(500, function setPendingBase() {
37
+ for (let [group, message] of pendingCache) {
38
+ if (!message) {
39
+ let lastSet = pendingLastSets.get(group);
40
+ if (lastSet) {
41
+ let duration = Date.now() - lastSet;
42
+ if (duration > 500) {
43
+ console.log(`Finished slow task after ${(0, format_1.formatTime)(duration)}: ${JSON.stringify(group)}, last is ${JSON.stringify(watchState.pending[group])}`);
44
+ }
45
+ pendingLastSets.delete(group);
46
+ }
47
+ delete watchState.pending[group];
48
+ }
49
+ else {
50
+ //console.log("setPending", group, message);
51
+ if (!(group in watchState.pending)) {
52
+ pendingLastSets.set(group, Date.now());
53
+ }
54
+ watchState.pending[group] = message;
55
+ }
56
+ }
57
+ pendingCache.clear();
58
+ });
59
+ let PendingDisplay = class PendingDisplay extends preact_1.default.Component {
60
+ render() {
61
+ // Single line, giving equal space, and ellipsis for overflow
62
+ return preact_1.default.createElement("div", { className: typesafecss_1.css.hbox(10) }, Object.keys(watchState.pending).map(group => (preact_1.default.createElement("div", { className: typesafecss_1.css.center.textOverflow("ellipsis").border("1px solid black").pad2(6, 2) },
63
+ group,
64
+ ": ",
65
+ watchState.pending[group]))));
66
+ }
67
+ };
68
+ exports.PendingDisplay = PendingDisplay;
69
+ exports.PendingDisplay = PendingDisplay = __decorate([
70
+ observer_1.observer
71
+ ], PendingDisplay);
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUGVuZGluZ01hbmFnZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJQZW5kaW5nTWFuYWdlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsbURBQTREO0FBQzVELGlEQUErQztBQUMvQyxvREFBNEI7QUFDNUIsNkNBQWtDO0FBQ2xDLCtDQUE0QztBQUM1QyxrRUFBbUU7QUFFbkUsSUFBSSxVQUFVLEdBQUcsSUFBQSxzQkFBVSxFQUFDO0lBQ3hCLE9BQU8sRUFBRSxFQUFpQztDQUM3QyxDQUFDLENBQUM7QUFDSCxJQUFJLGVBQWUsR0FBRyxJQUFJLEdBQUcsRUFBa0IsQ0FBQztBQUVoRCxJQUFJLFlBQVksR0FBRyxJQUFJLEdBQUcsRUFBa0IsQ0FBQztBQUU3Qyw4QkFBOEI7QUFDOUIsU0FBZ0IsVUFBVSxDQUFDLEtBQWEsRUFBRSxPQUFlO0lBQ3JELFlBQVksQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ2pDLEtBQUssY0FBYyxFQUFFLENBQUM7QUFDMUIsQ0FBQztBQUhELGdDQUdDO0FBRUQsU0FBZ0IsVUFBVTtJQUN0QixPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7QUFDdEQsQ0FBQztBQUZELGdDQUVDO0FBRUQsMkZBQTJGO0FBQzNGLGlGQUFpRjtBQUNqRixNQUFNLGNBQWMsR0FBRyxJQUFBLHVCQUFnQixFQUFDLEdBQUcsRUFBRSxTQUFTLGNBQWM7SUFDaEUsS0FBSyxJQUFJLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBRXhDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNYLElBQUksT0FBTyxHQUFHLGVBQWUsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDekMsSUFBSSxPQUFPLEVBQUUsQ0FBQztnQkFDVixJQUFJLFFBQVEsR0FBRyxJQUFJLENBQUMsR0FBRyxFQUFFLEdBQUcsT0FBTyxDQUFDO2dCQUNwQyxJQUFJLFFBQVEsR0FBRyxHQUFHLEVBQUUsQ0FBQztvQkFDakIsT0FBTyxDQUFDLEdBQUcsQ0FBQyw0QkFBNEIsSUFBQSxtQkFBVSxFQUFDLFFBQVEsQ0FBQyxLQUFLLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLGFBQWEsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO2dCQUNwSixDQUFDO2dCQUNELGVBQWUsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDbEMsQ0FBQztZQUNELE9BQU8sVUFBVSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNyQyxDQUFDO2FBQU0sQ0FBQztZQUNKLDRDQUE0QztZQUM1QyxJQUFJLENBQUMsQ0FBQyxLQUFLLElBQUksVUFBVSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7Z0JBQ2pDLGVBQWUsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDO1lBQzNDLENBQUM7WUFDRCxVQUFVLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLE9BQU8sQ0FBQztRQUN4QyxDQUFDO0lBQ0wsQ0FBQztJQUNELFlBQVksQ0FBQyxLQUFLLEVBQUUsQ0FBQztBQUN6QixDQUFDLENBQUMsQ0FBQztBQUdJLElBQU0sY0FBYyxHQUFwQixNQUFNLGNBQWUsU0FBUSxnQkFBTSxDQUFDLFNBQVM7SUFDaEQsTUFBTTtRQUNGLDZEQUE2RDtRQUM3RCxPQUFPLHdDQUFLLFNBQVMsRUFBRSxpQkFBRyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFDOUIsTUFBTSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FDMUMsd0NBQUssU0FBUyxFQUFFLGlCQUFHLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxVQUFVLENBQUMsQ0FBQyxNQUFNLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQztZQUNuRixLQUFLOztZQUFJLFVBQVUsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQ2pDLENBQ1QsQ0FBQyxDQUNBLENBQUM7SUFDWCxDQUFDO0NBQ0osQ0FBQTtBQVhZLHdDQUFjO3lCQUFkLGNBQWM7SUFEMUIsbUJBQVE7R0FDSSxjQUFjLENBVzFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdGhyb3R0bGVGdW5jdGlvbiB9IGZyb20gXCJzb2NrZXQtZnVuY3Rpb24vc3JjL21pc2NcIjtcbmltcG9ydCB7IG9ic2VydmFibGUgfSBmcm9tIFwiLi4vbWlzYy9tb2J4VHlwZWRcIjtcbmltcG9ydCBwcmVhY3QgZnJvbSBcInByZWFjdFwiO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSBcInR5cGVzYWZlY3NzXCI7XG5pbXBvcnQgeyBvYnNlcnZlciB9IGZyb20gXCIuLi9taXNjL29ic2VydmVyXCI7XG5pbXBvcnQgeyBmb3JtYXRUaW1lIH0gZnJvbSBcInNvY2tldC1mdW5jdGlvbi9zcmMvZm9ybWF0dGluZy9mb3JtYXRcIjtcblxubGV0IHdhdGNoU3RhdGUgPSBvYnNlcnZhYmxlKHtcbiAgICBwZW5kaW5nOiB7fSBhcyB7IFtncm91cDogc3RyaW5nXTogc3RyaW5nIH1cbn0pO1xubGV0IHBlbmRpbmdMYXN0U2V0cyA9IG5ldyBNYXA8c3RyaW5nLCBudW1iZXI+KCk7XG5cbmxldCBwZW5kaW5nQ2FjaGUgPSBuZXcgTWFwPHN0cmluZywgc3RyaW5nPigpO1xuXG4vLyBcIlwiIGNsZWFycyB0aGUgcGVuZGluZyB2YWx1ZVxuZXhwb3J0IGZ1bmN0aW9uIHNldFBlbmRpbmcoZ3JvdXA6IHN0cmluZywgbWVzc2FnZTogc3RyaW5nKSB7XG4gICAgcGVuZGluZ0NhY2hlLnNldChncm91cCwgbWVzc2FnZSk7XG4gICAgdm9pZCBzZXRQZW5kaW5nQmFzZSgpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaGFzUGVuZGluZygpOiBib29sZWFuIHtcbiAgICByZXR1cm4gT2JqZWN0LmtleXMod2F0Y2hTdGF0ZS5wZW5kaW5nKS5sZW5ndGggPiAwO1xufVxuXG4vLyBOT1RFOiBUaGlzIG5vdCBvbmx5IHByZXZlbnRzIHJlbmRlciBvdmVybG9hZCwgYnV0IGFsc28gbWVhbnMgYW55IHBlbmRpbmcgdGhhdCBhcmUgPCB0aGlzXG4vLyAgZGVsYXkgZG9uJ3Qgc2hvdyB1cCAod2hpY2ggaXMgdXNlZnVsIHRvIHJlZHVjZSB1bm5lY2Vzc2FyeSBwZW5kaW5nIG1lc3NhZ2VzKS5cbmNvbnN0IHNldFBlbmRpbmdCYXNlID0gdGhyb3R0bGVGdW5jdGlvbig1MDAsIGZ1bmN0aW9uIHNldFBlbmRpbmdCYXNlKCkge1xuICAgIGZvciAobGV0IFtncm91cCwgbWVzc2FnZV0gb2YgcGVuZGluZ0NhY2hlKSB7XG5cbiAgICAgICAgaWYgKCFtZXNzYWdlKSB7XG4gICAgICAgICAgICBsZXQgbGFzdFNldCA9IHBlbmRpbmdMYXN0U2V0cy5nZXQoZ3JvdXApO1xuICAgICAgICAgICAgaWYgKGxhc3RTZXQpIHtcbiAgICAgICAgICAgICAgICBsZXQgZHVyYXRpb24gPSBEYXRlLm5vdygpIC0gbGFzdFNldDtcbiAgICAgICAgICAgICAgICBpZiAoZHVyYXRpb24gPiA1MDApIHtcbiAgICAgICAgICAgICAgICAgICAgY29uc29sZS5sb2coYEZpbmlzaGVkIHNsb3cgdGFzayBhZnRlciAke2Zvcm1hdFRpbWUoZHVyYXRpb24pfTogJHtKU09OLnN0cmluZ2lmeShncm91cCl9LCBsYXN0IGlzICR7SlNPTi5zdHJpbmdpZnkod2F0Y2hTdGF0ZS5wZW5kaW5nW2dyb3VwXSl9YCk7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIHBlbmRpbmdMYXN0U2V0cy5kZWxldGUoZ3JvdXApO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgZGVsZXRlIHdhdGNoU3RhdGUucGVuZGluZ1tncm91cF07XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAvL2NvbnNvbGUubG9nKFwic2V0UGVuZGluZ1wiLCBncm91cCwgbWVzc2FnZSk7XG4gICAgICAgICAgICBpZiAoIShncm91cCBpbiB3YXRjaFN0YXRlLnBlbmRpbmcpKSB7XG4gICAgICAgICAgICAgICAgcGVuZGluZ0xhc3RTZXRzLnNldChncm91cCwgRGF0ZS5ub3coKSk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICB3YXRjaFN0YXRlLnBlbmRpbmdbZ3JvdXBdID0gbWVzc2FnZTtcbiAgICAgICAgfVxuICAgIH1cbiAgICBwZW5kaW5nQ2FjaGUuY2xlYXIoKTtcbn0pO1xuXG5Ab2JzZXJ2ZXJcbmV4cG9ydCBjbGFzcyBQZW5kaW5nRGlzcGxheSBleHRlbmRzIHByZWFjdC5Db21wb25lbnQge1xuICAgIHJlbmRlcigpIHtcbiAgICAgICAgLy8gU2luZ2xlIGxpbmUsIGdpdmluZyBlcXVhbCBzcGFjZSwgYW5kIGVsbGlwc2lzIGZvciBvdmVyZmxvd1xuICAgICAgICByZXR1cm4gPGRpdiBjbGFzc05hbWU9e2Nzcy5oYm94KDEwKX0+XG4gICAgICAgICAgICB7T2JqZWN0LmtleXMod2F0Y2hTdGF0ZS5wZW5kaW5nKS5tYXAoZ3JvdXAgPT4gKFxuICAgICAgICAgICAgICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MuY2VudGVyLnRleHRPdmVyZmxvdyhcImVsbGlwc2lzXCIpLmJvcmRlcihcIjFweCBzb2xpZCBibGFja1wiKS5wYWQyKDYsIDIpfT5cbiAgICAgICAgICAgICAgICAgICAge2dyb3VwfToge3dhdGNoU3RhdGUucGVuZGluZ1tncm91cF19XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9kaXY+O1xuICAgIH1cbn0iXX0=
73
+ /* _JS_SOURCE_HASH = "8f559dbbe9527016120e06db80675bb022384607e057609b93840bc57618742e"; */
@@ -0,0 +1,49 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true , configurable: true});
3
+ //exports.PendingStorage = void 0;
4
+ const misc_1 = require("socket-function/src/misc");
5
+ const PendingManager_1 = require("./PendingManager");
6
+ class PendingStorage {
7
+ constructor(pendingGroup, storage) {
8
+ this.pendingGroup = pendingGroup;
9
+ this.storage = storage;
10
+ this.pending = new Map();
11
+ this.updatePending = (0, misc_1.throttleFunction)(100, () => {
12
+ let text = Array.from(this.pending.entries()).map(([key, value]) => `${key}: ${value}`).join(", ");
13
+ (0, PendingManager_1.setPending)(this.pendingGroup, text);
14
+ });
15
+ }
16
+ async get(key) {
17
+ return this.watchPending("get", this.storage.get(key));
18
+ }
19
+ async set(key, value) {
20
+ return this.watchPending("set", this.storage.set(key, value));
21
+ }
22
+ async remove(key) {
23
+ return this.watchPending("remove", this.storage.remove(key));
24
+ }
25
+ async getKeys() {
26
+ return this.watchPending("getKeys", this.storage.getKeys());
27
+ }
28
+ async getInfo(key) {
29
+ return this.watchPending("getInfo", this.storage.getInfo(key));
30
+ }
31
+ watchPending(type, promise) {
32
+ this.pending.set(type, (this.pending.get(type) || 0) + 1);
33
+ void this.updatePending();
34
+ void promise.finally(() => {
35
+ this.pending.set(type, (this.pending.get(type) || 0) - 1);
36
+ if (this.pending.get(type) === 0) {
37
+ this.pending.delete(type);
38
+ }
39
+ void this.updatePending();
40
+ });
41
+ return promise;
42
+ }
43
+ async reset() {
44
+ return this.storage.reset();
45
+ }
46
+ }
47
+ exports.PendingStorage = PendingStorage;
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUGVuZGluZ1N0b3JhZ2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJQZW5kaW5nU3RvcmFnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtREFBNEQ7QUFFNUQscURBQThDO0FBRTlDLE1BQWEsY0FBYztJQUV2QixZQUNZLFlBQW9CLEVBQ3BCLE9BQW9CO1FBRHBCLGlCQUFZLEdBQVosWUFBWSxDQUFRO1FBQ3BCLFlBQU8sR0FBUCxPQUFPLENBQWE7UUFIaEMsWUFBTyxHQUFHLElBQUksR0FBRyxFQUFrQixDQUFDO1FBaUM1QixrQkFBYSxHQUFHLElBQUEsdUJBQWdCLEVBQUMsR0FBRyxFQUFFLEdBQUcsRUFBRTtZQUMvQyxJQUFJLElBQUksR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsRUFBRSxFQUFFLENBQUMsR0FBRyxHQUFHLEtBQUssS0FBSyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDbkcsSUFBQSwyQkFBVSxFQUFDLElBQUksQ0FBQyxZQUFZLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDeEMsQ0FBQyxDQUFDLENBQUM7SUFoQ0MsQ0FBQztJQUNFLEtBQUssQ0FBQyxHQUFHLENBQUMsR0FBVztRQUN4QixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUNNLEtBQUssQ0FBQyxHQUFHLENBQUMsR0FBVyxFQUFFLEtBQVE7UUFDbEMsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUNsRSxDQUFDO0lBQ00sS0FBSyxDQUFDLE1BQU0sQ0FBQyxHQUFXO1FBQzNCLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztJQUNqRSxDQUFDO0lBQ00sS0FBSyxDQUFDLE9BQU87UUFDaEIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7SUFDaEUsQ0FBQztJQUNNLEtBQUssQ0FBQyxPQUFPLENBQUMsR0FBVztRQUM1QixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDbkUsQ0FBQztJQUVPLFlBQVksQ0FBSSxJQUFZLEVBQUUsT0FBbUI7UUFDckQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDMUQsS0FBSyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7UUFDMUIsS0FBSyxPQUFPLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRTtZQUN0QixJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztZQUMxRCxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO2dCQUMvQixJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUM5QixDQUFDO1lBQ0QsS0FBSyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7UUFDOUIsQ0FBQyxDQUFDLENBQUM7UUFDSCxPQUFPLE9BQU8sQ0FBQztJQUNuQixDQUFDO0lBTU0sS0FBSyxDQUFDLEtBQUs7UUFDZCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDaEMsQ0FBQztDQUNKO0FBMUNELHdDQTBDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHRocm90dGxlRnVuY3Rpb24gfSBmcm9tIFwic29ja2V0LWZ1bmN0aW9uL3NyYy9taXNjXCI7XG5pbXBvcnQgeyBJU3RvcmFnZSB9IGZyb20gXCIuL0lTdG9yYWdlXCI7XG5pbXBvcnQgeyBzZXRQZW5kaW5nIH0gZnJvbSBcIi4vUGVuZGluZ01hbmFnZXJcIjtcblxuZXhwb3J0IGNsYXNzIFBlbmRpbmdTdG9yYWdlPFQ+IGltcGxlbWVudHMgSVN0b3JhZ2U8VD4ge1xuICAgIHBlbmRpbmcgPSBuZXcgTWFwPHN0cmluZywgbnVtYmVyPigpO1xuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIHBlbmRpbmdHcm91cDogc3RyaW5nLFxuICAgICAgICBwcml2YXRlIHN0b3JhZ2U6IElTdG9yYWdlPFQ+LFxuICAgICkgeyB9XG4gICAgcHVibGljIGFzeW5jIGdldChrZXk6IHN0cmluZyk6IFByb21pc2U8VCB8IHVuZGVmaW5lZD4ge1xuICAgICAgICByZXR1cm4gdGhpcy53YXRjaFBlbmRpbmcoXCJnZXRcIiwgdGhpcy5zdG9yYWdlLmdldChrZXkpKTtcbiAgICB9XG4gICAgcHVibGljIGFzeW5jIHNldChrZXk6IHN0cmluZywgdmFsdWU6IFQpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMud2F0Y2hQZW5kaW5nKFwic2V0XCIsIHRoaXMuc3RvcmFnZS5zZXQoa2V5LCB2YWx1ZSkpO1xuICAgIH1cbiAgICBwdWJsaWMgYXN5bmMgcmVtb3ZlKGtleTogc3RyaW5nKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgICAgIHJldHVybiB0aGlzLndhdGNoUGVuZGluZyhcInJlbW92ZVwiLCB0aGlzLnN0b3JhZ2UucmVtb3ZlKGtleSkpO1xuICAgIH1cbiAgICBwdWJsaWMgYXN5bmMgZ2V0S2V5cygpOiBQcm9taXNlPHN0cmluZ1tdPiB7XG4gICAgICAgIHJldHVybiB0aGlzLndhdGNoUGVuZGluZyhcImdldEtleXNcIiwgdGhpcy5zdG9yYWdlLmdldEtleXMoKSk7XG4gICAgfVxuICAgIHB1YmxpYyBhc3luYyBnZXRJbmZvKGtleTogc3RyaW5nKSB7XG4gICAgICAgIHJldHVybiB0aGlzLndhdGNoUGVuZGluZyhcImdldEluZm9cIiwgdGhpcy5zdG9yYWdlLmdldEluZm8oa2V5KSk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSB3YXRjaFBlbmRpbmc8VD4odHlwZTogc3RyaW5nLCBwcm9taXNlOiBQcm9taXNlPFQ+KTogUHJvbWlzZTxUPiB7XG4gICAgICAgIHRoaXMucGVuZGluZy5zZXQodHlwZSwgKHRoaXMucGVuZGluZy5nZXQodHlwZSkgfHwgMCkgKyAxKTtcbiAgICAgICAgdm9pZCB0aGlzLnVwZGF0ZVBlbmRpbmcoKTtcbiAgICAgICAgdm9pZCBwcm9taXNlLmZpbmFsbHkoKCkgPT4ge1xuICAgICAgICAgICAgdGhpcy5wZW5kaW5nLnNldCh0eXBlLCAodGhpcy5wZW5kaW5nLmdldCh0eXBlKSB8fCAwKSAtIDEpO1xuICAgICAgICAgICAgaWYgKHRoaXMucGVuZGluZy5nZXQodHlwZSkgPT09IDApIHtcbiAgICAgICAgICAgICAgICB0aGlzLnBlbmRpbmcuZGVsZXRlKHR5cGUpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgdm9pZCB0aGlzLnVwZGF0ZVBlbmRpbmcoKTtcbiAgICAgICAgfSk7XG4gICAgICAgIHJldHVybiBwcm9taXNlO1xuICAgIH1cbiAgICBwcml2YXRlIHVwZGF0ZVBlbmRpbmcgPSB0aHJvdHRsZUZ1bmN0aW9uKDEwMCwgKCkgPT4ge1xuICAgICAgICBsZXQgdGV4dCA9IEFycmF5LmZyb20odGhpcy5wZW5kaW5nLmVudHJpZXMoKSkubWFwKChba2V5LCB2YWx1ZV0pID0+IGAke2tleX06ICR7dmFsdWV9YCkuam9pbihcIiwgXCIpO1xuICAgICAgICBzZXRQZW5kaW5nKHRoaXMucGVuZGluZ0dyb3VwLCB0ZXh0KTtcbiAgICB9KTtcblxuICAgIHB1YmxpYyBhc3luYyByZXNldCgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuc3RvcmFnZS5yZXNldCgpO1xuICAgIH1cbn0iXX0=
49
+ /* _JS_SOURCE_HASH = "ed2840ea8600cecb451e492c01363588df0ab65b7e5c4231cffb60d15727a4b6"; */
@@ -0,0 +1,178 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true , configurable: true});
3
+ //exports.PrivateFileSystemStorage = void 0;
4
+ class PrivateFileSystemStorage {
5
+ constructor(path) {
6
+ this.path = path;
7
+ }
8
+ async ensureInitialized() {
9
+ var _a;
10
+ if (!this.rootHandle) {
11
+ if (!((_a = navigator.storage) === null || _a === void 0 ? void 0 : _a.getDirectory)) {
12
+ throw new Error("Private File System Access API not supported in this browser");
13
+ }
14
+ this.rootHandle = await navigator.storage.getDirectory();
15
+ }
16
+ return this.rootHandle;
17
+ }
18
+ async directoryExists() {
19
+ try {
20
+ const root = await this.ensureInitialized();
21
+ if (!this.path || this.path === "" || this.path === "/") {
22
+ return true; // Root always exists
23
+ }
24
+ const pathParts = this.path.split("/").filter(part => part.length > 0);
25
+ let currentHandle = root;
26
+ for (const part of pathParts) {
27
+ try {
28
+ currentHandle = await currentHandle.getDirectoryHandle(part);
29
+ }
30
+ catch (error) {
31
+ return false;
32
+ }
33
+ }
34
+ return true;
35
+ }
36
+ catch (error) {
37
+ return false;
38
+ }
39
+ }
40
+ async getDirectoryHandle(createPath = true) {
41
+ const root = await this.ensureInitialized();
42
+ if (!this.path || this.path === "" || this.path === "/") {
43
+ return root;
44
+ }
45
+ const pathParts = this.path.split("/").filter(part => part.length > 0);
46
+ let currentHandle = root;
47
+ for (const part of pathParts) {
48
+ try {
49
+ currentHandle = await currentHandle.getDirectoryHandle(part, { create: createPath });
50
+ }
51
+ catch (error) {
52
+ if (!createPath) {
53
+ throw new Error(`Directory not found: ${this.path}`);
54
+ }
55
+ throw error;
56
+ }
57
+ }
58
+ return currentHandle;
59
+ }
60
+ async getFileHandle(key, create = false) {
61
+ try {
62
+ const dirHandle = await this.getDirectoryHandle(create);
63
+ return await dirHandle.getFileHandle(key, { create });
64
+ }
65
+ catch (error) {
66
+ return undefined;
67
+ }
68
+ }
69
+ async fileExists(key) {
70
+ try {
71
+ // First check if directory exists
72
+ if (!(await this.directoryExists())) {
73
+ return false;
74
+ }
75
+ const dirHandle = await this.getDirectoryHandle(false);
76
+ await dirHandle.getFileHandle(key);
77
+ return true;
78
+ }
79
+ catch (error) {
80
+ return false;
81
+ }
82
+ }
83
+ async get(key) {
84
+ // Check if file exists first to avoid unnecessary errors
85
+ if (!(await this.fileExists(key))) {
86
+ return undefined;
87
+ }
88
+ try {
89
+ const fileHandle = await this.getFileHandle(key, false);
90
+ if (!fileHandle) {
91
+ return undefined;
92
+ }
93
+ const file = await fileHandle.getFile();
94
+ const arrayBuffer = await file.arrayBuffer();
95
+ return Buffer.from(arrayBuffer);
96
+ }
97
+ catch (error) {
98
+ console.warn(`Error reading file ${key}:`, error);
99
+ return undefined;
100
+ }
101
+ }
102
+ async set(key, value) {
103
+ try {
104
+ const fileHandle = await this.getFileHandle(key, true);
105
+ if (!fileHandle) {
106
+ throw new Error(`Failed to create file handle for key: ${key}`);
107
+ }
108
+ const writable = await fileHandle.createWritable();
109
+ await writable.write(value);
110
+ await writable.close();
111
+ }
112
+ catch (error) {
113
+ throw new Error(`Failed to write file ${key}: ${error}`);
114
+ }
115
+ }
116
+ async append(key, value) {
117
+ const existingContent = await this.get(key);
118
+ let newContent;
119
+ if (existingContent) {
120
+ newContent = Buffer.concat([existingContent, value]);
121
+ }
122
+ else {
123
+ newContent = value;
124
+ }
125
+ await this.set(key, newContent);
126
+ }
127
+ async remove(key) {
128
+ // Check if file exists first to avoid unnecessary errors
129
+ if (!(await this.fileExists(key))) {
130
+ return; // File doesn't exist, nothing to remove
131
+ }
132
+ try {
133
+ const dirHandle = await this.getDirectoryHandle(false);
134
+ await dirHandle.removeEntry(key);
135
+ }
136
+ catch (_a) { }
137
+ }
138
+ async getKeys() {
139
+ // Check if directory exists first to avoid unnecessary errors
140
+ if (!(await this.directoryExists())) {
141
+ return [];
142
+ }
143
+ try {
144
+ const dirHandle = await this.getDirectoryHandle(false);
145
+ const keys = [];
146
+ // Use the async iterator protocol for FileSystemDirectoryHandle
147
+ for await (const [name, handle] of dirHandle.entries()) {
148
+ if (handle.kind === "file") {
149
+ keys.push(name);
150
+ }
151
+ }
152
+ return keys.sort();
153
+ }
154
+ catch (error) {
155
+ if (error instanceof Error && error.message.includes("Directory not found")) {
156
+ return [];
157
+ }
158
+ throw new Error(`Failed to list files: ${error}`);
159
+ }
160
+ }
161
+ async getInfo(key) {
162
+ let fileHandle = await this.getFileHandle(key, false);
163
+ if (!fileHandle) {
164
+ return undefined;
165
+ }
166
+ let file = await fileHandle.getFile();
167
+ return {
168
+ size: file.size,
169
+ lastModified: file.lastModified,
170
+ };
171
+ }
172
+ async reset() {
173
+ throw new Error("Not implemented");
174
+ }
175
+ }
176
+ exports.PrivateFileSystemStorage = PrivateFileSystemStorage;
177
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PrivateFileSystemStorage.js","sourceRoot":"","sources":["PrivateFileSystemStorage.ts"],"names":[],"mappings":"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","sourcesContent":["import { IStorageRaw } from \"./IStorage\";\n\nexport class PrivateFileSystemStorage implements IStorageRaw {\n    private rootHandle: FileSystemDirectoryHandle | undefined;\n\n    constructor(private path: string) { }\n\n    private async ensureInitialized(): Promise<FileSystemDirectoryHandle> {\n        if (!this.rootHandle) {\n            if (!navigator.storage?.getDirectory) {\n                throw new Error(\"Private File System Access API not supported in this browser\");\n            }\n            this.rootHandle = await navigator.storage.getDirectory();\n        }\n        return this.rootHandle;\n    }\n\n    private async directoryExists(): Promise<boolean> {\n        try {\n            const root = await this.ensureInitialized();\n\n            if (!this.path || this.path === \"\" || this.path === \"/\") {\n                return true; // Root always exists\n            }\n\n            const pathParts = this.path.split(\"/\").filter(part => part.length > 0);\n            let currentHandle = root;\n\n            for (const part of pathParts) {\n                try {\n                    currentHandle = await currentHandle.getDirectoryHandle(part);\n                } catch (error) {\n                    return false;\n                }\n            }\n\n            return true;\n        } catch (error) {\n            return false;\n        }\n    }\n\n    private async getDirectoryHandle(createPath: boolean = true): Promise<FileSystemDirectoryHandle> {\n        const root = await this.ensureInitialized();\n\n        if (!this.path || this.path === \"\" || this.path === \"/\") {\n            return root;\n        }\n\n        const pathParts = this.path.split(\"/\").filter(part => part.length > 0);\n        let currentHandle = root;\n\n        for (const part of pathParts) {\n            try {\n                currentHandle = await currentHandle.getDirectoryHandle(part, { create: createPath });\n            } catch (error) {\n                if (!createPath) {\n                    throw new Error(`Directory not found: ${this.path}`);\n                }\n                throw error;\n            }\n        }\n\n        return currentHandle;\n    }\n\n    private async getFileHandle(key: string, create: boolean = false): Promise<FileSystemFileHandle | undefined> {\n        try {\n            const dirHandle = await this.getDirectoryHandle(create);\n            return await dirHandle.getFileHandle(key, { create });\n        } catch (error) {\n            return undefined;\n        }\n    }\n\n    private async fileExists(key: string): Promise<boolean> {\n        try {\n            // First check if directory exists\n            if (!(await this.directoryExists())) {\n                return false;\n            }\n\n            const dirHandle = await this.getDirectoryHandle(false);\n            await dirHandle.getFileHandle(key);\n            return true;\n        } catch (error) {\n            return false;\n        }\n    }\n\n    public async get(key: string): Promise<Buffer | undefined> {\n        // Check if file exists first to avoid unnecessary errors\n        if (!(await this.fileExists(key))) {\n            return undefined;\n        }\n\n        try {\n            const fileHandle = await this.getFileHandle(key, false);\n            if (!fileHandle) {\n                return undefined;\n            }\n\n            const file = await fileHandle.getFile();\n            const arrayBuffer = await file.arrayBuffer();\n            return Buffer.from(arrayBuffer);\n        } catch (error) {\n            console.warn(`Error reading file ${key}:`, error);\n            return undefined;\n        }\n    }\n\n    public async set(key: string, value: Buffer): Promise<void> {\n        try {\n            const fileHandle = await this.getFileHandle(key, true);\n            if (!fileHandle) {\n                throw new Error(`Failed to create file handle for key: ${key}`);\n            }\n\n            const writable = await fileHandle.createWritable();\n            await writable.write(value);\n            await writable.close();\n        } catch (error) {\n            throw new Error(`Failed to write file ${key}: ${error}`);\n        }\n    }\n\n    public async append(key: string, value: Buffer): Promise<void> {\n        const existingContent = await this.get(key);\n        let newContent: Buffer;\n        if (existingContent) {\n            newContent = Buffer.concat([existingContent, value]);\n        } else {\n            newContent = value;\n        }\n        await this.set(key, newContent);\n    }\n\n    public async remove(key: string): Promise<void> {\n        // Check if file exists first to avoid unnecessary errors\n        if (!(await this.fileExists(key))) {\n            return; // File doesn't exist, nothing to remove\n        }\n\n        try {\n            const dirHandle = await this.getDirectoryHandle(false);\n            await dirHandle.removeEntry(key);\n        } catch { }\n    }\n\n    public async getKeys(): Promise<string[]> {\n        // Check if directory exists first to avoid unnecessary errors\n        if (!(await this.directoryExists())) {\n            return [];\n        }\n\n        try {\n            const dirHandle = await this.getDirectoryHandle(false);\n            const keys: string[] = [];\n\n            // Use the async iterator protocol for FileSystemDirectoryHandle\n            for await (const [name, handle] of (dirHandle as any).entries()) {\n                if (handle.kind === \"file\") {\n                    keys.push(name);\n                }\n            }\n\n            return keys.sort();\n        } catch (error) {\n            if (error instanceof Error && error.message.includes(\"Directory not found\")) {\n                return [];\n            }\n            throw new Error(`Failed to list files: ${error}`);\n        }\n    }\n    public async getInfo(key: string): Promise<undefined | {\n        size: number;\n        lastModified: number;\n    }> {\n        let fileHandle = await this.getFileHandle(key, false);\n        if (!fileHandle) {\n            return undefined;\n        }\n        let file = await fileHandle.getFile();\n        return {\n            size: file.size,\n            lastModified: file.lastModified,\n        };\n    }\n    public async reset(): Promise<void> {\n        throw new Error(\"Not implemented\");\n    }\n}"]}
178
+ /* _JS_SOURCE_HASH = "148396348ae7c1ec76d652412f67620680447daaa3a8cfe83212b76412f8bc73"; */
@@ -0,0 +1,120 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true , configurable: true});
3
+ //exports.StorageSync = void 0;
4
+ const mobxTyped_1 = require("../misc/mobxTyped");
5
+ const types_1 = require("../misc/types");
6
+ // NOTE: At around 500K values (depending on their size to some degree), this will take about 2 minutes to load. But once it does it will be fast. So... keep that in mind. I recommend not exceeding 100K
7
+ class StorageSync {
8
+ constructor(storage) {
9
+ this.storage = storage;
10
+ this.cached = mobxTyped_1.observable.map(undefined, { deep: false });
11
+ this.infoCached = mobxTyped_1.observable.map(undefined, { deep: false });
12
+ this.keys = new Set();
13
+ this.synced = (0, mobxTyped_1.observable)({
14
+ keySeqNum: 0,
15
+ }, undefined, { deep: false });
16
+ this.loadedKeys = false;
17
+ }
18
+ get(key) {
19
+ if (!this.cached.has(key)) {
20
+ this.cached.set(key, undefined);
21
+ void this.getPromise(key);
22
+ }
23
+ if (this.cached.get(key) === undefined) {
24
+ this.synced.keySeqNum;
25
+ }
26
+ return this.cached.get(key);
27
+ }
28
+ set(key, value) {
29
+ if (!this.keys.has(key)) {
30
+ this.keys.add(key);
31
+ this.synced.keySeqNum++;
32
+ }
33
+ this.cached.set(key, value);
34
+ void this.storage.set(key, value);
35
+ }
36
+ remove(key) {
37
+ if (this.keys.has(key)) {
38
+ this.keys.delete(key);
39
+ this.synced.keySeqNum++;
40
+ }
41
+ this.cached.delete(key);
42
+ void this.storage.remove(key);
43
+ }
44
+ getKeys() {
45
+ void this.getKeysPromise();
46
+ this.synced.keySeqNum;
47
+ return Array.from(this.keys);
48
+ }
49
+ getInfo(key) {
50
+ if (!this.infoCached.has(key)) {
51
+ this.infoCached.set(key, { size: 0, lastModified: 0 });
52
+ void this.storage.getInfo(key).then(info => {
53
+ this.infoCached.set(key, info);
54
+ });
55
+ }
56
+ return this.infoCached.get(key);
57
+ }
58
+ getValues() {
59
+ let keys = this.getKeys();
60
+ return keys.map(key => this.get(key)).filter(types_1.isDefined);
61
+ }
62
+ getEntries() {
63
+ let keys = this.getKeys();
64
+ return keys.map(key => [key, this.get(key)]).filter(([_, value]) => (0, types_1.isDefined)(value));
65
+ }
66
+ async getPromise(key) {
67
+ let value = this.cached.get(key);
68
+ if (value === undefined) {
69
+ value = await this.storage.get(key);
70
+ if (this.cached.get(key) === undefined) {
71
+ this.cached.set(key, value);
72
+ }
73
+ }
74
+ return value;
75
+ }
76
+ async getKeysPromise() {
77
+ if (this.pendingGetKeys) {
78
+ return this.pendingGetKeys;
79
+ }
80
+ if (this.loadedKeys)
81
+ return Array.from(this.keys);
82
+ this.loadedKeys = true;
83
+ this.pendingGetKeys = this.storage.getKeys();
84
+ void this.pendingGetKeys.finally(() => {
85
+ this.pendingGetKeys = undefined;
86
+ });
87
+ let keys = await this.pendingGetKeys;
88
+ if (keys.length > 0) {
89
+ this.keys = new Set(keys);
90
+ this.synced.keySeqNum++;
91
+ }
92
+ return Array.from(this.keys);
93
+ }
94
+ reload() {
95
+ this.loadedKeys = false;
96
+ this.synced.keySeqNum++;
97
+ this.cached.clear();
98
+ this.infoCached.clear();
99
+ this.keys.clear();
100
+ }
101
+ reloadKeys() {
102
+ this.loadedKeys = false;
103
+ this.synced.keySeqNum++;
104
+ }
105
+ reloadKey(key) {
106
+ this.cached.delete(key);
107
+ this.infoCached.delete(key);
108
+ this.keys.delete(key);
109
+ }
110
+ async reset() {
111
+ this.cached.clear();
112
+ this.infoCached.clear();
113
+ this.keys.clear();
114
+ this.synced.keySeqNum++;
115
+ await this.storage.reset();
116
+ }
117
+ }
118
+ exports.StorageSync = StorageSync;
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"StorageObservable.js","sourceRoot":"","sources":["StorageObservable.ts"],"names":[],"mappings":"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","sourcesContent":["import { observable } from \"../misc/mobxTyped\";\nimport { isDefined } from \"../misc/types\";\nimport { IStorage, IStorageSync } from \"./IStorage\";\n\n// NOTE: At around 500K values (depending on their size to some degree), this will take about 2 minutes to load. But once it does it will be fast. So... keep that in mind. I recommend not exceeding 100K\nexport class StorageSync<T> implements IStorageSync<T> {\n    cached = observable.map<string, T | undefined>(undefined, { deep: false });\n    infoCached = observable.map<string, { size: number; lastModified: number } | undefined>(undefined, { deep: false });\n    keys = new Set<string>();\n    synced = observable({\n        keySeqNum: 0,\n    }, undefined, { deep: false });\n\n    constructor(public storage: IStorage<T>) { }\n\n    public get(key: string): T | undefined {\n        if (!this.cached.has(key)) {\n            this.cached.set(key, undefined);\n            void this.getPromise(key);\n        }\n        if (this.cached.get(key) === undefined) {\n            this.synced.keySeqNum;\n        }\n        return this.cached.get(key);\n    }\n    public set(key: string, value: T): void {\n        if (!this.keys.has(key)) {\n            this.keys.add(key);\n            this.synced.keySeqNum++;\n        }\n        this.cached.set(key, value);\n        void this.storage.set(key, value);\n    }\n    public remove(key: string): void {\n        if (this.keys.has(key)) {\n            this.keys.delete(key);\n            this.synced.keySeqNum++;\n        }\n        this.cached.delete(key);\n        void this.storage.remove(key);\n    }\n    private loadedKeys = false;\n    public getKeys(): string[] {\n        void this.getKeysPromise();\n        this.synced.keySeqNum;\n        return Array.from(this.keys);\n    }\n\n    public getInfo(key: string): { size: number; lastModified: number } | undefined {\n        if (!this.infoCached.has(key)) {\n            this.infoCached.set(key, { size: 0, lastModified: 0 });\n            void this.storage.getInfo(key).then(info => {\n                this.infoCached.set(key, info);\n            });\n        }\n        return this.infoCached.get(key);\n    }\n\n    public getValues(): T[] {\n        let keys = this.getKeys();\n        return keys.map(key => this.get(key)).filter(isDefined);\n    }\n    public getEntries(): [string, T][] {\n        let keys = this.getKeys();\n        return keys.map(key => [key, this.get(key)]).filter(([_, value]) => isDefined(value)) as [string, T][];\n    }\n\n\n    public async getPromise(key: string): Promise<T | undefined> {\n        let value = this.cached.get(key);\n        if (value === undefined) {\n            value = await this.storage.get(key);\n            if (this.cached.get(key) === undefined) {\n                this.cached.set(key, value);\n            }\n        }\n        return value;\n    }\n    private pendingGetKeys: Promise<string[]> | undefined;\n    public async getKeysPromise(): Promise<string[]> {\n        if (this.pendingGetKeys) {\n            return this.pendingGetKeys;\n        }\n        if (this.loadedKeys) return Array.from(this.keys);\n        this.loadedKeys = true;\n        this.pendingGetKeys = this.storage.getKeys();\n        void this.pendingGetKeys.finally(() => {\n            this.pendingGetKeys = undefined;\n        });\n        let keys = await this.pendingGetKeys;\n        if (keys.length > 0) {\n            this.keys = new Set(keys);\n            this.synced.keySeqNum++;\n        }\n        return Array.from(this.keys);\n    }\n\n    public reload() {\n        this.loadedKeys = false;\n        this.synced.keySeqNum++;\n        this.cached.clear();\n        this.infoCached.clear();\n        this.keys.clear();\n    }\n    public reloadKeys() {\n        this.loadedKeys = false;\n        this.synced.keySeqNum++;\n    }\n    public reloadKey(key: string) {\n        this.cached.delete(key);\n        this.infoCached.delete(key);\n        this.keys.delete(key);\n    }\n\n    public async reset() {\n        this.cached.clear();\n        this.infoCached.clear();\n        this.keys.clear();\n        this.synced.keySeqNum++;\n        await this.storage.reset();\n    }\n}"]}
120
+ /* _JS_SOURCE_HASH = "83f7e3709b75068426ee34cfb27c8af75bbde2d429ccc896355bd2c176744eaa"; */