mvc-kit 2.12.4 → 2.13.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/agent-config/bin/postinstall.mjs +4 -3
- package/agent-config/bin/setup.mjs +5 -1
- package/agent-config/claude-code/agents/mvc-kit-architect.md +11 -8
- package/agent-config/claude-code/skills/guide/SKILL.md +20 -7
- package/agent-config/claude-code/skills/guide/patterns.md +12 -0
- package/agent-config/claude-code/skills/guide/recipes.md +510 -0
- package/agent-config/claude-code/skills/guide/testing.md +297 -0
- package/agent-config/claude-code/skills/review/SKILL.md +3 -13
- package/agent-config/claude-code/skills/review/checklist.md +30 -5
- package/agent-config/claude-code/skills/scaffold/SKILL.md +4 -13
- package/agent-config/lib/install-claude.mjs +84 -25
- package/dist/Channel.cjs +276 -300
- package/dist/Channel.cjs.map +1 -1
- package/dist/Channel.js +275 -299
- package/dist/Channel.js.map +1 -1
- package/dist/Collection.cjs +424 -504
- package/dist/Collection.cjs.map +1 -1
- package/dist/Collection.js +423 -503
- package/dist/Collection.js.map +1 -1
- package/dist/Controller.cjs +70 -67
- package/dist/Controller.cjs.map +1 -1
- package/dist/Controller.js +69 -66
- package/dist/Controller.js.map +1 -1
- package/dist/EventBus.cjs +77 -88
- package/dist/EventBus.cjs.map +1 -1
- package/dist/EventBus.js +76 -87
- package/dist/EventBus.js.map +1 -1
- package/dist/Feed.cjs +81 -77
- package/dist/Feed.cjs.map +1 -1
- package/dist/Feed.js +80 -76
- package/dist/Feed.js.map +1 -1
- package/dist/Model.cjs +181 -207
- package/dist/Model.cjs.map +1 -1
- package/dist/Model.js +179 -205
- package/dist/Model.js.map +1 -1
- package/dist/Pagination.cjs +75 -73
- package/dist/Pagination.cjs.map +1 -1
- package/dist/Pagination.js +74 -72
- package/dist/Pagination.js.map +1 -1
- package/dist/Pending.cjs +255 -287
- package/dist/Pending.cjs.map +1 -1
- package/dist/Pending.js +253 -285
- package/dist/Pending.js.map +1 -1
- package/dist/PersistentCollection.cjs +242 -285
- package/dist/PersistentCollection.cjs.map +1 -1
- package/dist/PersistentCollection.js +241 -284
- package/dist/PersistentCollection.js.map +1 -1
- package/dist/Resource.cjs +166 -174
- package/dist/Resource.cjs.map +1 -1
- package/dist/Resource.js +164 -172
- package/dist/Resource.js.map +1 -1
- package/dist/Selection.cjs +84 -94
- package/dist/Selection.cjs.map +1 -1
- package/dist/Selection.js +83 -93
- package/dist/Selection.js.map +1 -1
- package/dist/Service.cjs +54 -55
- package/dist/Service.cjs.map +1 -1
- package/dist/Service.js +53 -54
- package/dist/Service.js.map +1 -1
- package/dist/Sorting.cjs +102 -101
- package/dist/Sorting.cjs.map +1 -1
- package/dist/Sorting.js +102 -101
- package/dist/Sorting.js.map +1 -1
- package/dist/Trackable.cjs +112 -80
- package/dist/Trackable.cjs.map +1 -1
- package/dist/Trackable.js +111 -79
- package/dist/Trackable.js.map +1 -1
- package/dist/ViewModel.cjs +528 -576
- package/dist/ViewModel.cjs.map +1 -1
- package/dist/ViewModel.js +525 -573
- package/dist/ViewModel.js.map +1 -1
- package/dist/bindPublicMethods.cjs +43 -24
- package/dist/bindPublicMethods.cjs.map +1 -1
- package/dist/bindPublicMethods.js +43 -24
- package/dist/bindPublicMethods.js.map +1 -1
- package/dist/errors.cjs +67 -68
- package/dist/errors.cjs.map +1 -1
- package/dist/errors.js +68 -71
- package/dist/errors.js.map +1 -1
- package/dist/mvc-kit.cjs +44 -46
- package/dist/mvc-kit.js +5 -32
- package/dist/produceDraft.cjs +105 -95
- package/dist/produceDraft.cjs.map +1 -1
- package/dist/produceDraft.js +106 -97
- package/dist/produceDraft.js.map +1 -1
- package/dist/react/components/CardList.cjs +30 -40
- package/dist/react/components/CardList.cjs.map +1 -1
- package/dist/react/components/CardList.js +31 -41
- package/dist/react/components/CardList.js.map +1 -1
- package/dist/react/components/DataTable.cjs +146 -169
- package/dist/react/components/DataTable.cjs.map +1 -1
- package/dist/react/components/DataTable.js +147 -170
- package/dist/react/components/DataTable.js.map +1 -1
- package/dist/react/components/InfiniteScroll.cjs +51 -42
- package/dist/react/components/InfiniteScroll.cjs.map +1 -1
- package/dist/react/components/InfiniteScroll.js +52 -43
- package/dist/react/components/InfiniteScroll.js.map +1 -1
- package/dist/react/components/types.cjs +10 -6
- package/dist/react/components/types.cjs.map +1 -1
- package/dist/react/components/types.js +11 -9
- package/dist/react/components/types.js.map +1 -1
- package/dist/react/guards.cjs +10 -6
- package/dist/react/guards.cjs.map +1 -1
- package/dist/react/guards.js +11 -9
- package/dist/react/guards.js.map +1 -1
- package/dist/react/provider.cjs +23 -20
- package/dist/react/provider.cjs.map +1 -1
- package/dist/react/provider.js +23 -21
- package/dist/react/provider.js.map +1 -1
- package/dist/react/use-event-bus.cjs +24 -20
- package/dist/react/use-event-bus.cjs.map +1 -1
- package/dist/react/use-event-bus.js +24 -21
- package/dist/react/use-event-bus.js.map +1 -1
- package/dist/react/use-instance.cjs +43 -36
- package/dist/react/use-instance.cjs.map +1 -1
- package/dist/react/use-instance.js +43 -36
- package/dist/react/use-instance.js.map +1 -1
- package/dist/react/use-local.cjs +48 -64
- package/dist/react/use-local.cjs.map +1 -1
- package/dist/react/use-local.js +47 -63
- package/dist/react/use-local.js.map +1 -1
- package/dist/react/use-model.cjs +84 -98
- package/dist/react/use-model.cjs.map +1 -1
- package/dist/react/use-model.js +84 -100
- package/dist/react/use-model.js.map +1 -1
- package/dist/react/use-singleton.cjs +19 -23
- package/dist/react/use-singleton.cjs.map +1 -1
- package/dist/react/use-singleton.js +16 -20
- package/dist/react/use-singleton.js.map +1 -1
- package/dist/react/use-subscribe-only.cjs +28 -22
- package/dist/react/use-subscribe-only.cjs.map +1 -1
- package/dist/react/use-subscribe-only.js +28 -22
- package/dist/react/use-subscribe-only.js.map +1 -1
- package/dist/react/use-teardown.cjs +20 -19
- package/dist/react/use-teardown.cjs.map +1 -1
- package/dist/react/use-teardown.js +20 -19
- package/dist/react/use-teardown.js.map +1 -1
- package/dist/react-native/NativeCollection.cjs +98 -78
- package/dist/react-native/NativeCollection.cjs.map +1 -1
- package/dist/react-native/NativeCollection.js +97 -77
- package/dist/react-native/NativeCollection.js.map +1 -1
- package/dist/react-native.cjs +2 -4
- package/dist/react-native.js +1 -4
- package/dist/react.cjs +24 -26
- package/dist/react.js +1 -17
- package/dist/singleton.cjs +28 -22
- package/dist/singleton.cjs.map +1 -1
- package/dist/singleton.js +29 -26
- package/dist/singleton.js.map +1 -1
- package/dist/walkPrototypeChain.cjs +20 -12
- package/dist/walkPrototypeChain.cjs.map +1 -1
- package/dist/walkPrototypeChain.js +21 -13
- package/dist/walkPrototypeChain.js.map +1 -1
- package/dist/web/IndexedDBCollection.cjs +53 -36
- package/dist/web/IndexedDBCollection.cjs.map +1 -1
- package/dist/web/IndexedDBCollection.js +52 -35
- package/dist/web/IndexedDBCollection.js.map +1 -1
- package/dist/web/WebStorageCollection.cjs +82 -84
- package/dist/web/WebStorageCollection.cjs.map +1 -1
- package/dist/web/WebStorageCollection.js +81 -83
- package/dist/web/WebStorageCollection.js.map +1 -1
- package/dist/web/idb.cjs +107 -99
- package/dist/web/idb.cjs.map +1 -1
- package/dist/web/idb.js +108 -105
- package/dist/web/idb.js.map +1 -1
- package/dist/web.cjs +4 -6
- package/dist/web.js +1 -5
- package/dist/wrapAsyncMethods.cjs +141 -168
- package/dist/wrapAsyncMethods.cjs.map +1 -1
- package/dist/wrapAsyncMethods.js +141 -168
- package/dist/wrapAsyncMethods.js.map +1 -1
- package/package.json +8 -8
- package/src/Pending.test.ts +1 -2
- package/src/Sorting.test.ts +1 -1
- package/src/produceDraft.test.ts +3 -3
- package/src/react/components/CardList.test.tsx +1 -1
- package/src/react/components/DataTable.test.tsx +1 -1
- package/src/react/components/InfiniteScroll.test.tsx +5 -5
- package/dist/mvc-kit.cjs.map +0 -1
- package/dist/mvc-kit.js.map +0 -1
- package/dist/react-native.cjs.map +0 -1
- package/dist/react-native.js.map +0 -1
- package/dist/react.cjs.map +0 -1
- package/dist/react.js.map +0 -1
- package/dist/web.cjs.map +0 -1
- package/dist/web.js.map +0 -1
package/dist/web/idb.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"idb.cjs","sources":["../../src/web/idb.ts"],"sourcesContent":["/**\n * Shared IndexedDB connection manager.\n * Deduplicates indexedDB.open() calls and handles dynamic object store creation\n * by bumping the DB version when a new storageKey is encountered.\n */\n\nconst _connections = new Map<string, IDBDatabase>();\nconst _stores = new Map<string, Set<string>>(); // dbName → known store names\nlet _openQueue: Promise<void> = Promise.resolve(); // Sequential open queue\n\nfunction openDB(dbName: string, storeName: string): Promise<IDBDatabase> {\n // If we already have a connection with the required store, reuse it\n const existing = _connections.get(dbName);\n if (existing) {\n if (existing.objectStoreNames.contains(storeName)) {\n return Promise.resolve(existing);\n }\n // Need to add a new store — close and reopen with bumped version\n existing.close();\n _connections.delete(dbName);\n }\n\n // Track known stores\n let stores = _stores.get(dbName);\n if (!stores) {\n stores = new Set();\n _stores.set(dbName, stores);\n }\n stores.add(storeName);\n\n // Serialize opens to prevent version conflicts\n const result = _openQueue.then(() => doOpen(dbName, stores!));\n _openQueue = result.then(() => {}, () => {}); // Absorb errors for the queue\n return result;\n}\n\nfunction doOpen(dbName: string, stores: Set<string>): Promise<IDBDatabase> {\n // Close existing cached connection if any (may have been opened by queued op)\n const existingDb = _connections.get(dbName);\n existingDb?.close();\n _connections.delete(dbName);\n\n // Probe current DB version (version-less open never triggers upgrade)\n return new Promise<IDBDatabase>((resolve, reject) => {\n const probe = indexedDB.open(dbName);\n probe.onsuccess = () => {\n const db = probe.result;\n const version = db.version;\n\n // Check if all required stores already exist\n let needsUpgrade = false;\n for (const name of stores) {\n if (!db.objectStoreNames.contains(name)) {\n needsUpgrade = true;\n break;\n }\n }\n\n if (!needsUpgrade) {\n _connections.set(dbName, db);\n resolve(db);\n return;\n }\n\n // Need new stores — close and reopen with bumped version\n db.close();\n const upgrade = indexedDB.open(dbName, version + 1);\n upgrade.onupgradeneeded = () => {\n const udb = upgrade.result;\n for (const name of stores) {\n if (!udb.objectStoreNames.contains(name)) {\n udb.createObjectStore(name, { keyPath: 'id' });\n }\n }\n };\n upgrade.onsuccess = () => {\n _connections.set(dbName, upgrade.result);\n resolve(upgrade.result);\n };\n upgrade.onerror = () => reject(upgrade.error);\n };\n probe.onerror = () => reject(probe.error);\n });\n}\n\n/**\n * Open a transaction and return the object store for the given database and store name.\n */\nexport function getStore(\n dbName: string,\n storeName: string,\n mode: IDBTransactionMode,\n): Promise<IDBObjectStore> {\n return openDB(dbName, storeName).then((db) => {\n const tx = db.transaction(storeName, mode);\n return tx.objectStore(storeName);\n });\n}\n\n/**\n * Retrieve all items from an IndexedDB object store.\n */\nexport function idbGetAll<T>(store: IDBObjectStore): Promise<T[]> {\n return new Promise((resolve, reject) => {\n const request = store.getAll();\n request.onsuccess = () => resolve(request.result);\n request.onerror = () => reject(request.error);\n });\n}\n\n/**\n * Retrieve a single item by key from an IndexedDB object store.\n */\nexport function idbGet<T>(store: IDBObjectStore, id: IDBValidKey): Promise<T | null> {\n return new Promise((resolve, reject) => {\n const request = store.get(id);\n request.onsuccess = () => resolve(request.result ?? null);\n request.onerror = () => reject(request.error);\n });\n}\n\n/**\n * Write (put) multiple items into an IndexedDB object store.\n */\nexport function idbPut<T>(store: IDBObjectStore, items: T[]): Promise<void> {\n return new Promise((resolve, reject) => {\n const tx = store.transaction;\n for (const item of items) {\n store.put(item);\n }\n tx.oncomplete = () => resolve();\n tx.onerror = () => reject(tx.error);\n });\n}\n\n/**\n * Delete multiple items by key from an IndexedDB object store.\n */\nexport function idbDelete(store: IDBObjectStore, ids: IDBValidKey[]): Promise<void> {\n return new Promise((resolve, reject) => {\n const tx = store.transaction;\n for (const id of ids) {\n store.delete(id);\n }\n tx.oncomplete = () => resolve();\n tx.onerror = () => reject(tx.error);\n });\n}\n\n/**\n * Clear all items from an IndexedDB object store.\n */\nexport function idbClear(store: IDBObjectStore): Promise<void> {\n return new Promise((resolve, reject) => {\n const tx = store.transaction;\n store.clear();\n tx.oncomplete = () => resolve();\n tx.onerror = () => reject(tx.error);\n });\n}\n\n/** Close all cached connections and delete all known databases. Used in test cleanup. */\nexport function closeAllConnections(): void {\n for (const db of _connections.values()) {\n db.close();\n }\n _connections.clear();\n _stores.clear();\n _openQueue = Promise.resolve();\n}\n\n/** Delete a database by name. Returns a promise that resolves when deleted. */\nexport function deleteDatabase(dbName: string): Promise<void> {\n const existing = _connections.get(dbName);\n existing?.close();\n _connections.delete(dbName);\n _stores.delete(dbName);\n\n return new Promise((resolve, reject) => {\n const request = indexedDB.deleteDatabase(dbName);\n request.onsuccess = () => resolve();\n request.onerror = () => reject(request.error);\n });\n}\n"],"
|
|
1
|
+
{"version":3,"file":"idb.cjs","names":[],"sources":["../../src/web/idb.ts"],"sourcesContent":["/**\n * Shared IndexedDB connection manager.\n * Deduplicates indexedDB.open() calls and handles dynamic object store creation\n * by bumping the DB version when a new storageKey is encountered.\n */\n\nconst _connections = new Map<string, IDBDatabase>();\nconst _stores = new Map<string, Set<string>>(); // dbName → known store names\nlet _openQueue: Promise<void> = Promise.resolve(); // Sequential open queue\n\nfunction openDB(dbName: string, storeName: string): Promise<IDBDatabase> {\n // If we already have a connection with the required store, reuse it\n const existing = _connections.get(dbName);\n if (existing) {\n if (existing.objectStoreNames.contains(storeName)) {\n return Promise.resolve(existing);\n }\n // Need to add a new store — close and reopen with bumped version\n existing.close();\n _connections.delete(dbName);\n }\n\n // Track known stores\n let stores = _stores.get(dbName);\n if (!stores) {\n stores = new Set();\n _stores.set(dbName, stores);\n }\n stores.add(storeName);\n\n // Serialize opens to prevent version conflicts\n const result = _openQueue.then(() => doOpen(dbName, stores!));\n _openQueue = result.then(() => {}, () => {}); // Absorb errors for the queue\n return result;\n}\n\nfunction doOpen(dbName: string, stores: Set<string>): Promise<IDBDatabase> {\n // Close existing cached connection if any (may have been opened by queued op)\n const existingDb = _connections.get(dbName);\n existingDb?.close();\n _connections.delete(dbName);\n\n // Probe current DB version (version-less open never triggers upgrade)\n return new Promise<IDBDatabase>((resolve, reject) => {\n const probe = indexedDB.open(dbName);\n probe.onsuccess = () => {\n const db = probe.result;\n const version = db.version;\n\n // Check if all required stores already exist\n let needsUpgrade = false;\n for (const name of stores) {\n if (!db.objectStoreNames.contains(name)) {\n needsUpgrade = true;\n break;\n }\n }\n\n if (!needsUpgrade) {\n _connections.set(dbName, db);\n resolve(db);\n return;\n }\n\n // Need new stores — close and reopen with bumped version\n db.close();\n const upgrade = indexedDB.open(dbName, version + 1);\n upgrade.onupgradeneeded = () => {\n const udb = upgrade.result;\n for (const name of stores) {\n if (!udb.objectStoreNames.contains(name)) {\n udb.createObjectStore(name, { keyPath: 'id' });\n }\n }\n };\n upgrade.onsuccess = () => {\n _connections.set(dbName, upgrade.result);\n resolve(upgrade.result);\n };\n upgrade.onerror = () => reject(upgrade.error);\n };\n probe.onerror = () => reject(probe.error);\n });\n}\n\n/**\n * Open a transaction and return the object store for the given database and store name.\n */\nexport function getStore(\n dbName: string,\n storeName: string,\n mode: IDBTransactionMode,\n): Promise<IDBObjectStore> {\n return openDB(dbName, storeName).then((db) => {\n const tx = db.transaction(storeName, mode);\n return tx.objectStore(storeName);\n });\n}\n\n/**\n * Retrieve all items from an IndexedDB object store.\n */\nexport function idbGetAll<T>(store: IDBObjectStore): Promise<T[]> {\n return new Promise((resolve, reject) => {\n const request = store.getAll();\n request.onsuccess = () => resolve(request.result);\n request.onerror = () => reject(request.error);\n });\n}\n\n/**\n * Retrieve a single item by key from an IndexedDB object store.\n */\nexport function idbGet<T>(store: IDBObjectStore, id: IDBValidKey): Promise<T | null> {\n return new Promise((resolve, reject) => {\n const request = store.get(id);\n request.onsuccess = () => resolve(request.result ?? null);\n request.onerror = () => reject(request.error);\n });\n}\n\n/**\n * Write (put) multiple items into an IndexedDB object store.\n */\nexport function idbPut<T>(store: IDBObjectStore, items: T[]): Promise<void> {\n return new Promise((resolve, reject) => {\n const tx = store.transaction;\n for (const item of items) {\n store.put(item);\n }\n tx.oncomplete = () => resolve();\n tx.onerror = () => reject(tx.error);\n });\n}\n\n/**\n * Delete multiple items by key from an IndexedDB object store.\n */\nexport function idbDelete(store: IDBObjectStore, ids: IDBValidKey[]): Promise<void> {\n return new Promise((resolve, reject) => {\n const tx = store.transaction;\n for (const id of ids) {\n store.delete(id);\n }\n tx.oncomplete = () => resolve();\n tx.onerror = () => reject(tx.error);\n });\n}\n\n/**\n * Clear all items from an IndexedDB object store.\n */\nexport function idbClear(store: IDBObjectStore): Promise<void> {\n return new Promise((resolve, reject) => {\n const tx = store.transaction;\n store.clear();\n tx.oncomplete = () => resolve();\n tx.onerror = () => reject(tx.error);\n });\n}\n\n/** Close all cached connections and delete all known databases. Used in test cleanup. */\nexport function closeAllConnections(): void {\n for (const db of _connections.values()) {\n db.close();\n }\n _connections.clear();\n _stores.clear();\n _openQueue = Promise.resolve();\n}\n\n/** Delete a database by name. Returns a promise that resolves when deleted. */\nexport function deleteDatabase(dbName: string): Promise<void> {\n const existing = _connections.get(dbName);\n existing?.close();\n _connections.delete(dbName);\n _stores.delete(dbName);\n\n return new Promise((resolve, reject) => {\n const request = indexedDB.deleteDatabase(dbName);\n request.onsuccess = () => resolve();\n request.onerror = () => reject(request.error);\n });\n}\n"],"mappings":"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"}
|
package/dist/web/idb.js
CHANGED
|
@@ -1,121 +1,124 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
//#region src/web/idb.ts
|
|
2
|
+
/**
|
|
3
|
+
* Shared IndexedDB connection manager.
|
|
4
|
+
* Deduplicates indexedDB.open() calls and handles dynamic object store creation
|
|
5
|
+
* by bumping the DB version when a new storageKey is encountered.
|
|
6
|
+
*/
|
|
7
|
+
var _connections = /* @__PURE__ */ new Map();
|
|
8
|
+
var _stores = /* @__PURE__ */ new Map();
|
|
9
|
+
var _openQueue = Promise.resolve();
|
|
4
10
|
function openDB(dbName, storeName) {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
_openQueue = result.then(() => {
|
|
21
|
-
}, () => {
|
|
22
|
-
});
|
|
23
|
-
return result;
|
|
11
|
+
const existing = _connections.get(dbName);
|
|
12
|
+
if (existing) {
|
|
13
|
+
if (existing.objectStoreNames.contains(storeName)) return Promise.resolve(existing);
|
|
14
|
+
existing.close();
|
|
15
|
+
_connections.delete(dbName);
|
|
16
|
+
}
|
|
17
|
+
let stores = _stores.get(dbName);
|
|
18
|
+
if (!stores) {
|
|
19
|
+
stores = /* @__PURE__ */ new Set();
|
|
20
|
+
_stores.set(dbName, stores);
|
|
21
|
+
}
|
|
22
|
+
stores.add(storeName);
|
|
23
|
+
const result = _openQueue.then(() => doOpen(dbName, stores));
|
|
24
|
+
_openQueue = result.then(() => {}, () => {});
|
|
25
|
+
return result;
|
|
24
26
|
}
|
|
25
27
|
function doOpen(dbName, stores) {
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
_connections.set(dbName, upgrade.result);
|
|
58
|
-
resolve(upgrade.result);
|
|
59
|
-
};
|
|
60
|
-
upgrade.onerror = () => reject(upgrade.error);
|
|
61
|
-
};
|
|
62
|
-
probe.onerror = () => reject(probe.error);
|
|
63
|
-
});
|
|
28
|
+
_connections.get(dbName)?.close();
|
|
29
|
+
_connections.delete(dbName);
|
|
30
|
+
return new Promise((resolve, reject) => {
|
|
31
|
+
const probe = indexedDB.open(dbName);
|
|
32
|
+
probe.onsuccess = () => {
|
|
33
|
+
const db = probe.result;
|
|
34
|
+
const version = db.version;
|
|
35
|
+
let needsUpgrade = false;
|
|
36
|
+
for (const name of stores) if (!db.objectStoreNames.contains(name)) {
|
|
37
|
+
needsUpgrade = true;
|
|
38
|
+
break;
|
|
39
|
+
}
|
|
40
|
+
if (!needsUpgrade) {
|
|
41
|
+
_connections.set(dbName, db);
|
|
42
|
+
resolve(db);
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
db.close();
|
|
46
|
+
const upgrade = indexedDB.open(dbName, version + 1);
|
|
47
|
+
upgrade.onupgradeneeded = () => {
|
|
48
|
+
const udb = upgrade.result;
|
|
49
|
+
for (const name of stores) if (!udb.objectStoreNames.contains(name)) udb.createObjectStore(name, { keyPath: "id" });
|
|
50
|
+
};
|
|
51
|
+
upgrade.onsuccess = () => {
|
|
52
|
+
_connections.set(dbName, upgrade.result);
|
|
53
|
+
resolve(upgrade.result);
|
|
54
|
+
};
|
|
55
|
+
upgrade.onerror = () => reject(upgrade.error);
|
|
56
|
+
};
|
|
57
|
+
probe.onerror = () => reject(probe.error);
|
|
58
|
+
});
|
|
64
59
|
}
|
|
60
|
+
/**
|
|
61
|
+
* Open a transaction and return the object store for the given database and store name.
|
|
62
|
+
*/
|
|
65
63
|
function getStore(dbName, storeName, mode) {
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
});
|
|
64
|
+
return openDB(dbName, storeName).then((db) => {
|
|
65
|
+
return db.transaction(storeName, mode).objectStore(storeName);
|
|
66
|
+
});
|
|
70
67
|
}
|
|
68
|
+
/**
|
|
69
|
+
* Retrieve all items from an IndexedDB object store.
|
|
70
|
+
*/
|
|
71
71
|
function idbGetAll(store) {
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
72
|
+
return new Promise((resolve, reject) => {
|
|
73
|
+
const request = store.getAll();
|
|
74
|
+
request.onsuccess = () => resolve(request.result);
|
|
75
|
+
request.onerror = () => reject(request.error);
|
|
76
|
+
});
|
|
77
77
|
}
|
|
78
|
+
/**
|
|
79
|
+
* Retrieve a single item by key from an IndexedDB object store.
|
|
80
|
+
*/
|
|
78
81
|
function idbGet(store, id) {
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
82
|
+
return new Promise((resolve, reject) => {
|
|
83
|
+
const request = store.get(id);
|
|
84
|
+
request.onsuccess = () => resolve(request.result ?? null);
|
|
85
|
+
request.onerror = () => reject(request.error);
|
|
86
|
+
});
|
|
84
87
|
}
|
|
88
|
+
/**
|
|
89
|
+
* Write (put) multiple items into an IndexedDB object store.
|
|
90
|
+
*/
|
|
85
91
|
function idbPut(store, items) {
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
tx.onerror = () => reject(tx.error);
|
|
93
|
-
});
|
|
92
|
+
return new Promise((resolve, reject) => {
|
|
93
|
+
const tx = store.transaction;
|
|
94
|
+
for (const item of items) store.put(item);
|
|
95
|
+
tx.oncomplete = () => resolve();
|
|
96
|
+
tx.onerror = () => reject(tx.error);
|
|
97
|
+
});
|
|
94
98
|
}
|
|
99
|
+
/**
|
|
100
|
+
* Delete multiple items by key from an IndexedDB object store.
|
|
101
|
+
*/
|
|
95
102
|
function idbDelete(store, ids) {
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
tx.onerror = () => reject(tx.error);
|
|
103
|
-
});
|
|
103
|
+
return new Promise((resolve, reject) => {
|
|
104
|
+
const tx = store.transaction;
|
|
105
|
+
for (const id of ids) store.delete(id);
|
|
106
|
+
tx.oncomplete = () => resolve();
|
|
107
|
+
tx.onerror = () => reject(tx.error);
|
|
108
|
+
});
|
|
104
109
|
}
|
|
110
|
+
/**
|
|
111
|
+
* Clear all items from an IndexedDB object store.
|
|
112
|
+
*/
|
|
105
113
|
function idbClear(store) {
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
114
|
+
return new Promise((resolve, reject) => {
|
|
115
|
+
const tx = store.transaction;
|
|
116
|
+
store.clear();
|
|
117
|
+
tx.oncomplete = () => resolve();
|
|
118
|
+
tx.onerror = () => reject(tx.error);
|
|
119
|
+
});
|
|
112
120
|
}
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
idbGet,
|
|
118
|
-
idbGetAll,
|
|
119
|
-
idbPut
|
|
120
|
-
};
|
|
121
|
-
//# sourceMappingURL=idb.js.map
|
|
121
|
+
//#endregion
|
|
122
|
+
export { getStore, idbClear, idbDelete, idbGet, idbGetAll, idbPut };
|
|
123
|
+
|
|
124
|
+
//# sourceMappingURL=idb.js.map
|
package/dist/web/idb.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"idb.js","sources":["../../src/web/idb.ts"],"sourcesContent":["/**\n * Shared IndexedDB connection manager.\n * Deduplicates indexedDB.open() calls and handles dynamic object store creation\n * by bumping the DB version when a new storageKey is encountered.\n */\n\nconst _connections = new Map<string, IDBDatabase>();\nconst _stores = new Map<string, Set<string>>(); // dbName → known store names\nlet _openQueue: Promise<void> = Promise.resolve(); // Sequential open queue\n\nfunction openDB(dbName: string, storeName: string): Promise<IDBDatabase> {\n // If we already have a connection with the required store, reuse it\n const existing = _connections.get(dbName);\n if (existing) {\n if (existing.objectStoreNames.contains(storeName)) {\n return Promise.resolve(existing);\n }\n // Need to add a new store — close and reopen with bumped version\n existing.close();\n _connections.delete(dbName);\n }\n\n // Track known stores\n let stores = _stores.get(dbName);\n if (!stores) {\n stores = new Set();\n _stores.set(dbName, stores);\n }\n stores.add(storeName);\n\n // Serialize opens to prevent version conflicts\n const result = _openQueue.then(() => doOpen(dbName, stores!));\n _openQueue = result.then(() => {}, () => {}); // Absorb errors for the queue\n return result;\n}\n\nfunction doOpen(dbName: string, stores: Set<string>): Promise<IDBDatabase> {\n // Close existing cached connection if any (may have been opened by queued op)\n const existingDb = _connections.get(dbName);\n existingDb?.close();\n _connections.delete(dbName);\n\n // Probe current DB version (version-less open never triggers upgrade)\n return new Promise<IDBDatabase>((resolve, reject) => {\n const probe = indexedDB.open(dbName);\n probe.onsuccess = () => {\n const db = probe.result;\n const version = db.version;\n\n // Check if all required stores already exist\n let needsUpgrade = false;\n for (const name of stores) {\n if (!db.objectStoreNames.contains(name)) {\n needsUpgrade = true;\n break;\n }\n }\n\n if (!needsUpgrade) {\n _connections.set(dbName, db);\n resolve(db);\n return;\n }\n\n // Need new stores — close and reopen with bumped version\n db.close();\n const upgrade = indexedDB.open(dbName, version + 1);\n upgrade.onupgradeneeded = () => {\n const udb = upgrade.result;\n for (const name of stores) {\n if (!udb.objectStoreNames.contains(name)) {\n udb.createObjectStore(name, { keyPath: 'id' });\n }\n }\n };\n upgrade.onsuccess = () => {\n _connections.set(dbName, upgrade.result);\n resolve(upgrade.result);\n };\n upgrade.onerror = () => reject(upgrade.error);\n };\n probe.onerror = () => reject(probe.error);\n });\n}\n\n/**\n * Open a transaction and return the object store for the given database and store name.\n */\nexport function getStore(\n dbName: string,\n storeName: string,\n mode: IDBTransactionMode,\n): Promise<IDBObjectStore> {\n return openDB(dbName, storeName).then((db) => {\n const tx = db.transaction(storeName, mode);\n return tx.objectStore(storeName);\n });\n}\n\n/**\n * Retrieve all items from an IndexedDB object store.\n */\nexport function idbGetAll<T>(store: IDBObjectStore): Promise<T[]> {\n return new Promise((resolve, reject) => {\n const request = store.getAll();\n request.onsuccess = () => resolve(request.result);\n request.onerror = () => reject(request.error);\n });\n}\n\n/**\n * Retrieve a single item by key from an IndexedDB object store.\n */\nexport function idbGet<T>(store: IDBObjectStore, id: IDBValidKey): Promise<T | null> {\n return new Promise((resolve, reject) => {\n const request = store.get(id);\n request.onsuccess = () => resolve(request.result ?? null);\n request.onerror = () => reject(request.error);\n });\n}\n\n/**\n * Write (put) multiple items into an IndexedDB object store.\n */\nexport function idbPut<T>(store: IDBObjectStore, items: T[]): Promise<void> {\n return new Promise((resolve, reject) => {\n const tx = store.transaction;\n for (const item of items) {\n store.put(item);\n }\n tx.oncomplete = () => resolve();\n tx.onerror = () => reject(tx.error);\n });\n}\n\n/**\n * Delete multiple items by key from an IndexedDB object store.\n */\nexport function idbDelete(store: IDBObjectStore, ids: IDBValidKey[]): Promise<void> {\n return new Promise((resolve, reject) => {\n const tx = store.transaction;\n for (const id of ids) {\n store.delete(id);\n }\n tx.oncomplete = () => resolve();\n tx.onerror = () => reject(tx.error);\n });\n}\n\n/**\n * Clear all items from an IndexedDB object store.\n */\nexport function idbClear(store: IDBObjectStore): Promise<void> {\n return new Promise((resolve, reject) => {\n const tx = store.transaction;\n store.clear();\n tx.oncomplete = () => resolve();\n tx.onerror = () => reject(tx.error);\n });\n}\n\n/** Close all cached connections and delete all known databases. Used in test cleanup. */\nexport function closeAllConnections(): void {\n for (const db of _connections.values()) {\n db.close();\n }\n _connections.clear();\n _stores.clear();\n _openQueue = Promise.resolve();\n}\n\n/** Delete a database by name. Returns a promise that resolves when deleted. */\nexport function deleteDatabase(dbName: string): Promise<void> {\n const existing = _connections.get(dbName);\n existing?.close();\n _connections.delete(dbName);\n _stores.delete(dbName);\n\n return new Promise((resolve, reject) => {\n const request = indexedDB.deleteDatabase(dbName);\n request.onsuccess = () => resolve();\n request.onerror = () => reject(request.error);\n });\n}\n"],"
|
|
1
|
+
{"version":3,"file":"idb.js","names":[],"sources":["../../src/web/idb.ts"],"sourcesContent":["/**\n * Shared IndexedDB connection manager.\n * Deduplicates indexedDB.open() calls and handles dynamic object store creation\n * by bumping the DB version when a new storageKey is encountered.\n */\n\nconst _connections = new Map<string, IDBDatabase>();\nconst _stores = new Map<string, Set<string>>(); // dbName → known store names\nlet _openQueue: Promise<void> = Promise.resolve(); // Sequential open queue\n\nfunction openDB(dbName: string, storeName: string): Promise<IDBDatabase> {\n // If we already have a connection with the required store, reuse it\n const existing = _connections.get(dbName);\n if (existing) {\n if (existing.objectStoreNames.contains(storeName)) {\n return Promise.resolve(existing);\n }\n // Need to add a new store — close and reopen with bumped version\n existing.close();\n _connections.delete(dbName);\n }\n\n // Track known stores\n let stores = _stores.get(dbName);\n if (!stores) {\n stores = new Set();\n _stores.set(dbName, stores);\n }\n stores.add(storeName);\n\n // Serialize opens to prevent version conflicts\n const result = _openQueue.then(() => doOpen(dbName, stores!));\n _openQueue = result.then(() => {}, () => {}); // Absorb errors for the queue\n return result;\n}\n\nfunction doOpen(dbName: string, stores: Set<string>): Promise<IDBDatabase> {\n // Close existing cached connection if any (may have been opened by queued op)\n const existingDb = _connections.get(dbName);\n existingDb?.close();\n _connections.delete(dbName);\n\n // Probe current DB version (version-less open never triggers upgrade)\n return new Promise<IDBDatabase>((resolve, reject) => {\n const probe = indexedDB.open(dbName);\n probe.onsuccess = () => {\n const db = probe.result;\n const version = db.version;\n\n // Check if all required stores already exist\n let needsUpgrade = false;\n for (const name of stores) {\n if (!db.objectStoreNames.contains(name)) {\n needsUpgrade = true;\n break;\n }\n }\n\n if (!needsUpgrade) {\n _connections.set(dbName, db);\n resolve(db);\n return;\n }\n\n // Need new stores — close and reopen with bumped version\n db.close();\n const upgrade = indexedDB.open(dbName, version + 1);\n upgrade.onupgradeneeded = () => {\n const udb = upgrade.result;\n for (const name of stores) {\n if (!udb.objectStoreNames.contains(name)) {\n udb.createObjectStore(name, { keyPath: 'id' });\n }\n }\n };\n upgrade.onsuccess = () => {\n _connections.set(dbName, upgrade.result);\n resolve(upgrade.result);\n };\n upgrade.onerror = () => reject(upgrade.error);\n };\n probe.onerror = () => reject(probe.error);\n });\n}\n\n/**\n * Open a transaction and return the object store for the given database and store name.\n */\nexport function getStore(\n dbName: string,\n storeName: string,\n mode: IDBTransactionMode,\n): Promise<IDBObjectStore> {\n return openDB(dbName, storeName).then((db) => {\n const tx = db.transaction(storeName, mode);\n return tx.objectStore(storeName);\n });\n}\n\n/**\n * Retrieve all items from an IndexedDB object store.\n */\nexport function idbGetAll<T>(store: IDBObjectStore): Promise<T[]> {\n return new Promise((resolve, reject) => {\n const request = store.getAll();\n request.onsuccess = () => resolve(request.result);\n request.onerror = () => reject(request.error);\n });\n}\n\n/**\n * Retrieve a single item by key from an IndexedDB object store.\n */\nexport function idbGet<T>(store: IDBObjectStore, id: IDBValidKey): Promise<T | null> {\n return new Promise((resolve, reject) => {\n const request = store.get(id);\n request.onsuccess = () => resolve(request.result ?? null);\n request.onerror = () => reject(request.error);\n });\n}\n\n/**\n * Write (put) multiple items into an IndexedDB object store.\n */\nexport function idbPut<T>(store: IDBObjectStore, items: T[]): Promise<void> {\n return new Promise((resolve, reject) => {\n const tx = store.transaction;\n for (const item of items) {\n store.put(item);\n }\n tx.oncomplete = () => resolve();\n tx.onerror = () => reject(tx.error);\n });\n}\n\n/**\n * Delete multiple items by key from an IndexedDB object store.\n */\nexport function idbDelete(store: IDBObjectStore, ids: IDBValidKey[]): Promise<void> {\n return new Promise((resolve, reject) => {\n const tx = store.transaction;\n for (const id of ids) {\n store.delete(id);\n }\n tx.oncomplete = () => resolve();\n tx.onerror = () => reject(tx.error);\n });\n}\n\n/**\n * Clear all items from an IndexedDB object store.\n */\nexport function idbClear(store: IDBObjectStore): Promise<void> {\n return new Promise((resolve, reject) => {\n const tx = store.transaction;\n store.clear();\n tx.oncomplete = () => resolve();\n tx.onerror = () => reject(tx.error);\n });\n}\n\n/** Close all cached connections and delete all known databases. Used in test cleanup. */\nexport function closeAllConnections(): void {\n for (const db of _connections.values()) {\n db.close();\n }\n _connections.clear();\n _stores.clear();\n _openQueue = Promise.resolve();\n}\n\n/** Delete a database by name. Returns a promise that resolves when deleted. */\nexport function deleteDatabase(dbName: string): Promise<void> {\n const existing = _connections.get(dbName);\n existing?.close();\n _connections.delete(dbName);\n _stores.delete(dbName);\n\n return new Promise((resolve, reject) => {\n const request = indexedDB.deleteDatabase(dbName);\n request.onsuccess = () => resolve();\n request.onerror = () => reject(request.error);\n });\n}\n"],"mappings":"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"}
|
package/dist/web.cjs
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
|
-
"use strict";
|
|
2
1
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const
|
|
4
|
-
const
|
|
5
|
-
exports.
|
|
6
|
-
exports.
|
|
7
|
-
//# sourceMappingURL=web.cjs.map
|
|
2
|
+
const require_WebStorageCollection = require("./web/WebStorageCollection.cjs");
|
|
3
|
+
const require_IndexedDBCollection = require("./web/IndexedDBCollection.cjs");
|
|
4
|
+
exports.IndexedDBCollection = require_IndexedDBCollection.IndexedDBCollection;
|
|
5
|
+
exports.WebStorageCollection = require_WebStorageCollection.WebStorageCollection;
|
package/dist/web.js
CHANGED
|
@@ -1,7 +1,3 @@
|
|
|
1
1
|
import { WebStorageCollection } from "./web/WebStorageCollection.js";
|
|
2
2
|
import { IndexedDBCollection } from "./web/IndexedDBCollection.js";
|
|
3
|
-
export {
|
|
4
|
-
IndexedDBCollection,
|
|
5
|
-
WebStorageCollection
|
|
6
|
-
};
|
|
7
|
-
//# sourceMappingURL=web.js.map
|
|
3
|
+
export { IndexedDBCollection, WebStorageCollection };
|