2023-08-05 18:15:01 +08:00
|
|
|
import { browser, isExt, isGm } from "./browser";
|
2023-07-20 13:45:41 +08:00
|
|
|
|
|
|
|
|
async function set(key, val) {
|
2023-08-05 18:15:01 +08:00
|
|
|
if (isExt) {
|
2023-07-20 13:45:41 +08:00
|
|
|
await browser.storage.local.set({ [key]: val });
|
2023-08-05 18:15:01 +08:00
|
|
|
} else if (isGm) {
|
2023-08-05 16:32:49 +08:00
|
|
|
await (window.GM_setValue || window.GM.setValue)(key, val);
|
2023-07-20 13:45:41 +08:00
|
|
|
} else {
|
|
|
|
|
const oldValue = window.localStorage.getItem(key);
|
|
|
|
|
window.localStorage.setItem(key, val);
|
|
|
|
|
// 手动唤起事件
|
|
|
|
|
window.dispatchEvent(
|
|
|
|
|
new StorageEvent("storage", {
|
|
|
|
|
key,
|
|
|
|
|
oldValue,
|
|
|
|
|
newValue: val,
|
|
|
|
|
})
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async function get(key) {
|
2023-08-05 18:15:01 +08:00
|
|
|
if (isExt) {
|
2023-08-05 15:32:51 +08:00
|
|
|
const val = await browser.storage.local.get([key]);
|
|
|
|
|
return val[key];
|
2023-08-05 18:15:01 +08:00
|
|
|
} else if (isGm) {
|
2023-08-05 16:32:49 +08:00
|
|
|
const val = await (window.GM_getValue || window.GM.getValue)(key);
|
2023-08-05 15:32:51 +08:00
|
|
|
return val;
|
2023-07-20 13:45:41 +08:00
|
|
|
}
|
|
|
|
|
return window.localStorage.getItem(key);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async function del(key) {
|
2023-08-05 18:15:01 +08:00
|
|
|
if (isExt) {
|
2023-07-20 13:45:41 +08:00
|
|
|
await browser.storage.local.remove([key]);
|
2023-08-05 18:15:01 +08:00
|
|
|
} else if (isGm) {
|
2023-08-05 16:32:49 +08:00
|
|
|
await (window.GM_deleteValue || window.GM.deleteValue)(key);
|
2023-07-20 13:45:41 +08:00
|
|
|
} else {
|
|
|
|
|
const oldValue = window.localStorage.getItem(key);
|
|
|
|
|
window.localStorage.removeItem(key);
|
|
|
|
|
// 手动唤起事件
|
|
|
|
|
window.dispatchEvent(
|
|
|
|
|
new StorageEvent("storage", {
|
|
|
|
|
key,
|
|
|
|
|
oldValue,
|
|
|
|
|
newValue: null,
|
|
|
|
|
})
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async function setObj(key, obj) {
|
|
|
|
|
await set(key, JSON.stringify(obj));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async function trySetObj(key, obj) {
|
|
|
|
|
if (!(await get(key))) {
|
|
|
|
|
await setObj(key, obj);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async function getObj(key) {
|
|
|
|
|
const val = await get(key);
|
|
|
|
|
return val && JSON.parse(val);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async function putObj(key, obj) {
|
|
|
|
|
const cur = (await getObj(key)) ?? {};
|
|
|
|
|
await setObj(key, { ...cur, ...obj });
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 监听storage事件
|
|
|
|
|
* @param {*} handleChanged
|
|
|
|
|
*/
|
|
|
|
|
function onChanged(handleChanged) {
|
2023-08-05 18:15:01 +08:00
|
|
|
if (isExt) {
|
2023-07-20 13:45:41 +08:00
|
|
|
browser.storage.onChanged.addListener(handleChanged);
|
2023-08-05 18:15:01 +08:00
|
|
|
} else if (isGm) {
|
2023-08-05 16:32:49 +08:00
|
|
|
(window.GM_addValueChangeListener || window.GM.addValueChangeListener)(
|
|
|
|
|
"storage",
|
|
|
|
|
handleChanged
|
|
|
|
|
);
|
2023-07-20 13:45:41 +08:00
|
|
|
} else {
|
|
|
|
|
window.addEventListener("storage", handleChanged);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 对storage的封装
|
|
|
|
|
*/
|
|
|
|
|
const storage = {
|
|
|
|
|
get,
|
|
|
|
|
set,
|
|
|
|
|
del,
|
|
|
|
|
setObj,
|
|
|
|
|
trySetObj,
|
|
|
|
|
getObj,
|
|
|
|
|
putObj,
|
|
|
|
|
onChanged,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export default storage;
|