|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ clear: () => (/* binding */ clear),\n/* harmony export */ createStore: () => (/* binding */ createStore),\n/* harmony export */ del: () => (/* binding */ del),\n/* harmony export */ delMany: () => (/* binding */ delMany),\n/* harmony export */ entries: () => (/* binding */ entries),\n/* harmony export */ get: () => (/* binding */ get),\n/* harmony export */ getMany: () => (/* binding */ getMany),\n/* harmony export */ keys: () => (/* binding */ keys),\n/* harmony export */ promisifyRequest: () => (/* binding */ promisifyRequest),\n/* harmony export */ set: () => (/* binding */ set),\n/* harmony export */ setMany: () => (/* binding */ setMany),\n/* harmony export */ update: () => (/* binding */ update),\n/* harmony export */ values: () => (/* binding */ values)\n/* harmony export */ });\nfunction promisifyRequest(request) {\n return new Promise((resolve, reject)=>{\n // @ts-ignore - file size hacks\n request.oncomplete = request.onsuccess = ()=>resolve(request.result);\n // @ts-ignore - file size hacks\n request.onabort = request.onerror = ()=>reject(request.error);\n });\n}\nfunction createStore(dbName, storeName) {\n const request = indexedDB.open(dbName);\n request.onupgradeneeded = ()=>request.result.createObjectStore(storeName);\n const dbp = promisifyRequest(request);\n return (txMode, callback)=>dbp.then((db)=>callback(db.transaction(storeName, txMode).objectStore(storeName)));\n}\nlet defaultGetStoreFunc;\nfunction defaultGetStore() {\n if (!defaultGetStoreFunc) {\n defaultGetStoreFunc = createStore(\"keyval-store\", \"keyval\");\n }\n return defaultGetStoreFunc;\n}\n/**\n * Get a value by its key.\n *\n * @param key\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */ function get(key, customStore = defaultGetStore()) {\n return customStore(\"readonly\", (store)=>promisifyRequest(store.get(key)));\n}\n/**\n * Set a value with a key.\n *\n * @param key\n * @param value\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */ function set(key, value, customStore = defaultGetStore()) {\n return customStore(\"readwrite\", (store)=>{\n store.put(value, key);\n return promisifyRequest(store.transaction);\n });\n}\n/**\n * Set multiple values at once. This is faster than calling set() multiple times.\n * It's also atomic – if one of the pairs can't be added, none will be added.\n *\n * @param entries Array of entries, where each entry is an array of `[key, value]`.\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */ function setMany(entries, customStore = defaultGetStore()) {\n return customStore(\"readwrite\", (store)=>{\n entries.forEach((entry)=>store.put(entry[1], entry[0]));\n return promisifyRequest(store.transaction);\n });\n}\n/**\n * Get multiple values by their keys\n *\n * @param keys\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */ function getMany(keys, customStore = defaultGetStore()) {\n return customStore(\"readonly\", (store)=>Promise.all(keys.map((key)=>promisifyRequest(store.get(key)))));\n}\n/**\n * Update a value. This lets you see the old value and update it as an atomic operation.\n *\n * @param key\n * @param updater A callback that takes the old value and returns a new value.\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */ function update(key, updater, customStore = defaultGetStore()) {\n return customStore(\"readwrite\", (store)=>// Need to create the promise manually.\n // If I try to chain promises, the transaction closes in browsers\n // that use a promise polyfill (IE10/11).\n new Promise((resolve, reject)=>{\n store.get(key).onsuccess = function() {\n try {\n store.put(updater(this.result), key);\n resolve(promisifyRequest(store.transaction));\n } catch (err) {\n reject(err);\n }\n };\n }));\n}\n/**\n * Delete a particular key from the store.\n *\n * @param key\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */ function del(key, customStore = defaultGetStore()) {\n return customStore(\"readwrite\", (store)=>{\n store.delete(key);\n return promisifyRequest(store.transaction);\n });\n}\n/**\n * Delete multiple keys at once.\n *\n * @param keys List of keys to delete.\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */ function delMany(keys, customStore = defaultGetStore()) {\n return customStore(\"readwrite\", (store)=>{\n keys.forEach((key)=>store.delete(key));\n return promisifyRequest(store.transaction);\n });\n}\n/**\n * Clear all values in the store.\n *\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */ function clear(customStore = defaultGetStore()) {\n return customStore(\"readwrite\", (store)=>{\n store.clear();\n return promisifyRequest(store.transaction);\n });\n}\nfunction eachCursor(store, callback) {\n store.openCursor().onsuccess = function() {\n if (!this.result) return;\n callback(this.result);\n this.result.continue();\n };\n return promisifyRequest(store.transaction);\n}\n/**\n * Get all keys in the store.\n *\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */ function keys(customStore = defaultGetStore()) {\n return customStore(\"readonly\", (store)=>{\n // Fast path for modern browsers\n if (store.getAllKeys) {\n return promisifyRequest(store.getAllKeys());\n }\n const items = [];\n return eachCursor(store, (cursor)=>items.push(cursor.key)).then(()=>items);\n });\n}\n/**\n * Get all values in the store.\n *\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */ function values(customStore = defaultGetStore()) {\n return customStore(\"readonly\", (store)=>{\n // Fast path for modern browsers\n if (store.getAll) {\n return promisifyRequest(store.getAll());\n }\n const items = [];\n return eachCursor(store, (cursor)=>items.push(cursor.value)).then(()=>items);\n });\n}\n/**\n * Get all entries in the store. Each entry is an array of `[key, value]`.\n *\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */ function entries(customStore = defaultGetStore()) {\n return customStore(\"readonly\", (store)=>{\n // Fast path for modern browsers\n // (although, hopefully we'll get a simpler path some day)\n if (store.getAll && store.getAllKeys) {\n return Promise.all([\n promisifyRequest(store.getAllKeys()),\n promisifyRequest(store.getAll())\n ]).then(([keys, values])=>keys.map((key, i)=>[\n key,\n values[i]\n ]));\n }\n const items = [];\n return customStore(\"readonly\", (store)=>eachCursor(store, (cursor)=>items.push([\n cursor.key,\n cursor.value\n ])).then(()=>items));\n });\n}\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/idb-keyval/dist/index.js","mappings":"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","sources":["webpack://nextchat/./node_modules/idb-keyval/dist/index.js?f422"],"sourcesContent":["function promisifyRequest(request) {\n    return new Promise((resolve, reject) => {\n        // @ts-ignore - file size hacks\n        request.oncomplete = request.onsuccess = () => resolve(request.result);\n        // @ts-ignore - file size hacks\n        request.onabort = request.onerror = () => reject(request.error);\n    });\n}\nfunction createStore(dbName, storeName) {\n    const request = indexedDB.open(dbName);\n    request.onupgradeneeded = () => request.result.createObjectStore(storeName);\n    const dbp = promisifyRequest(request);\n    return (txMode, callback) => dbp.then((db) => callback(db.transaction(storeName, txMode).objectStore(storeName)));\n}\nlet defaultGetStoreFunc;\nfunction defaultGetStore() {\n    if (!defaultGetStoreFunc) {\n        defaultGetStoreFunc = createStore('keyval-store', 'keyval');\n    }\n    return defaultGetStoreFunc;\n}\n/**\n * Get a value by its key.\n *\n * @param key\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */\nfunction get(key, customStore = defaultGetStore()) {\n    return customStore('readonly', (store) => promisifyRequest(store.get(key)));\n}\n/**\n * Set a value with a key.\n *\n * @param key\n * @param value\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */\nfunction set(key, value, customStore = defaultGetStore()) {\n    return customStore('readwrite', (store) => {\n        store.put(value, key);\n        return promisifyRequest(store.transaction);\n    });\n}\n/**\n * Set multiple values at once. This is faster than calling set() multiple times.\n * It's also atomic – if one of the pairs can't be added, none will be added.\n *\n * @param entries Array of entries, where each entry is an array of `[key, value]`.\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */\nfunction setMany(entries, customStore = defaultGetStore()) {\n    return customStore('readwrite', (store) => {\n        entries.forEach((entry) => store.put(entry[1], entry[0]));\n        return promisifyRequest(store.transaction);\n    });\n}\n/**\n * Get multiple values by their keys\n *\n * @param keys\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */\nfunction getMany(keys, customStore = defaultGetStore()) {\n    return customStore('readonly', (store) => Promise.all(keys.map((key) => promisifyRequest(store.get(key)))));\n}\n/**\n * Update a value. This lets you see the old value and update it as an atomic operation.\n *\n * @param key\n * @param updater A callback that takes the old value and returns a new value.\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */\nfunction update(key, updater, customStore = defaultGetStore()) {\n    return customStore('readwrite', (store) => \n    // Need to create the promise manually.\n    // If I try to chain promises, the transaction closes in browsers\n    // that use a promise polyfill (IE10/11).\n    new Promise((resolve, reject) => {\n        store.get(key).onsuccess = function () {\n            try {\n                store.put(updater(this.result), key);\n                resolve(promisifyRequest(store.transaction));\n            }\n            catch (err) {\n                reject(err);\n            }\n        };\n    }));\n}\n/**\n * Delete a particular key from the store.\n *\n * @param key\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */\nfunction del(key, customStore = defaultGetStore()) {\n    return customStore('readwrite', (store) => {\n        store.delete(key);\n        return promisifyRequest(store.transaction);\n    });\n}\n/**\n * Delete multiple keys at once.\n *\n * @param keys List of keys to delete.\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */\nfunction delMany(keys, customStore = defaultGetStore()) {\n    return customStore('readwrite', (store) => {\n        keys.forEach((key) => store.delete(key));\n        return promisifyRequest(store.transaction);\n    });\n}\n/**\n * Clear all values in the store.\n *\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */\nfunction clear(customStore = defaultGetStore()) {\n    return customStore('readwrite', (store) => {\n        store.clear();\n        return promisifyRequest(store.transaction);\n    });\n}\nfunction eachCursor(store, callback) {\n    store.openCursor().onsuccess = function () {\n        if (!this.result)\n            return;\n        callback(this.result);\n        this.result.continue();\n    };\n    return promisifyRequest(store.transaction);\n}\n/**\n * Get all keys in the store.\n *\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */\nfunction keys(customStore = defaultGetStore()) {\n    return customStore('readonly', (store) => {\n        // Fast path for modern browsers\n        if (store.getAllKeys) {\n            return promisifyRequest(store.getAllKeys());\n        }\n        const items = [];\n        return eachCursor(store, (cursor) => items.push(cursor.key)).then(() => items);\n    });\n}\n/**\n * Get all values in the store.\n *\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */\nfunction values(customStore = defaultGetStore()) {\n    return customStore('readonly', (store) => {\n        // Fast path for modern browsers\n        if (store.getAll) {\n            return promisifyRequest(store.getAll());\n        }\n        const items = [];\n        return eachCursor(store, (cursor) => items.push(cursor.value)).then(() => items);\n    });\n}\n/**\n * Get all entries in the store. Each entry is an array of `[key, value]`.\n *\n * @param customStore Method to get a custom store. Use with caution (see the docs).\n */\nfunction entries(customStore = defaultGetStore()) {\n    return customStore('readonly', (store) => {\n        // Fast path for modern browsers\n        // (although, hopefully we'll get a simpler path some day)\n        if (store.getAll && store.getAllKeys) {\n            return Promise.all([\n                promisifyRequest(store.getAllKeys()),\n                promisifyRequest(store.getAll()),\n            ]).then(([keys, values]) => keys.map((key, i) => [key, values[i]]));\n        }\n        const items = [];\n        return customStore('readonly', (store) => eachCursor(store, (cursor) => items.push([cursor.key, cursor.value])).then(() => items));\n    });\n}\n\nexport { clear, createStore, del, delMany, entries, get, getMany, keys, promisifyRequest, set, setMany, update, values };\n"],"names":["promisifyRequest","request","Promise","resolve","reject","oncomplete","onsuccess","result","onabort","onerror","error","createStore","dbName","storeName","indexedDB","open","onupgradeneeded","createObjectStore","dbp","txMode","callback","then","db","transaction","objectStore","defaultGetStoreFunc","defaultGetStore","get","key","customStore","store","set","value","put","setMany","entries","forEach","entry","getMany","keys","all","map","update","updater","err","del","delete","delMany","clear","eachCursor","openCursor","continue","getAllKeys","items","cursor","push","values","getAll","i"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/idb-keyval/dist/index.js\n");
|