doc.yeswiki.pro/node_modules/@vueuse/integrations/useIDBKeyval.cjs
2023-05-20 19:38:02 +03:00

71 lines
2.1 KiB
JavaScript

'use strict';
var shared = require('@vueuse/shared');
var vueDemi = require('vue-demi');
var idbKeyval = require('idb-keyval');
var __defProp = Object.defineProperty;
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __propIsEnum = Object.prototype.propertyIsEnumerable;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __spreadValues = (a, b) => {
for (var prop in b || (b = {}))
if (__hasOwnProp.call(b, prop))
__defNormalProp(a, prop, b[prop]);
if (__getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(b)) {
if (__propIsEnum.call(b, prop))
__defNormalProp(a, prop, b[prop]);
}
return a;
};
function useIDBKeyval(key, initialValue, options = {}) {
const {
flush = "pre",
deep = true,
shallow = false,
onError = (e) => {
console.error(e);
},
writeDefaults = true
} = options;
const isFinished = vueDemi.ref(false);
const data = (shallow ? vueDemi.shallowRef : vueDemi.ref)(initialValue);
const rawInit = shared.toValue(initialValue);
async function read() {
try {
const rawValue = await idbKeyval.get(key);
if (rawValue === void 0) {
if (rawInit !== void 0 && rawInit !== null && writeDefaults)
await idbKeyval.set(key, rawInit);
} else {
data.value = rawValue;
}
} catch (e) {
onError(e);
}
isFinished.value = true;
}
read();
async function write() {
try {
if (data.value == null) {
await idbKeyval.del(key);
} else {
if (Array.isArray(data.value))
await idbKeyval.update(key, () => JSON.parse(JSON.stringify(data.value)));
else if (typeof data.value === "object")
await idbKeyval.update(key, () => __spreadValues({}, data.value));
else
await idbKeyval.update(key, () => data.value);
}
} catch (e) {
onError(e);
}
}
vueDemi.watch(data, () => write(), { flush, deep });
return { isFinished, data };
}
exports.useIDBKeyval = useIDBKeyval;