// ==UserScript==
// @name CookieManager
// @namespace https://github.com/WhiteSevs/TamperMonkeyScript
// @version 2025.3.25
// @author WhiteSevs
// @description 简单而强大的Cookie编辑器,允许您快速创建、编辑和删除Cookie
// @license GPL-3.0-only
// @icon 
// @supportURL https://github.com/WhiteSevs/TamperMonkeyScript/issues
// @match *://*/*
// @require https://fastly.jsdelivr.net/gh/WhiteSevs/TamperMonkeyScript@86be74b83fca4fa47521cded28377b35e1d7d2ac/lib/CoverUMD/index.js
// @require https://fastly.jsdelivr.net/npm/@whitesev/[email protected]/dist/index.umd.js
// @require https://fastly.jsdelivr.net/npm/@whitesev/[email protected]/dist/index.umd.js
// @require https://fastly.jsdelivr.net/npm/@whitesev/[email protected]/dist/index.umd.js
// @require https://fastly.jsdelivr.net/npm/[email protected]/dist/index.umd.js
// @connect *
// @grant GM_cookie
// @grant GM_getValue
// @grant GM_info
// @grant GM_registerMenuCommand
// @grant GM_setValue
// @grant GM_unregisterMenuCommand
// @grant unsafeWindow
// @run-at document-start
// ==/UserScript==
(function (Qmsg, DOMUtils, Utils, pops) {
'use strict';
var _a;
var _GM_cookie = /* @__PURE__ */ (() => typeof GM_cookie != "undefined" ? GM_cookie : void 0)();
var _GM_getValue = /* @__PURE__ */ (() => typeof GM_getValue != "undefined" ? GM_getValue : void 0)();
var _GM_info = /* @__PURE__ */ (() => typeof GM_info != "undefined" ? GM_info : void 0)();
var _GM_registerMenuCommand = /* @__PURE__ */ (() => typeof GM_registerMenuCommand != "undefined" ? GM_registerMenuCommand : void 0)();
var _GM_setValue = /* @__PURE__ */ (() => typeof GM_setValue != "undefined" ? GM_setValue : void 0)();
var _GM_unregisterMenuCommand = /* @__PURE__ */ (() => typeof GM_unregisterMenuCommand != "undefined" ? GM_unregisterMenuCommand : void 0)();
var _unsafeWindow = /* @__PURE__ */ (() => typeof unsafeWindow != "undefined" ? unsafeWindow : void 0)();
var _monkeyWindow = /* @__PURE__ */ (() => window)();
const PanelSettingConfig = {
/** Toast位置 */
qmsg_config_position: {
key: "qmsg-config-position",
defaultValue: "bottom"
},
/** 最多显示的数量 */
qmsg_config_maxnums: {
key: "qmsg-config-maxnums",
defaultValue: 3
},
/** 逆序弹出 */
qmsg_config_showreverse: {
key: "qmsg-config-showreverse",
defaultValue: false
}
};
const _SCRIPT_NAME_ = "CookieManager";
const utils = Utils.noConflict();
const domUtils = DOMUtils.noConflict();
const __pops = pops;
const log = new utils.Log(
_GM_info,
_unsafeWindow.console || _monkeyWindow.console
);
const SCRIPT_NAME = ((_a = _GM_info == null ? void 0 : _GM_info.script) == null ? void 0 : _a.name) || _SCRIPT_NAME_;
const DEBUG = false;
log.config({
debug: DEBUG,
logMaxCount: 1e3,
autoClearConsole: true,
tag: true
});
Qmsg.config(
Object.defineProperties(
{
html: true,
autoClose: true,
showClose: false
},
{
position: {
get() {
return PopsPanel.getValue(
PanelSettingConfig.qmsg_config_position.key,
PanelSettingConfig.qmsg_config_position.defaultValue
);
}
},
maxNums: {
get() {
return PopsPanel.getValue(
PanelSettingConfig.qmsg_config_maxnums.key,
PanelSettingConfig.qmsg_config_maxnums.defaultValue
);
}
},
showReverse: {
get() {
return PopsPanel.getValue(
PanelSettingConfig.qmsg_config_showreverse.key,
PanelSettingConfig.qmsg_config_showreverse.defaultValue
);
}
},
zIndex: {
get() {
let maxZIndex = Utils.getMaxZIndex();
let popsMaxZIndex = pops.config.InstanceUtils.getPopsMaxZIndex().zIndex;
return Utils.getMaxValue(maxZIndex, popsMaxZIndex) + 100;
}
}
}
)
);
__pops.GlobalConfig.setGlobalConfig({
zIndex: () => {
let maxZIndex = Utils.getMaxZIndex(void 0, void 0, ($ele) => {
var _a2;
if ((_a2 = $ele == null ? void 0 : $ele.classList) == null ? void 0 : _a2.contains("qmsg-shadow-container")) {
return false;
}
if (($ele == null ? void 0 : $ele.closest("qmsg")) && $ele.getRootNode() instanceof ShadowRoot) {
return false;
}
});
let popsMaxZIndex = pops.config.InstanceUtils.getPopsMaxZIndex().zIndex;
return Utils.getMaxValue(maxZIndex, popsMaxZIndex) + 100;
},
mask: {
// 开启遮罩层
enable: true,
// 取消点击遮罩层的事件
clickEvent: {
toClose: false,
toHide: false
}
}
});
const GM_Menu = new utils.GM_Menu({
GM_getValue: _GM_getValue,
GM_setValue: _GM_setValue,
GM_registerMenuCommand: _GM_registerMenuCommand,
GM_unregisterMenuCommand: _GM_unregisterMenuCommand
});
({
Object: {
defineProperty: _unsafeWindow.Object.defineProperty
},
Function: {
apply: _unsafeWindow.Function.prototype.apply,
call: _unsafeWindow.Function.prototype.call
},
Element: {
appendChild: _unsafeWindow.Element.prototype.appendChild
},
setTimeout: _unsafeWindow.setTimeout
});
utils.addStyle.bind(utils);
document.querySelector.bind(document);
document.querySelectorAll.bind(document);
const utilsCookieManager = new Utils.GM_Cookie();
const KEY = "GM_Panel";
const ATTRIBUTE_INIT = "data-init";
const ATTRIBUTE_KEY = "data-key";
const ATTRIBUTE_DEFAULT_VALUE = "data-default-value";
const ATTRIBUTE_INIT_MORE_VALUE = "data-init-more-value";
const PROPS_STORAGE_API = "data-storage-api";
const UISwitch = function(text, key, defaultValue, clickCallBack, description, afterAddToUListCallBack) {
let result = {
text,
type: "switch",
description,
attributes: {},
props: {},
getValue() {
return Boolean(
this.props[PROPS_STORAGE_API].get(key, defaultValue)
);
},
callback(event, __value) {
let value = Boolean(__value);
log.success(`${value ? "开启" : "关闭"} ${text}`);
if (typeof clickCallBack === "function") {
if (clickCallBack(event, value)) {
return;
}
}
this.props[PROPS_STORAGE_API].set(key, value);
},
afterAddToUListCallBack
};
Reflect.set(result.attributes, ATTRIBUTE_KEY, key);
Reflect.set(result.attributes, ATTRIBUTE_DEFAULT_VALUE, defaultValue);
Reflect.set(result.props, PROPS_STORAGE_API, {
get(key2, defaultValue2) {
return PopsPanel.getValue(key2, defaultValue2);
},
set(key2, value) {
PopsPanel.setValue(key2, value);
}
});
return result;
};
const UISelect = function(text, key, defaultValue, data, callback, description) {
let selectData = [];
if (typeof data === "function") {
selectData = data();
} else {
selectData = data;
}
let result = {
text,
type: "select",
description,
attributes: {},
props: {},
getValue() {
return this.props[PROPS_STORAGE_API].get(key, defaultValue);
},
callback(event, isSelectedValue, isSelectedText) {
let value = isSelectedValue;
log.info(`选择:${isSelectedText}`);
this.props[PROPS_STORAGE_API].set(key, value);
if (typeof callback === "function") {
callback(event, value, isSelectedText);
}
},
data: selectData
};
Reflect.set(result.attributes, ATTRIBUTE_KEY, key);
Reflect.set(result.attributes, ATTRIBUTE_DEFAULT_VALUE, defaultValue);
Reflect.set(result.props, PROPS_STORAGE_API, {
get(key2, defaultValue2) {
return PopsPanel.getValue(key2, defaultValue2);
},
set(key2, value) {
PopsPanel.setValue(key2, value);
}
});
return result;
};
const Component_Common = {
id: "view-general",
title: "通用",
forms: [
{
text: "Toast配置",
type: "forms",
forms: [
UISelect(
"Toast位置",
PanelSettingConfig.qmsg_config_position.key,
PanelSettingConfig.qmsg_config_position.defaultValue,
[
{
value: "topleft",
text: "左上角"
},
{
value: "top",
text: "顶部"
},
{
value: "topright",
text: "右上角"
},
{
value: "left",
text: "左边"
},
{
value: "center",
text: "中间"
},
{
value: "right",
text: "右边"
},
{
value: "bottomleft",
text: "左下角"
},
{
value: "bottom",
text: "底部"
},
{
value: "bottomright",
text: "右下角"
}
],
(event, isSelectValue, isSelectText) => {
log.info("设置当前Qmsg弹出位置" + isSelectText);
},
"Toast显示在页面九宫格的位置"
),
UISelect(
"最多显示的数量",
PanelSettingConfig.qmsg_config_maxnums.key,
PanelSettingConfig.qmsg_config_maxnums.defaultValue,
[
{
value: 1,
text: "1"
},
{
value: 2,
text: "2"
},
{
value: 3,
text: "3"
},
{
value: 4,
text: "4"
},
{
value: 5,
text: "5"
}
],
void 0,
"限制Toast显示的数量"
),
UISwitch(
"逆序弹出",
PanelSettingConfig.qmsg_config_showreverse.key,
PanelSettingConfig.qmsg_config_showreverse.defaultValue,
void 0,
"修改Toast弹出的顺序"
)
]
},
{
text: "Cookie配置",
type: "forms",
forms: [
UISwitch(
"启用GM_cookie Api",
"use-GM-cookie",
false,
void 0,
"获取到的Cookie信息会更完善,需要脚本管理器支持该函数"
)
]
}
]
};
const PanelUISize = {
/**
* 一般设置界面的尺寸
*/
setting: {
get width() {
return window.innerWidth < 550 ? "88vw" : "550px";
},
get height() {
return window.innerHeight < 450 ? "70vh" : "450px";
}
},
/**
* 信息界面,一般用于提示信息之类
*/
info: {
get width() {
return window.innerWidth < 350 ? "350px" : "350px";
},
get height() {
return window.innerHeight < 250 ? "250px" : "250px";
}
}
};
const PopsPanel = {
/** 数据 */
$data: {
__data: null,
__oneSuccessExecMenu: null,
__onceExec: null,
__listenData: null,
/**
* 菜单项的默认值
*/
get data() {
if (PopsPanel.$data.__data == null) {
PopsPanel.$data.__data = new utils.Dictionary();
}
return PopsPanel.$data.__data;
},
/**
* 成功只执行了一次的项
*/
get oneSuccessExecMenu() {
if (PopsPanel.$data.__oneSuccessExecMenu == null) {
PopsPanel.$data.__oneSuccessExecMenu = new utils.Dictionary();
}
return PopsPanel.$data.__oneSuccessExecMenu;
},
/**
* 成功只执行了一次的项
*/
get onceExec() {
if (PopsPanel.$data.__onceExec == null) {
PopsPanel.$data.__onceExec = new utils.Dictionary();
}
return PopsPanel.$data.__onceExec;
},
/** 脚本名,一般用在设置的标题上 */
get scriptName() {
return SCRIPT_NAME;
},
/** 菜单项的总值在本地数据配置的键名 */
key: KEY,
/** 菜单项在attributes上配置的菜单键 */
attributeKeyName: ATTRIBUTE_KEY,
/** 菜单项在attributes上配置的菜单默认值 */
attributeDefaultValueName: ATTRIBUTE_DEFAULT_VALUE
},
/** 监听器 */
$listener: {
/**
* 值改变的监听器
*/
get listenData() {
if (PopsPanel.$data.__listenData == null) {
PopsPanel.$data.__listenData = new utils.Dictionary();
}
return PopsPanel.$data.__listenData;
}
},
init() {
let contentConfigList = this.getPanelContentConfig();
this.initPanelConfigDefaultValue([...contentConfigList]);
this.registerMenu();
},
/** 判断是否是顶层窗口 */
isTopWindow() {
return _unsafeWindow.top === _unsafeWindow.self;
},
/** 初始化进行注册(不可用)油猴菜单 */
registerMenu() {
if (!this.isTopWindow()) {
return;
}
GM_Menu.add([
{
key: "show_pops_panel_setting",
text: "⚙ 设置",
autoReload: false,
isStoreValue: false,
showText(text) {
return text;
},
callback: () => {
this.showPanel();
}
}
]);
},
/** 初始化菜单项的默认值保存到本地数据中 */
initPanelConfigDefaultValue(contentConfigList) {
let that = this;
function initDefaultValue(config) {
if (!config.attributes) {
return;
}
let needInitConfig = {};
let key = config.attributes[ATTRIBUTE_KEY];
if (key != null) {
needInitConfig[key] = config.attributes[ATTRIBUTE_DEFAULT_VALUE];
}
let __attr_init__ = config.attributes[ATTRIBUTE_INIT];
if (typeof __attr_init__ === "function") {
let __attr_result__ = __attr_init__();
if (typeof __attr_result__ === "boolean" && !__attr_result__) {
return;
}
}
let initMoreValue = config.attributes[ATTRIBUTE_INIT_MORE_VALUE];
if (initMoreValue && typeof initMoreValue === "object") {
Object.assign(needInitConfig, initMoreValue);
}
let needInitConfigList = Object.keys(needInitConfig);
if (!needInitConfigList.length) {
if (config.type !== "button") {
log.warn("请先配置键", config);
}
return;
}
needInitConfigList.forEach((__key) => {
let __defaultValue = needInitConfig[__key];
if (that.$data.data.has(__key)) {
log.warn("请检查该key(已存在): " + __key);
}
that.$data.data.set(__key, __defaultValue);
});
}
function loopInitDefaultValue(configList) {
for (let index = 0; index < configList.length; index++) {
let configItem = configList[index];
initDefaultValue(configItem);
let childForms = configItem.forms;
if (childForms && Array.isArray(childForms)) {
loopInitDefaultValue(childForms);
}
}
}
for (let index = 0; index < contentConfigList.length; index++) {
let leftContentConfigItem = contentConfigList[index];
if (!leftContentConfigItem.forms) {
continue;
}
let rightContentConfigList = leftContentConfigItem.forms;
if (rightContentConfigList && Array.isArray(rightContentConfigList)) {
loopInitDefaultValue(rightContentConfigList);
}
}
},
/**
* 设置值
* @param key 键
* @param value 值
*/
setValue(key, value) {
let locaData = _GM_getValue(KEY, {});
let oldValue = locaData[key];
locaData[key] = value;
_GM_setValue(KEY, locaData);
if (this.$listener.listenData.has(key)) {
this.$listener.listenData.get(key).callback(key, oldValue, value);
}
},
/**
* 获取值
* @param key 键
* @param defaultValue 默认值
*/
getValue(key, defaultValue) {
let locaData = _GM_getValue(KEY, {});
let localValue = locaData[key];
if (localValue == null) {
if (this.$data.data.has(key)) {
return this.$data.data.get(key);
}
return defaultValue;
}
return localValue;
},
/**
* 删除值
* @param key 键
*/
deleteValue(key) {
let locaData = _GM_getValue(KEY, {});
let oldValue = locaData[key];
Reflect.deleteProperty(locaData, key);
_GM_setValue(KEY, locaData);
if (this.$listener.listenData.has(key)) {
this.$listener.listenData.get(key).callback(key, oldValue, void 0);
}
},
/**
* 监听调用setValue、deleteValue
* @param key 需要监听的键
* @param callback
*/
addValueChangeListener(key, callback, option) {
let listenerId = Math.random();
this.$listener.listenData.set(key, {
id: listenerId,
key,
callback
});
if (option) {
if (option.immediate) {
callback(key, this.getValue(key), this.getValue(key));
}
}
return listenerId;
},
/**
* 移除监听
* @param listenerId 监听的id
*/
removeValueChangeListener(listenerId) {
let deleteKey = null;
for (const [key, value] of this.$listener.listenData.entries()) {
if (value.id === listenerId) {
deleteKey = key;
break;
}
}
if (typeof deleteKey === "string") {
this.$listener.listenData.delete(deleteKey);
} else {
console.warn("没有找到对应的监听器");
}
},
/**
* 主动触发菜单值改变的回调
* @param key 菜单键
* @param newValue 想要触发的新值,默认使用当前值
* @param oldValue 想要触发的旧值,默认使用当前值
*/
triggerMenuValueChange(key, newValue, oldValue) {
if (this.$listener.listenData.has(key)) {
let listenData = this.$listener.listenData.get(key);
if (typeof listenData.callback === "function") {
let value = this.getValue(key);
let __newValue = value;
let __oldValue = value;
if (typeof newValue !== "undefined" && arguments.length > 1) {
__newValue = newValue;
}
if (typeof oldValue !== "undefined" && arguments.length > 2) {
__oldValue = oldValue;
}
listenData.callback(key, __oldValue, __newValue);
}
}
},
/**
* 判断该键是否存在
* @param key 键
*/
hasKey(key) {
let locaData = _GM_getValue(KEY, {});
return key in locaData;
},
/**
* 自动判断菜单是否启用,然后执行回调
* @param key
* @param callback 回调
* @param isReverse 逆反判断菜单启用
* @param checkEnableCallBack 自定义检测菜单的值,可自行决定是否强制启用菜单,true是启用菜单,false是不启用菜单
*/
execMenu(key, callback, isReverse = false, checkEnableCallBack) {
if (!(typeof key === "string" || typeof key === "object" && Array.isArray(key))) {
throw new TypeError("key 必须是字符串或者字符串数组");
}
let runKeyList = [];
if (typeof key === "object" && Array.isArray(key)) {
runKeyList = [...key];
} else {
runKeyList.push(key);
}
let value = void 0;
for (let index = 0; index < runKeyList.length; index++) {
const runKey = runKeyList[index];
if (!this.$data.data.has(runKey)) {
log.warn(`${key} 键不存在`);
return;
}
let runValue = PopsPanel.getValue(runKey);
if (isReverse) {
runValue = !runValue;
}
if (typeof checkEnableCallBack === "function") {
let checkResult = checkEnableCallBack(runKey, runValue);
if (typeof checkResult === "boolean") {
runValue = checkResult;
}
}
if (!runValue) {
break;
}
value = runValue;
}
if (value) {
callback(value);
}
},
/**
* 自动判断菜单是否启用,然后执行回调,只会执行一次
* @param key
* @param callback 回调
* @param getValueFn 自定义处理获取当前值,值true是启用并执行回调,值false是不执行回调
* @param handleValueChangeFn 自定义处理值改变时的回调,值true是启用并执行回调,值false是不执行回调
* @param checkEnableCallBack 自定义检测菜单的值,可自行决定是否强制启用菜单,true是启用菜单,false是不启用菜单
*/
execMenuOnce(key, callback, getValueFn, handleValueChangeFn, checkEnableCallBack) {
if (typeof key !== "string") {
throw new TypeError("key 必须是字符串");
}
if (!this.$data.data.has(key)) {
log.warn(`${key} 键不存在`);
return;
}
if (this.$data.oneSuccessExecMenu.has(key)) {
return;
}
this.$data.oneSuccessExecMenu.set(key, 1);
let __getValue = () => {
let localValue = PopsPanel.getValue(key);
return typeof getValueFn === "function" ? getValueFn(key, localValue) : localValue;
};
let resultStyleList = [];
let dynamicPushStyleNode = ($style) => {
let __value = __getValue();
let dynamicResultList = [];
if ($style instanceof HTMLStyleElement) {
dynamicResultList = [$style];
} else if (Array.isArray($style)) {
dynamicResultList = [
...$style.filter(
(item) => item != null && item instanceof HTMLStyleElement
)
];
}
if (__value) {
resultStyleList = resultStyleList.concat(dynamicResultList);
} else {
for (let index = 0; index < dynamicResultList.length; index++) {
let $css = dynamicResultList[index];
$css.remove();
dynamicResultList.splice(index, 1);
index--;
}
}
};
let checkMenuEnableCallBack = (currentValue) => {
return typeof checkEnableCallBack === "function" ? checkEnableCallBack(key, currentValue) : currentValue;
};
let changeCallBack = (currentValue) => {
let resultList = [];
if (checkMenuEnableCallBack(currentValue)) {
let result = callback(currentValue, dynamicPushStyleNode);
if (result instanceof HTMLStyleElement) {
resultList = [result];
} else if (Array.isArray(result)) {
resultList = [
...result.filter(
(item) => item != null && item instanceof HTMLStyleElement
)
];
}
}
for (let index = 0; index < resultStyleList.length; index++) {
let $css = resultStyleList[index];
$css.remove();
resultStyleList.splice(index, 1);
index--;
}
resultStyleList = [...resultList];
};
this.addValueChangeListener(
key,
(__key, oldValue, newValue) => {
let __newValue = newValue;
if (typeof handleValueChangeFn === "function") {
__newValue = handleValueChangeFn(__key, newValue, oldValue);
}
changeCallBack(__newValue);
}
);
let value = __getValue();
if (value) {
changeCallBack(value);
}
},
/**
* 父子菜单联动,自动判断菜单是否启用,然后执行回调,只会执行一次
* @param key 菜单键
* @param childKey 子菜单键
* @param callback 回调
* @param replaceValueFn 用于修改mainValue,返回undefined则不做处理
*/
execInheritMenuOnce(key, childKey, callback, replaceValueFn) {
let that = this;
const handleInheritValue = (key2, childKey2) => {
let mainValue = that.getValue(key2);
let childValue = that.getValue(childKey2);
if (typeof replaceValueFn === "function") {
let changedMainValue = replaceValueFn(mainValue, childValue);
if (changedMainValue != null) {
return changedMainValue;
}
}
return mainValue;
};
this.execMenuOnce(
key,
callback,
() => {
return handleInheritValue(key, childKey);
},
() => {
return handleInheritValue(key, childKey);
}
);
this.execMenuOnce(
childKey,
() => {
},
() => false,
() => {
this.triggerMenuValueChange(key);
return false;
}
);
},
/**
* 根据自定义key只执行一次
* @param key 自定义key
*/
onceExec(key, callback) {
if (typeof key !== "string") {
throw new TypeError("key 必须是字符串");
}
if (this.$data.onceExec.has(key)) {
return;
}
callback();
this.$data.onceExec.set(key, 1);
},
/**
* 显示设置面板
*/
showPanel() {
__pops.panel({
title: {
text: `${SCRIPT_NAME}-设置`,
position: "center",
html: false,
style: ""
},
content: this.getPanelContentConfig(),
mask: {
enable: true,
clickEvent: {
toClose: true,
toHide: false
}
},
zIndex() {
let maxZIndex = Utils.getMaxZIndex();
let popsMaxZIndex = __pops.config.InstanceUtils.getPopsMaxZIndex().zIndex;
return Utils.getMaxValue(maxZIndex, popsMaxZIndex) + 100;
},
width: PanelUISize.setting.width,
height: PanelUISize.setting.height,
drag: true,
only: true
});
},
/**
* 获取配置内容
*/
getPanelContentConfig() {
let configList = [Component_Common];
return configList;
}
};
const CookieManager = {
get cookieManagerApiName() {
let managerApi = PopsPanel.getValue(
"cookie-manager-api",
"document.cookie"
);
return managerApi;
},
get cookieManager() {
if (this.cookieManagerApiName === "GM_cookie") {
return _GM_cookie;
} else if (this.cookieManagerApiName === "cookieStore") {
let cookieStore = _unsafeWindow.cookieStore;
return {
list(options, callback) {
cookieStore.getAll().then((result) => {
callback(result);
}).catch((reason) => {
log.error(reason);
Qmsg.error(reason.toString());
});
},
set(cookieInfo, callback) {
cookieStore.set(cookieInfo).then(() => {
callback();
}).catch((reason) => {
callback(reason);
});
},
delete(cookieInfo, callback) {
cookieStore.delete(cookieInfo).then((result) => {
callback();
}).catch((reason) => {
callback(reason);
});
}
};
} else {
return utilsCookieManager;
}
},
/**
* 查询所有Cookie
*/
queryAllCookie() {
return new Promise((resolve) => {
this.cookieManager.list({}, (cookieListResult) => {
let __cookieListResult__ = cookieListResult || [];
__cookieListResult__ = __cookieListResult__.sort(
(a, b) => a.name.localeCompare(b.name)
);
resolve(__cookieListResult__);
});
});
},
/**
* 清除所有Cookie
*/
deleteAllCookie() {
return new Promise((resolve) => {
this.cookieManager.list({}, async (cookieListResult) => {
const __cookieListResult__ = cookieListResult || [];
const result = {
success: 0,
error: 0
};
for (let index = 0; index < __cookieListResult__.length; index++) {
const cookieListItem = __cookieListResult__[index];
let deleteError = await new Promise((deleteResolve) => {
this.deleteCookie(cookieListItem).then((deleteResult) => {
deleteResolve(deleteResult);
});
});
if (deleteError) {
result.error++;
} else {
result.success++;
}
}
resolve(result);
});
});
},
/**
* 添加Cookie
*/
addCookie(cookieInfo) {
return new Promise((resolve) => {
delete cookieInfo.hostOnly;
CookieManager.cookieManager.set(cookieInfo, (error) => {
log.info(["添加Cookie", cookieInfo]);
resolve(error);
});
});
},
/**
* 删除Cookie
*/
deleteCookie(cookieInfo) {
return new Promise((resolve) => {
CookieManager.cookieManager.delete(cookieInfo, (error) => {
log.info(["删除Cookie", cookieInfo]);
resolve(error);
});
});
},
/**
* 更新Cookie
*/
updateCookie(cookieInfo) {
return new Promise(async (resolve) => {
let result;
try {
log.info(["更新Cookie", cookieInfo]);
let deleteError = await CookieManager.deleteCookie(cookieInfo);
log.error(deleteError);
if (deleteError) {
throw new TypeError(deleteError.toString());
}
let addError = await CookieManager.addCookie(cookieInfo);
log.error(addError);
if (addError) {
throw new TypeError(addError.toString());
}
} catch (error) {
result = error;
} finally {
resolve(result);
}
});
}
};
let edit_ui_input = (text, getValue, setValue, disabled) => {
let config = {
text,
type: "input",
isNumber: false,
isPassword: false,
props: {},
attributes: {},
description: "",
getValue() {
return getValue();
},
callback(event, value) {
setValue(value);
},
placeholder: "",
disabled: Boolean(disabled)
};
return config;
};
let edit_ui_select = (text, data, getValue, setValue, disabled) => {
let config = {
text,
type: "select",
description: "",
attributes: {},
props: {},
getValue() {
return getValue();
},
callback(event, isSelectedValue, isSelectedText) {
let value = isSelectedValue;
setValue(value);
},
// @ts-ignore
data,
disabled: Boolean(disabled)
};
return config;
};
const CookieManagerEditView = {
init() {
},
/**
* 显示视图
* @param cookieInfo 需要编辑的cookie
* @param dialogCloseCallBack 弹窗关闭的回调
*/
showView(__cookieInfo__, dialogCloseCallBack) {
let isEdit = !!__cookieInfo__;
let cookieInfo = utils.assign(
{
name: "",
value: "",
domain: window.location.hostname,
path: "/",
secure: false,
hostOnly: false,
httpOnly: false,
sameSite: "lax",
expirationDate: Date.now() + 60 * 60 * 24 * 30 * 1e3
},
__cookieInfo__,
true
);
if (CookieManager.cookieManagerApiName === "cookieStore") {
if (cookieInfo.expires) {
cookieInfo.expirationDate = cookieInfo.expires;
}
}
let $dialog = __pops.confirm({
title: {
text: isEdit ? "编辑Cookie" : "添加Cookie",
position: "center"
},
content: {
text: "",
html: true
},
drag: true,
btn: {
position: "center",
ok: {
text: isEdit ? "编辑" : "添加",
async callback(eventDetails, event) {
let valid = CookieManagerEditView.validCookieInfo(cookieInfo);
if (!valid) {
return;
}
cookieInfo.value = encodeURIComponent(cookieInfo.value);
if (CookieManager.cookieManagerApiName === "document.cookie") {
cookieInfo.domain = "";
} else if (CookieManager.cookieManagerApiName === "GM_cookie") {
cookieInfo.expirationDate = Math.floor(
cookieInfo.expirationDate / 1e3
);
}
if (isEdit) {
let result = await CookieManager.updateCookie(cookieInfo);
if (result) {
Qmsg.error(result.toString());
} else {
Qmsg.success("修改成功");
eventDetails.close();
}
} else {
let result = await CookieManager.addCookie(cookieInfo);
if (result) {
Qmsg.error(result.toString());
} else {
Qmsg.success("添加成功");
eventDetails.close();
}
}
if (typeof dialogCloseCallBack === "function") {
dialogCloseCallBack(cookieInfo);
}
}
},
cancel: {
text: "取消"
}
},
mask: {
enable: true
},
width: window.innerWidth > 350 ? "350px" : "80vw",
height: PanelUISize.setting.height,
style: (
/*css*/
`
${__pops.config.cssText.panelCSS}
.pops-panel-input input:disabled{
color: #b4b4b4;
}
.pops-confirm-content{
padding: 10px;
}
.pops-confirm-content li{
display: flex;
flex-direction: column;
}
.pops-panel-item-left-text{
margin-bottom: 5px;
}
.pops-panel-input.pops-input-disabled{
border: 1px solid #dcdfe6;
}
#cookie-item-property-expires{
border: 1px solid rgb(184, 184, 184, var(--pops-bd-opacity));
border-radius: 4px;
background-color: #ffffff;
width: 100%;
height: 32px;
padding: 0px 8px;
}
#cookie-item-property-expires:hover{
box-shadow: 0 0 0 1px #c0c4cc inset;
}
#cookie-item-property-expires:focus,
#cookie-item-property-expires:focus-within{
outline: 0;
border: 1px solid #409eff;
border-radius: 4px;
box-shadow: none;
}
`
)
});
let $editContent = $dialog.$shadowRoot.querySelector(
".pops-confirm-content"
);
let panelHandleContentUtils = __pops.config.panelHandleContentUtils();
let $name = panelHandleContentUtils.createSectionContainerItem_input(
edit_ui_input(
"name",
() => cookieInfo.name,
(value) => cookieInfo.name = value,
isEdit
)
);
let $value = panelHandleContentUtils.createSectionContainerItem_input(
edit_ui_input(
"value",
() => cookieInfo.value,
(value) => cookieInfo.value = value
)
);
let $domain = panelHandleContentUtils.createSectionContainerItem_input(
edit_ui_input(
"domain",
() => cookieInfo.domain,
(value) => cookieInfo.domain = value
)
);
let $path = panelHandleContentUtils.createSectionContainerItem_input(
edit_ui_input(
"path",
() => cookieInfo.path,
(value) => cookieInfo.path = value
)
);
let $expires;
if (cookieInfo.session) {
$expires = panelHandleContentUtils.createSectionContainerItem_input(
edit_ui_input(
"expires",
() => "会话",
(value) => {
},
true
)
);
} else {
$expires = panelHandleContentUtils.createSectionContainerItem_own({
type: "own",
getLiElementCallBack: function(liElement) {
let $li = domUtils.createElement("li", {
innerHTML: (
/*html*/
`
<div class="pops-panel-item-left-text">
<p class="pops-panel-item-left-main-text">expires</p>
</div>
<div class="pops-panel-item-right-wrapper">
<input type="datetime-local" id="cookie-item-property-expires">
</div>
`
)
});
let $dateTime = $li.querySelector(
"#cookie-item-property-expires"
);
$dateTime.valueAsNumber = cookieInfo.expirationDate;
domUtils.on(
$dateTime,
["change", "input", "propertychange"],
(event) => {
utils.preventEvent(event);
cookieInfo.expirationDate = $dateTime.valueAsNumber;
}
);
return $li;
}
});
}
let $httpOnly = panelHandleContentUtils.createSectionContainerItem_select(
edit_ui_select(
"httpOnly",
[
{
text: "true",
value: true
},
{
text: "false",
value: false
}
],
() => cookieInfo.httpOnly,
(value) => cookieInfo.httpOnly = value
)
);
let $secure = panelHandleContentUtils.createSectionContainerItem_select(
edit_ui_select(
"secure",
[
{
text: "true",
value: true
},
{
text: "false",
value: false
}
],
() => cookieInfo.secure,
(value) => cookieInfo.secure = value
)
);
let sameSiteData = [
{
text: "no_restriction",
value: "no_restriction"
},
{
text: "lax",
value: "lax"
},
{
text: "strict",
value: "strict"
},
{
text: "unspecified",
value: "unspecified"
}
];
if (CookieManager.cookieManagerApiName === "cookieStore") {
sameSiteData = [
{
text: "lax",
value: "lax"
},
{
text: "strict",
value: "strict"
},
{
text: "none",
value: "none"
}
];
}
let $sameSite = panelHandleContentUtils.createSectionContainerItem_select(
edit_ui_select(
"sameSite",
sameSiteData,
() => cookieInfo.sameSite,
(value) => cookieInfo.sameSite = value
)
);
domUtils.append($editContent, [$name, $value]);
if (CookieManager.cookieManagerApiName === "GM_cookie") {
domUtils.append($editContent, [
$domain,
$path,
$expires,
$httpOnly,
$secure,
$sameSite
]);
} else if (CookieManager.cookieManagerApiName === "cookieStore") {
domUtils.append($editContent, [$domain, $path, $expires, $sameSite]);
}
},
/**
* Cookie信息校验
*/
validCookieInfo(cookieInfo) {
if (cookieInfo.name == null || cookieInfo.name == "") {
Qmsg.error("name不能为空");
return false;
}
if (cookieInfo.domain == null || cookieInfo.domain == "") {
Qmsg.error("domain不能为空");
return false;
}
if (cookieInfo.path == null || cookieInfo.path == "") {
Qmsg.error("path不能为空");
return false;
}
return true;
}
};
const CookieManagerView = {
init() {
this.registerMenu();
},
/**
* 显示视图
*/
async showView() {
const $alert = __pops.alert({
title: {
text: "Cookie编辑器",
html: false,
position: "center"
},
content: {
text: (
/*html*/
`
<div class="cookie-wrapper">
<div class="cookie-search-wrapper">
<div class="cookie-search-inner">
<input type="text" placeholder="搜索Cookie名称">
</div>
<div class="cookie-search-setting">
<svg class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4368" width="28" height="28">
<path fill="#2c2c2c" d="M439.264 208a16 16 0 0 0-16 16v67.968a239.744 239.744 0 0 0-46.496 26.896l-58.912-34a16 16 0 0 0-21.856 5.856l-80 138.56a16 16 0 0 0 5.856 21.856l58.896 34a242.624 242.624 0 0 0 0 53.728l-58.88 34a16 16 0 0 0-6.72 20.176l0.848 1.68 80 138.56a16 16 0 0 0 21.856 5.856l58.912-34a239.744 239.744 0 0 0 46.496 26.88V800a16 16 0 0 0 16 16h160a16 16 0 0 0 16-16v-67.968a239.744 239.744 0 0 0 46.512-26.896l58.912 34a16 16 0 0 0 21.856-5.856l80-138.56a16 16 0 0 0-4.288-20.832l-1.568-1.024-58.896-34a242.624 242.624 0 0 0 0-53.728l58.88-34a16 16 0 0 0 6.72-20.176l-0.848-1.68-80-138.56a16 16 0 0 0-21.856-5.856l-58.912 34a239.744 239.744 0 0 0-46.496-26.88V224a16 16 0 0 0-16-16h-160z m32 48h96v67.376l28.8 12.576c13.152 5.76 25.632 12.976 37.184 21.52l25.28 18.688 58.448-33.728 48 83.136-58.368 33.68 3.472 31.2a194.624 194.624 0 0 1 0 43.104l-3.472 31.2 58.368 33.68-48 83.136-58.432-33.728-25.296 18.688c-11.552 8.544-24.032 15.76-37.184 21.52l-28.8 12.576V768h-96v-67.376l-28.784-12.576c-13.152-5.76-25.632-12.976-37.184-21.52l-25.28-18.688-58.448 33.728-48-83.136 58.368-33.68-3.472-31.2a194.624 194.624 0 0 1 0-43.104l3.472-31.2-58.368-33.68 48-83.136 58.432 33.728 25.296-18.688a191.744 191.744 0 0 1 37.184-21.52l28.8-12.576V256z m47.28 144a112 112 0 1 0 0 224 112 112 0 0 0 0-224z m0 48a64 64 0 1 1 0 128 64 64 0 0 1 0-128z"></path>
</svg>
</div>
</div>
<div class="cookie-control-wrapper">
<button class="cookie-control-refresh" type="default">刷新</button>
<button class="cookie-control-add" type="default">添加</button>
<button class="cookie-control-copy-all" type="default">复制全部</button>
<button class="cookie-control-clear-all" type="default">清除全部</button>
<div class="cookie-setting">
<svg class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4368" width="28" height="28">
<path fill="#2c2c2c" d="M439.264 208a16 16 0 0 0-16 16v67.968a239.744 239.744 0 0 0-46.496 26.896l-58.912-34a16 16 0 0 0-21.856 5.856l-80 138.56a16 16 0 0 0 5.856 21.856l58.896 34a242.624 242.624 0 0 0 0 53.728l-58.88 34a16 16 0 0 0-6.72 20.176l0.848 1.68 80 138.56a16 16 0 0 0 21.856 5.856l58.912-34a239.744 239.744 0 0 0 46.496 26.88V800a16 16 0 0 0 16 16h160a16 16 0 0 0 16-16v-67.968a239.744 239.744 0 0 0 46.512-26.896l58.912 34a16 16 0 0 0 21.856-5.856l80-138.56a16 16 0 0 0-4.288-20.832l-1.568-1.024-58.896-34a242.624 242.624 0 0 0 0-53.728l58.88-34a16 16 0 0 0 6.72-20.176l-0.848-1.68-80-138.56a16 16 0 0 0-21.856-5.856l-58.912 34a239.744 239.744 0 0 0-46.496-26.88V224a16 16 0 0 0-16-16h-160z m32 48h96v67.376l28.8 12.576c13.152 5.76 25.632 12.976 37.184 21.52l25.28 18.688 58.448-33.728 48 83.136-58.368 33.68 3.472 31.2a194.624 194.624 0 0 1 0 43.104l-3.472 31.2 58.368 33.68-48 83.136-58.432-33.728-25.296 18.688c-11.552 8.544-24.032 15.76-37.184 21.52l-28.8 12.576V768h-96v-67.376l-28.784-12.576c-13.152-5.76-25.632-12.976-37.184-21.52l-25.28-18.688-58.448 33.728-48-83.136 58.368-33.68-3.472-31.2a194.624 194.624 0 0 1 0-43.104l3.472-31.2-58.368-33.68 48-83.136 58.432 33.728 25.296-18.688a191.744 191.744 0 0 1 37.184-21.52l28.8-12.576V256z m47.28 144a112 112 0 1 0 0 224 112 112 0 0 0 0-224z m0 48a64 64 0 1 1 0 128 64 64 0 0 1 0-128z"></path>
</svg>
</div>
</div>
<div class="cookie-list-wrapper">
</div>
</div>
`
),
html: true
},
btn: {
ok: {
enable: false
}
},
mask: {
enable: true
},
drag: true,
width: PanelUISize.setting.width,
height: PanelUISize.setting.height,
style: (
/*css*/
`
${__pops.config.cssText.panelCSS}
.cookie-wrapper{
display: flex;
flex-direction: column;
padding: 10px;
gap: 10px;
}
.cookie-control-wrapper{
display: flex;
flex-wrap: wrap;
padding: 0px 10px;
gap: 5px;
--button-margin-left: 0px;
}
.cookie-search-wrapper{
display: flex;
align-items: center;
}
.cookie-search-inner{
width: 100%;
padding: 0px 10px;
}
.cookie-search-inner input{
height: 30px;
padding: 5px;
width: 100%;
}
.cookie-search-inner input:focus-visible{
outline: none;
}
.cookie-setting,
.cookie-search-setting{
display: flex;
align-items: center;
}
.cookie-setting svg,
.cookie-search-setting svg{
cursor: pointer;
}
.cookie-list-wrapper{
display: flex;
flex-wrap: wrap;
gap: 10px;
}
.cookie-item{
display: flex;
flex-direction: column;
padding: 10px 10px;
margin: 0px 10px;
background: #f1efef;
border-radius: 10px;
gap: 5px;
box-sizing: border-box;
width: 100%;
}
.cookie-item-group{
display: flex;
align-items: center;
}
.cookie-item-group-left{
width: 100px;
min-width: 100px;
max-width: 100px;
text-transform: capitalize
}
.cookie-item-group-control .cookie-item-group-right{
display: flex;
align-items: center;
gap: 10px;
}
.cookie-item-group-control .cookie-item-group-control-copy,
.cookie-item-group-control .cookie-item-group-control-edit,
.cookie-item-group-control .cookie-item-group-control-delete{
display: flex;
align-items: center;
}
.cookie-item-group-control .cookie-item-group-control-delete svg{
width: 16px;
height: 16px;
}
.cookie-item-group-control svg{
cursor: pointer;
}
`
)
});
const $search = $alert.$shadowRoot.querySelector(
".cookie-search-inner input"
);
const $searchSetting = $alert.$shadowRoot.querySelector(
".cookie-search-setting"
);
const $refresh = $alert.$shadowRoot.querySelector(
".cookie-control-refresh"
);
const $add = $alert.$shadowRoot.querySelector(
".cookie-control-add"
);
const $copyAll = $alert.$shadowRoot.querySelector(
".cookie-control-copy-all"
);
const $clearAll = $alert.$shadowRoot.querySelector(
".cookie-control-clear-all"
);
const $setting = $alert.$shadowRoot.querySelector(".cookie-setting");
const $cookieListWrapper = $alert.$shadowRoot.querySelector(
".cookie-list-wrapper"
);
let createCookieItemElement = (cookieInfo) => {
const $cookieItem = domUtils.createElement("div", {
className: "cookie-item",
innerHTML: (
/*html*/
`
`
)
});
const cookieProperty = [
{
leftText: "name",
rightText: cookieInfo.name
},
{
leftText: "value",
rightText: PopsPanel.getValue("decode-cookie-value") ? decodeURIComponent(cookieInfo.value) : encodeURIComponent(cookieInfo.value)
}
];
if (CookieManager.cookieManagerApiName === "GM_cookie") {
cookieInfo = cookieInfo;
cookieProperty.push(
{
leftText: "domain",
rightText: cookieInfo.domain
},
{
leftText: "path",
rightText: cookieInfo.path
},
{
leftText: "session",
rightText: JSON.stringify(cookieInfo.session)
},
{
leftText: "expires",
rightText: cookieInfo.session ? "会话" : cookieInfo.expirationDate ? new Date(cookieInfo.expirationDate * 1e3).toISOString() : "未知"
},
{
leftText: "httpOnly",
rightText: JSON.stringify(cookieInfo.httpOnly)
},
{
leftText: "hostOnly",
rightText: JSON.stringify(cookieInfo.hostOnly)
},
{
leftText: "secure",
rightText: JSON.stringify(cookieInfo.secure)
},
{
leftText: "sameSite",
rightText: cookieInfo.sameSite
}
);
} else if (CookieManager.cookieManagerApiName === "cookieStore") {
cookieInfo = cookieInfo;
cookieProperty.push(
{
leftText: "domain",
rightText: cookieInfo.domain
},
{
leftText: "path",
rightText: cookieInfo.path
},
{
leftText: "expires",
rightText: cookieInfo.expires ? new Date(cookieInfo.expires).toISOString() : "未知"
},
{
leftText: "secure",
rightText: JSON.stringify(cookieInfo.secure)
},
{
leftText: "sameSite",
rightText: cookieInfo.sameSite
}
);
}
cookieProperty.forEach((it) => {
const $cookieItemGroup = domUtils.createElement("div", {
className: "cookie-item-group",
innerHTML: (
/*html*/
`
<div class="cookie-item-group-left">
<p>${it.leftText}</p>
</div>
<div class="cookie-item-group-right">
<p>${it.rightText}</p>
</div>
`
)
});
domUtils.append($cookieItem, $cookieItemGroup);
});
let $cookieItemGroupControl = domUtils.createElement("div", {
className: "cookie-item-group cookie-item-group-control",
innerHTML: (
/*html*/
`
<div class="cookie-item-group-left">操作</div>
<div class="cookie-item-group-right">
<div class="cookie-item-group-control-copy">
<svg t="1742795616339" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" width="16" height="16">
<path d="M880 247.008l-162.016-166.016Q700.992 64 677.984 64h-316.992q-26.016 0-46.016 18.016-16.992 15.008-23.008 36.992H231.968q-43.008 0-73.504 31.008t-30.496 76v627.008q0 44 30.496 75.488T231.968 960h508q43.008 0 73.504-31.488t30.496-75.488v-63.008q23.008-6.016 37.504-25.504t14.496-44.512V287.008q0-24-16-40z m-168-160.992l-3.008-3.008z m98.016 177.984L744 196z m-126.016-116.992l108 110.016h-108V147.008zM676.992 128zM204.992 948q4 0.992 4.992 2.016-2.016-0.992-4.992-2.016z m27.008 4q-6.016 0-12-0.992 4.992 0.992 12 0.992z m543.008-99.008q0 15.008-10.016 25.504t-24.992 10.496H232q-14.016 0-24.512-10.496t-10.496-25.504V225.984q0-15.008 10.496-25.504t24.512-10.496h58.016v531.008q0 30.016 20.992 51.008t50.016 20.992H775.04v60z m52-132.992q0 2.016-2.016 2.016h-464q-2.016 0-2.016-2.016V136.992q0-2.016 2.016-2.016h251.008v156.992q0 15.008 10.016 24.992t24 10.016h180.992v392.992z m9.984 64q4-0.992 8.992-2.016-4.992 0.992-8.992 2.016z m-244-168.992h-107.008q-15.008 0-24.992 10.496t-10.016 24.992 10.016 24.992 24.992 10.496h107.008q14.016 0 24.512-10.496t10.496-24.992-10.496-24.992-24.512-10.496z m107.008-111.008h-214.016q-14.016 0-24.512 10.496t-10.496 24.992 10.496 24.992 24.512 10.496h214.016q14.016 0 24-10.496t10.016-24.992-10.016-24.992-24-10.496z m-240.992 36q0 4 0.992 8-0.992-4-0.992-8zM700 512z m12 52l4-2.016z m-260.992-135.488q0 14.496 10.496 24.992t24.512 10.496h214.016q14.016 0 24-10.496t10.016-24.992-10.016-24.992-24-10.496h-214.016q-14.016 0-24.512 10.496t-10.496 24.992z m8 1.504z"></path>
</svg>
</div>
<div class="cookie-item-group-control-edit">
<svg t="1742795710451" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" width="16" height="16">
<path d="M800 960 224 960c-52.928 0-96-43.072-96-96L128 224c0-52.928 43.072-96 96-96l448 0c17.696 0 32 14.336 32 32s-14.304 32-32 32L224 192C206.368 192 192 206.368 192 224l0 640c0 17.664 14.368 32 32 32l576 0c17.664 0 32-14.336 32-32L832 352c0-17.664 14.304-32 32-32s32 14.336 32 32l0 512C896 916.928 852.928 960 800 960zM612 448c-8.192 0-16.384-3.136-22.624-9.376-12.512-12.512-12.512-32.736 0-45.248l318.016-318.016c12.512-12.512 32.736-12.512 45.248 0s12.512 32.736 0 45.248l-318.016 318.016C628.384 444.896 620.192 448 612 448zM480 448 288 448c-17.664 0-32-14.336-32-32s14.336-32 32-32l192 0c17.664 0 32 14.336 32 32S497.664 448 480 448zM672 640 288 640c-17.664 0-32-14.304-32-32s14.336-32 32-32l384 0c17.696 0 32 14.304 32 32S689.696 640 672 640z"></path>
</svg>
</div>
<div class="cookie-item-group-control-delete">
${__pops.config.iconSVG.delete}
</div>
</div>
`
)
});
let $cookieItemCopy = $cookieItemGroupControl.querySelector(
".cookie-item-group-control-copy"
);
let $cookieItemEdit = $cookieItemGroupControl.querySelector(
".cookie-item-group-control-edit"
);
let $cookieItemDelete = $cookieItemGroupControl.querySelector(
".cookie-item-group-control-delete"
);
domUtils.on($cookieItemCopy, "click", (event) => {
utils.preventEvent(event);
let cookieText = cookieInfo.value;
utils.setClip(cookieText).then((status) => {
if (status) {
Qmsg.success("复制成功");
} else {
Qmsg.error("复制失败");
}
});
});
domUtils.on($cookieItemEdit, "click", (event) => {
utils.preventEvent(event);
CookieManagerEditView.showView(cookieInfo, (__cookieInfo__) => {
var _a2;
let $newCookieItem = createCookieItemElement(__cookieInfo__);
domUtils.after($cookieItem, $newCookieItem);
(_a2 = $cookieItem.parentElement) == null ? void 0 : _a2.removeChild($cookieItem);
});
});
domUtils.on($cookieItemDelete, "click", (event) => {
utils.preventEvent(event);
let result = confirm("确定删除该Cookie?");
if (!result) {
return;
}
CookieManager.deleteCookie(cookieInfo).then((status) => {
var _a2;
if (!status) {
Qmsg.success("删除成功");
(_a2 = $cookieItem.parentElement) == null ? void 0 : _a2.removeChild($cookieItem);
} else {
log.error(status);
Qmsg.error("删除失败");
}
});
});
domUtils.append($cookieItem, [$cookieItemGroupControl]);
return $cookieItem;
};
let updateCookieListGroup = async (filterCallBack) => {
let cookieList = await CookieManager.queryAllCookie();
if (typeof filterCallBack === "function") {
cookieList = cookieList.filter(filterCallBack);
}
domUtils.empty($cookieListWrapper);
let $fragment = document.createDocumentFragment();
cookieList.forEach((cookieItem) => {
if (
// @ts-ignore
cookieItem.session && PopsPanel.getValue("exclude-session-cookie")
) {
return;
}
const $cookieItem = createCookieItemElement(cookieItem);
domUtils.append($fragment, $cookieItem);
});
domUtils.append($cookieListWrapper, $fragment);
};
updateCookieListGroup();
domUtils.on(
$search,
["input", "propertychange"],
utils.debounce((event) => {
updateCookieListGroup((cookieItem) => {
let searchText = domUtils.val($search);
let enableRegExp = PopsPanel.getValue(
"search-config-use-regexp"
);
return enableRegExp ? Boolean(cookieItem.name.match(new RegExp(searchText))) : cookieItem.name.includes(searchText);
});
})
);
domUtils.listenKeyboard(
$search,
"keypress",
(keyName, keyValue, otherCodeList) => {
if (keyName === "Enter" && otherCodeList.length === 0) {
utils.dispatchEvent($search, "input");
}
}
);
domUtils.on($searchSetting, "click", (event) => {
utils.preventEvent(event);
let $settingAlert = __pops.alert({
title: {
text: "搜索配置",
position: "center"
},
content: {
text: "",
html: true
},
btn: {
ok: {
enable: false
}
},
drag: true,
mask: {
clickEvent: {
toClose: true
}
},
width: PanelUISize.info.width,
height: PanelUISize.info.height,
style: (
/*css*/
`
${__pops.config.cssText.panelCSS}
.pops-alert-content li{
display: flex;
justify-content: space-between;
align-items: center;
padding: 10px;
}
.pops-panel-item-left-desc-text{
line-height: normal;
margin-top: 6px;
font-size: 0.8em;
color: rgb(108, 108, 108);
}
`
)
});
let $content = $settingAlert.$shadowRoot.querySelector(
".pops-alert-content"
);
let panelHandleContentUtils = __pops.config.panelHandleContentUtils();
let $useRegExp = panelHandleContentUtils.createSectionContainerItem_switch(
UISwitch(
"启用正则表达式",
"search-config-use-regexp",
false,
void 0,
"使用正则表达式搜索Cookie名称"
)
);
domUtils.append($content, $useRegExp);
});
domUtils.on($refresh, "click", (event) => {
utils.preventEvent(event);
let searchText = domUtils.val($search);
if (searchText == "") {
updateCookieListGroup();
} else {
utils.dispatchEvent($search, "input");
}
});
domUtils.on($add, "click", (event) => {
utils.preventEvent(event);
CookieManagerEditView.showView(void 0, (__cookieInfo__) => {
updateCookieListGroup();
});
});
domUtils.on($copyAll, "click", (event) => {
utils.preventEvent(event);
CookieManager.queryAllCookie().then((cookieList) => {
cookieList = cookieList.filter((it) => {
return !(it.session && PopsPanel.getValue("exclude-session-cookie"));
});
if (cookieList.length === 0) {
Qmsg.warning("没有Cookie可以复制");
return;
}
let cookieText = cookieList.map((it) => {
let cookieItemValueText = it.value;
return `${it.name}=${cookieItemValueText}; `;
}).join("");
utils.setClip(cookieText).then((status) => {
if (status) {
Qmsg.success("复制成功");
} else {
Qmsg.error("复制失败");
}
});
});
});
domUtils.on($clearAll, "click", (event) => {
utils.preventEvent(event);
let result = window.confirm("确定清除全部Cookie?");
if (!result) {
return;
}
CookieManager.deleteAllCookie().then((deleteInfo) => {
if (deleteInfo.error) {
Qmsg.warning(
`清除成功:${deleteInfo.success} 失败:${deleteInfo.error}`
);
} else {
Qmsg.success("清除成功");
}
updateCookieListGroup();
});
});
domUtils.on($setting, "click", (event) => {
utils.preventEvent(event);
let $settingAlert = __pops.alert({
title: {
text: "设置",
position: "center"
},
content: {
text: "",
html: true
},
btn: {
ok: {
enable: false
}
},
drag: true,
mask: {
clickEvent: {
toClose: true
}
},
width: PanelUISize.info.width,
height: PanelUISize.info.height,
style: (
/*css*/
`
${__pops.config.cssText.panelCSS}
.pops-alert-content li{
display: flex;
justify-content: space-between;
align-items: center;
padding: 10px;
}
.pops-panel-item-left-desc-text{
line-height: normal;
margin-top: 6px;
font-size: 0.8em;
color: rgb(108, 108, 108);
}
`
)
});
let $content = $settingAlert.$shadowRoot.querySelector(
".pops-alert-content"
);
let panelHandleContentUtils = __pops.config.panelHandleContentUtils();
let $useGM_cookie = panelHandleContentUtils.createSectionContainerItem_select(
UISelect(
"CookieManager Api",
"cookie-manager-api",
"document.cookie",
[
{
text: "document.cookie",
value: "document.cookie"
},
{
text: "cookieStore",
value: "cookieStore"
},
{
text: "GM_cookie",
value: "GM_cookie"
}
],
() => {
updateCookieListGroup();
},
"操作Cookie的Api函数"
)
);
let $decodeValue = panelHandleContentUtils.createSectionContainerItem_switch(
UISwitch(
"解码Cookie值",
"decode-cookie-value",
false,
() => {
updateCookieListGroup();
},
"对Cookie值进行解码"
)
);
let $excludeSessionCookie = panelHandleContentUtils.createSectionContainerItem_switch(
UISwitch(
"排除Session Cookie",
"exclude-session-cookie",
false,
() => {
updateCookieListGroup();
},
"过滤掉浏览器会话Cookie"
)
);
domUtils.append($content, [
$useGM_cookie,
$decodeValue,
$excludeSessionCookie
]);
});
},
/**
* 注册(不可用)脚本菜单
*/
registerMenu() {
const that = this;
GM_Menu.add({
key: "cookie_manager_view",
text: "⚙ Cookie管理",
autoReload: false,
isStoreValue: false,
showText(text, enable) {
return text;
},
callback(data) {
that.showView();
}
});
}
};
PopsPanel.init();
CookieManagerView.init();
})(Qmsg, DOMUtils, Utils, pops);