您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
顶部加载条 => 进度条 | 个性化滚动条 | favicon 替换 | 自定义字体 | 百度 / 语雀 / ComfyUI / DeepSeek / ChatGPT ... 多站点界面个性化增强
// ==UserScript== // @name 全局定制 Global.Custom // @description 顶部加载条 => 进度条 | 个性化滚动条 | favicon 替换 | 自定义字体 | 百度 / 语雀 / ComfyUI / DeepSeek / ChatGPT ... 多站点界面个性化增强 // @version 5.5.1 // @author YMN // @icon https://greasyfork.org/vite/assets/blacklogo96-CxYTSM_T.png // @sourceXXX https://greasyfork.org/scripts/539125 // @match *://**/* // @include *://baidu.com/* // @include *://google.com/* // @include *://bing.com/* // @include *://youtube.com/* // @include *://bilibili.com/* // @include *://chat.deepseek.com/* // @include *://deepseek.com/* // @include *://chatgpt.com/* // @include *://zhihu.com/* // @include *://localhost:*/* // @include *://127.0.0.1:*/* // @exclude *://xxxxx.com/* // @run-at document-start // @grant GM_addStyle // @grant GM_getValue // @grant GM_setValue // @grant GM_registerMenuCommand // @grant GM_deleteValue // @connect XXXXX // @namespace https://github.com/rvnymn // @homepageURL https://greasyfork.org/scripts/539125 // @compatible Chrome // @license MIT // @copyright 2025 YMN // @contact [email protected] // @supportURL https://greasyfork.org/zh-CN/scripts/539125/feedback // @contributionURL https://buymeacoffee.com/rvnymn // @LOG 20.02.02 - Ver.0.1.0 // @LOG 25.03.14 - Ver.1.0.0 // @LOG 25.04.05 - Ver.2.0.0 // @LOG 25.04.24 - Ver.3.0.0 // @LOG 25.05.12 - Ver.4.0.0 // @LOG 25.06.05 - Ver.5.0.0 // @LOG 25.06.12 - Ver.5.2.4 // @LOG 25.07.16 - Ver.5.3.0 // @LOG 25.07.21 - Ver.5.4.0 // @LOG 25.08.01 - Ver.5.5.0 // ==/UserScript== /** * & TODO * * = ========== ↓ NEXT * = * = * + ========== ↓ NEW * + * + 挂载 悬浮/面板按钮 点击呼出弹窗 可输入多行下载链接 进行 单独/批量下载 「调用浏览器原生方式」 * + * + * # ========== ↓ OPTIMIZE * # * # 样式 .vbnTips * # VBN_GLOBAL_CACHE.valueStorage 存储各模块开关 当前最新 实时 的值 可在各具体功能 UI面板 获取/更新 让状态共联 * # VBN_OBSERVER_CENTER 可暴露 debugListObservers() debug开启时输出当前所有活跃的目标和监听函数数量 * # VBN_GlobalVariable 采用社区 --vbn-c-xxxxx 小写短横线的方式 按应用场景划分 完善亮暗主题适配颜色 * # * ! ========== ↓ WARN * ! * ! 应用样式的效率问题 可能是主逻辑过重所导致 * ! 某些网站更新页面内容后 需要手动刷新才可正确应用样式 * ! * ! * ? ========== ↓ ERROR * ? * ? * */ if (window.VBN_GLOBAL_CUSTOM || window.top !== window.self) return; window.VBN_GLOBAL_CUSTOM = true; (function VBN_GlobalVariable() { 'use strict'; GM_addStyle( /* css */ ` :root, [vbnGlobalColor] { --vbnBase09HEX: #F9F9F9; --vbnBase08HEX: #F4F4F4; --vbnBase07HEX: #BEC2CA; --vbnBase06HEX: #ABB0BA; --vbnBase05HEX: #757C8A; --vbnBase04HEX: #454A54; --vbnBase03HEX: #353941; --vbnBase02HEX: #2C2F35; --vbnBase01HEX: #1F2228; --vbnBase00HEX: #1C1E22; --vbnBase00HSL: var(--vbnBase00HSL-H), var(--vbnBase00HSL-S), var(--vbnBase00HSL-L); --vbnBase01HSL: var(--vbnBase00HSL-H), var(--vbnBase01HSL-S), var(--vbnBase01HSL-L); --vbnBase02HSL: var(--vbnBase00HSL-H), var(--vbnBase02HSL-S), var(--vbnBase02HSL-L); --vbnBase03HSL: var(--vbnBase00HSL-H), var(--vbnBase03HSL-S), var(--vbnBase03HSL-L); --vbnBase04HSL: var(--vbnBase00HSL-H), var(--vbnBase04HSL-S), var(--vbnBase04HSL-L); --vbnBase05HSL: var(--vbnBase00HSL-H), var(--vbnBase05HSL-S), var(--vbnBase05HSL-L); --vbnBase06HSL: var(--vbnBase00HSL-H), var(--vbnBase06HSL-S), var(--vbnBase06HSL-L); --vbnBase07HSL: var(--vbnBase00HSL-H), var(--vbnBase07HSL-S), var(--vbnBase07HSL-L); --vbnBase08HSL: var(--vbnBase00HSL-H), var(--vbnBase08HSL-S), var(--vbnBase08HSL-L); --vbnBase09HSL: var(--vbnBase00HSL-H), var(--vbnBase09HSL-S), var(--vbnBase09HSL-L); --vbnBase00HSL-H: 220; --vbnBase00HSL-S: 10%; --vbnBase00HSL-L: 12%; --vbnBase01HSL-S: 13%; --vbnBase01HSL-L: 34%; --vbnBase02HSL-S: 09%; --vbnBase02HSL-L: 19%; --vbnBase03HSL-S: 10%; --vbnBase03HSL-L: 23%; --vbnBase04HSL-S: 10%; --vbnBase04HSL-L: 30%; --vbnBase05HSL-S: 08%; --vbnBase05HSL-L: 50%; --vbnBase06HSL-S: 10%; --vbnBase06HSL-L: 70%; --vbnBase07HSL-S: 10%; --vbnBase07HSL-L: 77%; --vbnBase08HSL-S: 00%; --vbnBase08HSL-L: 96%; --vbnBase09HSL-S: 00%; --vbnBase09HSL-L: 98%; --vbnBase02AltXXX: var(--vbnBase00HSL-H), calc(var(--vbnBase02HSL-S) - 000%), calc(var(--vbnBase02HSL-L) - 000%); --vbnBase02PickXX: var(--vbnBase00HSL-H), calc(var(--vbnBase02HSL-S) - 000%), calc(var(--vbnBase02HSL-L) - 000%); --vbnBase02Border: var(--vbnBase00HSL-H), calc(var(--vbnBase02HSL-S) - 000%), calc(var(--vbnBase02HSL-L) + 020%); --vbnBase02Shadow: var(--vbnBase00HSL-H), calc(var(--vbnBase04HSL-S) - 000%), calc(var(--vbnBase04HSL-L) - 000%); --vbnBase04AltXXX: var(--vbnBase00HSL-H), calc(var(--vbnBase04HSL-S) - 000%), calc(var(--vbnBase04HSL-L) - 000%); --vbnBase04PickXX: var(--vbnBase00HSL-H), calc(var(--vbnBase04HSL-S) - 000%), calc(var(--vbnBase04HSL-L) - 010%); --vbnBase04Border: var(--vbnBase00HSL-H), calc(var(--vbnBase04HSL-S) - 000%), calc(var(--vbnBase04HSL-L) + 020%); --vbnBase04Shadow: var(--vbnBase00HSL-H), calc(var(--vbnBase04HSL-S) - 000%), calc(var(--vbnBase04HSL-L) - 000%); --vbnGlow09HEX: #85E0D7; --vbnGlow02HEX: #9087F8; --vbnGlow06HEX: #CEF4FD; --vbnGlow00HEX: #D9B9F9; --vbnGlow08HEX: #BCF5F4; --vbnGlow07HEX: #F7F0B7; --vbnGlow05HEX: #79ECD9; --vbnGlow04HEX: #13EC99; --vbnGlow03HEX: #25F493; --vbnGlow01HEX: #708BC2; --vbnGlow09HSL: 174, 059%, 070%; --vbnGlow02HSL: 245, 089%, 075%; --vbnGlow06HSL: 191, 092%, 090%; --vbnGlow00HSL: 270, 084%, 085%; --vbnGlow08HSL: 179, 074%, 085%; --vbnGlow07HSL: 053, 080%, 084%; --vbnGlow05HSL: 170, 075%, 070%; --vbnGlow04HSL: 157, 085%, 050%; --vbnGlow03HSL: 152, 090%, 055%; --vbnGlow01HSL: 220, 040%, 060%; --vbnMarkdownH1: #494F4D; --vbnMarkdownH2: #515463; --vbnMarkdownH3: #40465D; --vbnMarkdownH4: #4D5B66; --vbnMarkdownH5: #4F5E68; --vbnMarkdownH6: #5B7481; --vbnRed00000: #EF4444; --vbnOrange00: #EE5C2A; --vbnYellow00: var(--vbnGlow07HEX); --vbnGreen000: #10B981; --vbnCyan0000: #00B3B3; --vbnBlue0000: #478BE5; --vbnPurple00: var(--vbnGlow02HEX); --vbnRed00001: #000; --vbnOrange01: #FF5242; --vbnYellow01: #000; --vbnGreen001: #29F9A9; --vbnCyan0001: #000; --vbnBlue0001: #2BC2FF; --vbnPurple01: #000; --vbnLink: var(--vbnBlue0000); --vbnStateCorrect: var(--vbnGreen000); --vbnStateWarn: var(--vbnOrange00); --vbnStateError: var(--vbnRed00000); --vbnStateVisited: var(--vbnCyan0000); --vbnStateMatch: var(--vbnOrange01); --vbnBackdrop: ; --vbnForeground: ; --vbnBackground: ; --vbnGlassDark: hsla(var(--vbnPrimaryHSL), .526); --vbnGlassLight: hsla(var(--vbnBase09HSL), .526); --vbn115: #2777F8; --vbnBaidu: #4E6EF2; --vbnIQIYI: #00F48E; --vbnBiliPink: #FB7299; --vbnBiliBlue: #00AEEC; } :root, [vbnGlobalFont] { --vbnBaseFont: Emoji, "Public Sans", "Inter", "PingFang SC", "Source Han Sans SC", "Microsoft YaHei", sans-serif, system-ui; --vbnBaseSize: 14px; --vbnBaseWeight: 400; --vbnBaseLineHeight: 1.5; --vbnBaseColor: var(--vbnBase04HEX); --vbnTitleSize: 24px; --vbnTitleWeight: 700; --vbnTitleLineHeight: 1.5; --vbnTitleColor: var(--vbnBase02HEX); --vbnCodeFont: "JetBrains Mono", "Fira Code", "PingFang SC", "Source Han Sans SC", "Microsoft YaHei", monospace; --vbnCodeSize: 12px; --vbnCodeWeight: 400; --vbnCodeLineHeight: 1.5; --vbnCodeColor: var(--vbnAccentHEX); --vbnOftenFontBase: var(--vbnBaseWeight) var(--vbnBaseSize)/var(--vbnBaseLineHeight) var(--vbnBaseFont); --vbnOftenFontTitle: var(--vbnTitleWeight) var(--vbnTitleSize)/var(--vbnTitleLineHeight) var(--vbnBaseFont); } @font-face { font-family: Emoji; src: local("Apple Color Emoji"), local("Segoe UI Emoji"), local("Segoe UI Symbol"), local("Noto Color Emoji"); unicode-range: U+1F000-1F9FF; } :root, [vbnGlobalSpace] { --vbnPriority00: 9999; --vbnPriority02: 999999; --vbnPriority09: 999999999; --vbnPriorityHead: ; --vbnPrioritySidebar: ; --vbnPriorityFooter: ; --vbnPriorityBase: ; --vbnSpace2X: 20px; --vbnSpace4X: 60px; --vbnSpace2Y: 260px; --vbnSpace4Y: 292.6px; --vbnSpaceAxialX: 1.26%; --vbnSpaceAxialY: ; --vbnSpaceWidth00: 80%; --vbnSpaceWidth02: 40vw; --vbnSpaceWidthVW: 60vw; --vbnSpaceWidthPX: calc(260px + 920px + 220px); --vbnSpaceHead: ; --vbnSpacePadding: 10px 20px; --vbnSpaceMargin: 15px 0; --vbnButtonWidth: 92px; --vbnButtonHeight: 40px; --vbnButtonPadding: ; --vbnButtonAxialX: ; --vbnButtonAxialY: ; --vbnButtonBase: ; --vbnTransitionSmooth: cubic-bezier(.260, .920, .60, 0.926); --vbnTransitionSoft: cubic-bezier(.250, .460, .45, 0.940); --vbnTransitionDrop: cubic-bezier(.240, .920, .92, 0.240); --vbnTransitionZoom: cubic-bezier(.526, .260, .92, 0.920); --vbnTransitionFlow: cubic-bezier(.240, .926, .60, 0.920); --vbnTransitionElastic: cubic-bezier(.175, .885, .32, 1.260); --vbnOftenTransition: all .526s var(--vbnTransitionSoft); } :root, [vbnGlobalStyle] { --vbnBaseRadius: 4px; --vbnBaseBorder: 1px solid; --vbnBaseShadow: 0 0 10px 0; --vbnBaseFilter: blur(5.26px); --vbnBaseZoomIn: ; --vbnOftenBaseBorderBase: var(); --vbnOftenBaseBorderHover: var(); --vbnOftenBaseShadowBase: var(); --vbnOftenBaseShadowHover: var(); --vbnUIRadius: 6px; --vbnUIBorder: 2px solid; --vbnUIShadow: 10px 10px 20px 0; --vbnUIFilter: blur(9.26px) saturate(1.52); --vbnUIZoomIn: scale(1.26); --vbnOftenUIBorderBase: var(--vbnUIBorder) hsla(var(--vbnAccentHSL), .4); --vbnOftenUIBorderHover: var(); --vbnOftenUIShadowBase: var(); --vbnOftenUIShadowHover: var(); --vbnPanelRadius: 12.6px; --vbnPanelBorder: 3px solid; --vbnPanelShadow: 0px 10px 20px 0; --vbnPanelFilter: blur(12.6px); --vbnPanelZoomIn: ; --vbnOftenPanelBorderBase: var(--vbnPanelBorder) hsla(var(--vbnAccentHSL), .4); --vbnOftenPanelBorderHover: var(--vbnPanelBorder) hsla(var(--vbnAccentHSL), .6); --vbnOftenPanelShadowBase: var(--vbnPanelShadow) hsla(var(--vbnAccentShadow), .4); --vbnOftenPanelShadowHover: var(--vbnPanelShadow) hsla(var(--vbnAccentShadow), .6); --vbnSurfaceRadius: 20.6px; --vbnSurfaceBorder: 2px solid; --vbnSurfaceShadow: 0px 20px 30px 0; --vbnSurfaceFilter: blur(20.6px); --vbnSurfaceZoomIn: scale(1.026); --vbnOftenSurfaceBorderBase: var(); --vbnOftenSurfaceBorderHover: var(); --vbnOftenSurfaceShadowBase: var(--vbnSurfaceShadow) hsla(var(--vbnBase04HSL), .05); --vbnOftenSurfaceShadowHover: var(--vbnSurfaceShadow) hsla(var(--vbnAccentHSL), .126); --vbnGlassShadow: inset 0px -1px 4px hsla(var(--vbnBase09HSL), .26), var(--vbnPanelShadow) hsla(var(--vbnBase04HSL), .0526); --vbnTipsShadow-S: inset 0 0 0 2px; --vbnTipsShadow-M: 10px 10px 20px; --vbnTipsShadow-L: 10px 10px 40px; } :root, [vbnGlobalURL] { --vbnICON-URL-Deepseek: url(""); --vbnICON-URL-OpenAI: url(""); --vbnICON-URL-OpenAI-Dark: url(""); --vbnICON-URL-Gemini-Vint: url(""); --vbnICON-URL-Gemini-Fill: url(""); --vbnICON-URL-Gemini-Line: url(""); --vbnICON-URL-Liblib: url(""); --vbnICON-URL-Prompt: url(""); --vbnICON-URL-Workflow: url(""); --vbnICON-URL-Tick: url(""); --vbnICON-URL-Tick-Vint: url(""); --vbnICON-URL-YUQUE: url(""); --vbnICON-URL-YUQUE-Line: url(""); --vbnICON-URL-Markdown-Line: url(""); --vbnICON-URL-Markdown-Fill: url(""); --vbnICON-URL-Twitter: url(""); --vbnICON-URL-Dict: url(""); --vbnICON-URL-AIGC: url(""); --vbnICON-URL-Character: url(""); --vbnICON-URL-Network: url(""); --vbnICON-URL-SVG: url(""); --vbnICON-URL-Mecha: url(""); --vbnICON-URL-Music: url(""); --vbnICON-URL-VideoPlay: url(""); --vbnICON-URL-VideoStop: url(""); --vbnICON-URL-Correct: url(""); --vbnICON-URL-Error: url(""); --vbnICON-URL-Transition: url(""); --vbnICON-URL-Info: url(""); --vbnICON-URL-Safety: url(""); } .vbnThemeDark { --vbnAccentHEX: #4C525E; --vbnAccentHSL: 220, 011%, 033%; --vbnAccentHSL-H: 220; --vbnAccentHSL-S: 11%; --vbnAccentHSL-L: 33%; --vbnAccentAltXXX: var(--vbnAccentHSL-H), calc(var(--vbnAccentHSL-S) - 000%), calc(var(--vbnAccentHSL-L) - 000%); --vbnAccentPickXX: var(--vbnAccentHSL-H), calc(var(--vbnAccentHSL-S) - 002%), calc(var(--vbnAccentHSL-L) - 010%); --vbnAccentBorder: var(--vbnAccentHSL-H), calc(var(--vbnAccentHSL-S) - 000%), calc(var(--vbnAccentHSL-L) + 020%); --vbnAccentShadow: var(--vbnAccentHSL-H), calc(var(--vbnAccentHSL-S) - 000%), calc(var(--vbnAccentHSL-L) - 000%); --vbnSecondaryHEX: #2D3139; --vbnSecondaryHSL: 220, 012%, 020%; --vbnSecondaryHSL-H: 220; --vbnSecondaryHSL-S: 12%; --vbnSecondaryHSL-L: 20%; --vbnSecondaryAltXXX: var(--vbnSecondaryHSL-H), calc(var(--vbnSecondaryHSL-S) - 000%), calc(var(--vbnSecondaryHSL-L) - 000%); --vbnSecondaryPickXX: var(--vbnSecondaryHSL-H), calc(var(--vbnSecondaryHSL-S) - 000%), calc(var(--vbnSecondaryHSL-L) - 010%); --vbnSecondaryBorder: var(--vbnSecondaryHSL-H), calc(var(--vbnSecondaryHSL-S) - 000%), calc(var(--vbnSecondaryHSL-L) + 020%); --vbnSecondaryShadow: var(--vbnSecondaryHSL-H), calc(var(--vbnSecondaryHSL-S) - 000%), calc(var(--vbnSecondaryHSL-L) - 000%); --vbnPrimaryHEX: #1D1E20; --vbnPrimaryHSL: 220, 005%, 012%; --vbnPrimaryHSL-H: 220; --vbnPrimaryHSL-S: 05%; --vbnPrimaryHSL-L: 12%; --vbnPrimaryAltXXX: var(--vbnPrimaryHSL-H), calc(var(--vbnPrimaryHSL-S) - 000%), calc(var(--vbnPrimaryHSL-L) - 000%); --vbnPrimaryPickXX: var(--vbnPrimaryHSL-H), calc(var(--vbnPrimaryHSL-S) - 000%), calc(var(--vbnPrimaryHSL-L) - 010%); --vbnPrimaryBorder: var(--vbnPrimaryHSL-H), calc(var(--vbnPrimaryHSL-S) - 000%), calc(var(--vbnPrimaryHSL-L) + 020%); --vbnPrimaryShadow: var(--vbnPrimaryHSL-H), calc(var(--vbnPrimaryHSL-S) - 000%), calc(var(--vbnPrimaryHSL-L) - 010%); --vbnGrid-S: hsla(0, 0%, 50%, 0.07); --vbnGrid-L: hsla(0, 0%, 50%, 0.09); } .vbnThemeLight { --vbnAccentHEX: #75839F; --vbnAccentHSL: 220, 018%, 054%; --vbnAccentHSL-H: 220; --vbnAccentHSL-S: 18%; --vbnAccentHSL-L: 54%; --vbnAccentAltXXX: var(--vbnAccentHSL-H), calc(var(--vbnAccentHSL-S) - 000%), calc(var(--vbnAccentHSL-L) - 000%); --vbnAccentPickXX: var(--vbnAccentHSL-H), calc(var(--vbnAccentHSL-S) - 002%), calc(var(--vbnAccentHSL-L) - 010%); --vbnAccentBorder: var(--vbnAccentHSL-H), calc(var(--vbnAccentHSL-S) - 000%), calc(var(--vbnAccentHSL-L) + 020%); --vbnAccentShadow: var(--vbnAccentHSL-H), calc(var(--vbnAccentHSL-S) - 000%), calc(var(--vbnAccentHSL-L) - 000%); --vbnSecondaryHEX: #454A54; --vbnSecondaryHSL: 220, 010%, 030%; --vbnSecondaryHSL-H: 220; --vbnSecondaryHSL-S: 10%; --vbnSecondaryHSL-L: 30%; --vbnSecondaryAltXXX: var(--vbnSecondaryHSL-H), calc(var(--vbnSecondaryHSL-S) - 000%), calc(var(--vbnSecondaryHSL-L) - 000%); --vbnSecondaryPickXX: var(--vbnSecondaryHSL-H), calc(var(--vbnSecondaryHSL-S) - 000%), calc(var(--vbnSecondaryHSL-L) - 010%); --vbnSecondaryBorder: var(--vbnSecondaryHSL-H), calc(var(--vbnSecondaryHSL-S) - 000%), calc(var(--vbnSecondaryHSL-L) + 020%); --vbnSecondaryShadow: var(--vbnSecondaryHSL-H), calc(var(--vbnSecondaryHSL-S) - 000%), calc(var(--vbnSecondaryHSL-L) - 000%); --vbnPrimaryHEX: #2C2F35; --vbnPrimaryHSL: 220, 009%, 019%; --vbnPrimaryHSL-H: 220; --vbnPrimaryHSL-S: 09%; --vbnPrimaryHSL-L: 19%; --vbnPrimaryAltXXX: var(--vbnPrimaryHSL-H), calc(var(--vbnPrimaryHSL-S) - 000%), calc(var(--vbnPrimaryHSL-L) - 000%); --vbnPrimaryPickXX: var(--vbnPrimaryHSL-H), calc(var(--vbnPrimaryHSL-S) - 000%), calc(var(--vbnPrimaryHSL-L) - 010%); --vbnPrimaryBorder: var(--vbnPrimaryHSL-H), calc(var(--vbnPrimaryHSL-S) - 000%), calc(var(--vbnPrimaryHSL-L) + 020%); --vbnPrimaryShadow: var(--vbnPrimaryHSL-H), calc(var(--vbnPrimaryHSL-S) - 000%), calc(var(--vbnPrimaryHSL-L) - 010%); --vbnGrid-S: hsla(0, 0%, 50%, 0.05); --vbnGrid-L: hsla(0, 0%, 50%, 0.07); } #vbnDOM { z-index: var(--vbnPriority09); pointer-events: none; padding: 0; margin: 0; font-size: var(--vbnBaseSize); } #vbnDOM, #vbnDOM *, #vbnDOM ::before, #vbnDOM ::after { box-sizing: border-box; outline: none; } /* ================================================== ↓ VBN */ /* ========== ↓ Animation */ @keyframes vbnSlideIn { 000% { transform: scale(0.00); opacity: 0; } 020% { transform: scale(0.40); opacity: 0.5; } 030% { transform: scale(0.80); opacity: 1.0; } 085% { transform: scale(1.03); opacity: 1.0; } 100% { transform: scale(1.00); opacity: 1.0; } } @keyframes vbnSlideOut { 000% { transform: translateX(-200%) scale(0.90); opacity: 0; } 020% { transform: translateX(010px) scale(1.02); opacity: 1; } 030% { transform: translateX(000px) scale(1.00); opacity: 1; } 085% { transform: translateX(000px) scale(1.00); opacity: 1; } 100% { transform: translateX(-100%) scale(0.95); opacity: 0; } } @keyframes vbnLoaderUnknown { 000% { left: -10%; width: 10%; } 020% { left: 010%; width: 30%; } 040% { left: 040%; width: 50%; } 060% { left: 070%; width: 30%; } 100% { left: 100%; width: 10%; } } /* ========== ↓ LoaderBar */ #vbnLoaderBar { opacity: .92; z-index: var(--vbnPriority09); position: fixed; top: 0; left: 0; width: 0%; height: 2px; background: linear-gradient( 90deg, hsla(var(--vbnGlow05HSL), 1), hsla(var(--vbnGlow05HSL), 1), hsla(var(--vbnGlow03HSL), 1)); box-shadow: 0 2px 05px 0px hsla(var(--vbnGlow05HSL), .6), 0 2px 15px 0px hsla(var(--vbnGlow05HSL), .6), 0 2px 25px 2px hsla(var(--vbnGlow03HSL), .6); border-radius: 100vmax; will-change: left, width; transition: width .4s cubic-bezier(0.25, 0.46, 0.45, 0.94), opacity .26s ease-out; } #vbnLoaderBar[data-state="loading"] { animation: vbnLoaderUnknown 2.4s infinite cubic-bezier(0.4, 0.0, 0.6, 1); } /* ========== ↓ Panel */ #vbnOptionsPanel { --vbnHeightHead: 35px; --vbnHeightRow: 32px; --vbnRowPadding: 15px; --vbnGap: 12px; } .vbnPanelBase { pointer-events: auto; opacity: 0; will-change: opacity, transform; padding: 20px; border: var(--vbnOftenPanelBorderBase); font-family: var(--vbnBaseFont); color: var(--vbnBase06HEX); background: hsla(var(--vbnBase00HSL-H), 60%, 6%, .8); box-shadow: var(--vbnSurfaceShadow) hsla(var(--vbnAccentShadow), .8); border-radius: var(--vbnSurfaceRadius); backdrop-filter: var(--vbnPanelFilter); transition: all .526s var(--vbnTransitionElastic), opacity .26s ease; } .vbnPanelBase.show { opacity: 1; transform: translate(0, -50%); } .vbnPanelBase.hide { opacity: 0; transform: translate(120%, -50%); } .vbnOptionBase { z-index: var(--vbnPriority09); overflow-y: auto; display: flex; flex-direction: column; gap: var(--vbnGap); width: calc(260px + 40px); } .vbnFixed { position: fixed; top: 50%; right: var(--vbnSpaceAxialX); transform: translate(120%, -50%); } .vbnRelative { position: relative; top: 20px; right: 20px; } .vbnOptionBase h2 { margin-top: 0; margin: calc(var(--vbnGap) / 2) 0 calc(var(--vbnGap) / 2 + 5px) 0; color: var(--vbnGlow04HEX); font-size: 1.7em; font-weight: var(--vbnTitleWeight); text-align: center; text-shadow: 0 0 5px var(--vbnGlow04HEX); } .vbnPanelGroup { display: flex; flex-direction: column; gap: 0; width: 100%; } /* ========== ↓ 功能模块 > 子功能样式 */ .vbnBodyRow, .vbnPanelGroup.Sub .vbnHeaderRow { font-size: .82em; font-weight: normal; } .vbnBodyRow, .vbnPanelGroup.Sub .vbnHeaderRow, .vbnPanelGroup.Sub .vbnFoldBox { height: var(--vbnHeightRow); background: hsla(var(--vbnBase00HSL), .4); transition: background-color .26s, opacity 0.26s; } .vbnBodyRow:hover, .vbnPanelGroup.Sub .vbnHeaderRow:hover { background: hsla(var(--vbnBase00HSL), .8); } .vbnPanelGroup.Sub { vbn { top: var(); } .vbnGroupBody { margin: 0 0 0 calc(var(--vbnGap) - 2px); } .vbnFoldBox { opacity: .4; width: calc(var(--vbnHeightRow) - 5px); color: hsla(var(--vbnBase00HSL), .8); background: transparent; box-shadow: none; margin: 0 0 0 calc(var(--vbnGap) - 28px); } .vbnHeaderRow { padding: 9px var(--vbnRowPadding); } .vbnHeaderRow, .vbnFoldBox { border-radius: var(--vbnUIRadius); box-shadow: 0 10px 20px hsla(var(--vbnBase00HSL), .2); } } /* ========== ↓ Header */ .vbnGroupHeader { display: flex; align-items: center; width: 100%; } .vbnHeaderRow, .vbnFoldBox { background: hsla(var(--vbnBase00HSL), .6); box-shadow: 0 10px 20px hsla(var(--vbnBase00HSL), .4); transition: background-color .26s; } .vbnHeaderRow:hover, .vbnFoldBox:hover { background: hsla(var(--vbnBase00HSL), .8); } .vbnHeaderRow { cursor: pointer; padding: 5px var(--vbnRowPadding) 5px 5px; height: var(--vbnHeightHead); display: flex; flex: 1 1 auto; align-items: center; justify-content: flex-start; gap: 0; font-size: .85em; font-weight: var(--vbnTitleWeight); border-radius: 0 var(--vbnUIRadius) var(--vbnUIRadius) 0; } .vbnHeaderRow > span { flex-grow: 0; margin-right: auto; user-select: none; } .vbnFoldBox { cursor: pointer; flex: 0 0 auto; width: calc(var(--vbnHeightHead) - 5px); height: var(--vbnHeightHead); font-size: 18px; user-select: none; transition: transform 0.4s ease; display: flex; align-items: center; justify-content: center; border-radius: var(--vbnUIRadius) 0 0 var(--vbnUIRadius); } .vbnArrow { margin: -1px -4px 0 0; font-size: 16px; transform: rotate(0deg); transition: transform .4s ease; } .vbnArrow.rotated { transform: rotate(90deg); } /* ========== ↓ Body */ .vbnGroupBody { display: flex; flex-direction: column; gap: calc(var(--vbnGap) / 2 - 1px); opacity: 1; height: auto; transition: all .526s var(--vbnTransitionSmooth); } .vbnGroupBody.open { overflow: hidden; } .vbnGroupBody.close { overflow: hidden; opacity: 0; height: 0 !important; } .vbnBodyRow { cursor: pointer; display: flex; justify-content: space-between; align-items: center; padding: 9px var(--vbnRowPadding); margin: 0 0 0 calc(var(--vbnGap) - 2px); border-radius: var(--vbnUIRadius); } .vbnBodyRow:first-of-type { margin: calc(var(--vbnGap) / 2) 0 0 calc(var(--vbnGap) - 2px); } .vbnBodyRow:last-of-type { margin: 0 0 calc(var(--vbnGap) / 4) calc(var(--vbnGap) - 2px); } /* ========== ↓ Other */ .vbnOptionBase input[type="checkbox"] { cursor: pointer; position: relative; appearance: none; width: .6em; height: .6em; margin: 0; background: var(--vbnBase04HEX); border: none; border-radius: 50%; transition: background-color .26s ease; box-shadow: 0 0 2px hsla(0, 0%, 0%, .3); } .vbnOptionBase input[type="checkbox"].correct:checked { background: var(--vbnStateCorrect); box-shadow: 0 0 10px var(--vbnStateCorrect); } .vbnOptionBase input[type="checkbox"].warn:checked { background: var(--vbnStateWarn); box-shadow: 0 0 10px var(--vbnStateWarn); } .vbnOptionBase input[type="checkbox"].error:checked { background: var(--vbnStateError); box-shadow: 0 0 10px var(--vbnStateError); } /* ========== ↓ Other */ /* ========== ↓ ItemBlock */ .vbnItemBlock { box-sizing: border-box; position: relative; padding: var(--vbnSpacePadding); margin: var(--vbnSpaceMargin); border: none; width: 100%; font-size: 12px; background: #FFFFFF; box-shadow: var(--vbnOftenSurfaceShadowBase); border-radius: var(--vbnSurfaceRadius); transition: var(--vbnOftenTransition); } .vbnItemBlock:hover { z-index: var(--vbnPriority00); box-shadow: inset 0 0 2px hsla(0, 0%, 92%, .6), var(--vbnOftenSurfaceShadowHover); transform: var(--vbnSurfaceZoomIn); } /* ========== ↓ Button */ .vbnButtonBase { cursor: pointer; user-select: none; border: var(--vbnUIBorder) var(--vbnAccentBorder); font-size: 1em; font-weight: var(--vbnTitleWeight); color: var(--vbnBase00HEX); background: var(--vbnAccentHEX); box-shadow: var(--vbnUIShadow) var(--vbnAccentShadow); border-radius: var(--vbnPanelRadius); transition: transform .26s var(--vbnTransitionSoft); } .vbnButtonBase:hover { transform: var(--vbnSurfaceZoomIn); } .vbnButtonBase:first-of-type { margin-top: calc(var(--vbnGap) - 2px); } .vbnButtonBase.fill { cursor: pointer; } .vbnButtonBase.outline { cursor: pointer; } .vbnButtonBase.text { cursor: pointer; } .vbnButtonBase.ICON { cursor: pointer; } .vbnButtonBase.open { border: none; color: var(--vbnBase00HEX); background: linear-gradient( 90deg, var(--vbnGreen001), var(--vbnBlue0001) ); box-shadow: inset 0 0 20px hsla(var(--vbnGlow06HSL), .6), 0 0 10px hsla(var(--vbnGlow04HSL), .4); } .vbnButtonBase.close { border: none; color: var(--vbnBase00HEX); background: linear-gradient( 90deg, var(--vbnGreen001), var(--vbnBlue0001) ); box-shadow: inset 0 0 20px hsla(var(--vbnGlow06HSL), .6), 0 0 10px hsla(var(--vbnGlow04HSL), .4); } .vbnButtonFixed { padding: 5px 10px; width: var(--vbnButtonWidth); height: var(--vbnButtonHeight); } .vbnButtonAdapt { padding: 10px 0; width: 100%; } /* ========== ↓ State */ .vbnCurrentRow::after { content: ""; position: absolute; top: 50%; left: 1.2%; transform: translateY(-50%); height: 1.2em; width: .26rem; background: var(--vbnGlow01HEX); box-shadow: 4px 0 14px 1px hsla(var(--vbnGlow01HSL), .92); border-radius: 1em; } .vbnTipsInside { position: absolute; top: 2%; left: 50%; width: 80%; padding: 5px 12px; text-align: center; font-size: 12px; font-weight: var(--vbnTitleWeight); color: var(--vbnBase00HEX); background: var(--vbnAccentHEX); border-radius: var(--vbnPanelRadius); transform: translateX(-50%); } .vbnTipsHover { pointer-events: none; opacity: 0; z-index: calc(var(--vbnPriority09) + 1); position: fixed; padding: 5px 15px; width: max-content; /* max-width: 260px; */ min-height: 12px; border: var(--vbnUIBorder) hsla(var(--vbnAccentHSL), .2); text-align: justify; font-size: 12px; line-height: 1.5; color: var(--vbnGlow04HEX); background: hsla(var(--vbnBase00HSL), .8); box-shadow: var(--vbnUIShadow) hsla(var(--vbnBase00HSL), .4); border-radius: calc(var(--vbnPanelRadius) - 2.6px); transition: opacity .2s ease; } .vbnTipsHover.show { opacity: 1; } .vbnTips { z-index: var(--vbnPriority09); position: fixed; top: 2.26em; left: 2em; padding: .6em 1.26em; border: 1.52px solid hsla(var(--vbnBase09HSL), .526); font-size: 15px; font-weight: 526; line-height: 1.5; color: hsla(var(--vbnBase00HSL), .8); background: var(--vbnBase08HEX); box-shadow: var(--vbnTipsShadow-S) hsla(var(--vbnBase09HSL), .226), var(--vbnTipsShadow-M) hsla(var(--vbnAccentHSL), .120), var(--vbnTipsShadow-L) hsla(var(--vbnAccentHSL), .092); border-radius: .92em; animation: vbnSlideOut 2s cubic-bezier(0.25, 1.4, 0.5, 1) forwards; transition: var(--vbnOftenTransition); } .vbnTips.remind { background: var(--vbnBase09HEX); box-shadow: var(--vbnTipsShadow-S) hsla(var(--vbnBase09HSL), .226), var(--vbnTipsShadow-M) hsla(var(--vbnAccentHSL), .120), var(--vbnTipsShadow-L) hsla(var(--vbnAccentHSL), .092); } .vbnTips.correct { background: var(--vbnBase09HEX); box-shadow: var(--vbnTipsShadow-S) hsla(var(--vbnBase09HSL), .226), var(--vbnTipsShadow-M) hsla(var(--vbnAccentHSL), .120), var(--vbnTipsShadow-L) hsla(var(--vbnAccentHSL), .092); } .vbnTips.warn { background: var(--vbnStateWarn); box-shadow: var(--vbnTipsShadow-S) hsla(var(--vbnBase09HSL), .226), var(--vbnTipsShadow-M) hsla(20, 85%, 55%, .120), var(--vbnTipsShadow-L) hsla(20, 85%, 55%, .092); } .vbnTips.error { background: var(--vbnStateError); box-shadow: var(--vbnTipsShadow-S) hsla(var(--vbnBase09HSL), .226), var(--vbnTipsShadow-M) hsla(0, 85%, 55%, .120), var(--vbnTipsShadow-L) hsla(0, 85%, 55%, .092); } /* ========== ↓ Link */ .vbnLink { position: relative !important; text-decoration: none !important; } .vbnLink::before, .vbnLink::after { content: "" !important; position: absolute !important; top: calc(100% + 0px) !important; left: 0 !important; width: 100% !important; border-bottom: dashed .0926em currentColor !important; } .vbnLink:hover::before, .vbnLink:hover::after { border-bottom: solid .0926em currentColor !important; } /* ========== ↓ Load */ .vbnFadeInLoad { opacity: 0; transform: translateY(100px); transition: opacity .5s var(--vbnTransitionSmooth), transform .9s var(--vbnTransitionSmooth); } .vbnFadeInLoad.loaded { opacity: 1; transform: translateY(0); } /* ========== ↓ Focal */ .vbnFocal { --height: 2px; --time: .526s; --offset: -2px; --base: var(--vbnAccentHEX); --radius: var(--vbnBaseRadius); --bezier: var(--vbnTransitionSoft); position: relative; width: max-content; text-decoration: none; } .vbnFocal.CT::after { content: ""; position: absolute; left: 50%; bottom: var(--offset); width: 100%; height: var(--height); background: var(--base); border-radius: var(--radius); transform: translateX(-50%) scaleX(0); transform-origin: center; transition: transform var(--time) var(--bezier); } .vbnFocal.CT:hover::after { transform: translateX(-50%) scaleX(1);} .vbnFocal.LR::after { content: ""; position: absolute; left: 0; bottom: var(--offset); width: 100%; height: var(--height); background: var(--base); border-radius: var(--radius); transform: scaleX(0); transform-origin: left; transition: transform var(--time) var(--bezier); } .vbnFocal.LR:hover::after { transform: scaleX(1); } /* ========== ↓ Grid */ .vbnGridSolid { background-attachment: fixed; background-image: linear-gradient(00deg, var(--vbnGrid-S) 1px, transparent 0), linear-gradient(90deg, var(--vbnGrid-S) 1px, transparent 0), linear-gradient(00deg, var(--vbnGrid-L) 1px, transparent 0), linear-gradient(90deg, var(--vbnGrid-L) 1px, transparent 0); background-size: 100px 100px, 100px 100px, 20px 20px, 20px 20px; } /* ========== ↓ Table */ .vbnTableBox { display: flex; justify-content: center; padding: 15px; } .vbnTable { overflow: hidden !important; border-collapse: collapse !important; background: transparent !important; box-shadow: 0 0 0 1px hsla(0, 0%, 5%, .02), 0 2px 10px hsla(0, 0%, 0%, .04), 0 10px 10px hsla(0, 0%, 0%, .02) !important; border-radius: var(--vbnSurfaceRadius) !important; } .vbnTable :is(thead) { font-weight: var(--vbnTitleWeight) !important; background: #FFF !important; } .vbnTable :is(tr):hover { background: #FAFAFA !important; } /* ========== ↓ 首行 */ .vbnTable :is(tr):first-child :is(td):not(:first-child, :last-child) { border-left: 1px solid #00000006 !important; border-right: 1px solid #00000006 !important; } /* ========== ↓ 尾行 */ .vbnTable tbody tr:last-child :is(td) { border-bottom: none !important;} /* ========== ↓ 含代码 */ .vbnTable :is(code) { padding: 2px 5px !important; font-family: var(--vbnCodeFont) !important; color: var(--vbnCodeColor) !important; background: #F2F2F2 !important; border-radius: var(--vbnBaseRadius) !important; } /* ========== ↓ 单元格 */ .vbnTable :is(th), .vbnTable :is(td) { border-style: solid !important; border-width: 0 0 1px 0 !important; border-color: transparent transparent #FAFAFA transparent !important; text-align: left !important; } .vbnTable :is(th)[style*="padding: 0px"], .vbnTable :is(td):not([style*="padding"]) { padding: 5px 10px !important; } .vbnTable :is(th) { color: #4D4D4D !important;} .vbnTable :is(td) { color: #444 !important;} `) })(); (function VBN_GlobalCustom() { 'use strict'; // $ ================================================== ↓ Global const vbnMatchURL = window.location.href; const vbnMatchHost = window.location.hostname; document.documentElement.classList.add('vbn'); // #region Config const VBN_SITE_GROUP = { AIGC: [ "*127.0.0.1:8188/*", "*localhost:8188/*", "*127.0.0.1:7860/*", "*localhost:7860/*", "*127.0.0.1:9222/*", "*localhost:9222/*", ], Chat: [ "*deepseek.com/*", "*chatgpt.com/*", ], ProgDev: [ "*github.com/*", "*huggingface.co/*", ], Manage: [ "*yuque.com/*", "*ticktick.com/*", "*dida365.com/*", "*workona.com/*", ], Search: [ "*google.com/*", "*baidu.com/*", "*bing.com/*", ], Media: [ "*youtube.com/*", "*bilibili.com/*", "*weibo.com/*", ], Font: [ "*fonts.google.com/*", "*cp.baidu.com/*", ], }; /** * @type {Object} * @property {boolean} debug - 全局调试 | 开启后控制台将输出 当前站点各功能的运行状态 * @property {Object} siteBlock - 站点阻塞 | 功能若与原始站点产生冲突 可在相应功能组内添加站点进行屏蔽 紧急阻塞 */ const VBN_GLOBAL_CONFIG = { debug: false, siteBlock: { Global: [ ], Assign: [ ], Micro: [ ], }, }; // #endregion // #region Modules const VBN_GLOBAL_MODULES = { Global: { fold: false, ScrollBar: { feature: "原生滚动条样式 个性化", match: { include: [ "*" ], exclude: [ ] }, }, LoaderBar: { name: "顶部加载条", feature: "全局顶部植入 加载状态条 => 进度条", state: true, default: true, debug: false, match: { include: [ "*" ], exclude: [ ] }, }, CustomICON: { feature: "站点 ICO 替换 | 书签栏 > DeepSeek > HUA! 黑鲸", }, FontStyle: { feature: "字体样式 | 可去 FontStyle 重定义所需站点/变更应用已安装的某款字体", }, Selection: { feature: "原生鼠标选取样式 个性化", match: { include: [ "*" ], exclude: [ "*yuque.com/*" ] }, }, }, Assign: { fold: false, Search: { feature: " ", }, Chat: { fold: true, DeepSeek: { feature: "聊天窗格 宽度增加", }, ChatGPT: { feature: "聊天窗格 宽度增加", }, }, ComfyUI: { feature: "YOYOYO", fold: true, manager: { }, crystools: { }, rgthree: { }, }, YUQUE: { fold: true, vbnTable: { feature: "表格样式", }, vbnGrid: { feature: "背景网格", } }, TickTick: { feature: " ", }, Youtube: { feature: " ", }, Bilibili: { feature: " ", }, NetDisk_Check: { feature: " ", match: { include: [ "*" ], exclude: [ ] }, }, }, Micro: { fold: true, }, }; // #endregion // #region Basics const VBN_GLOBAL_DEBUG = (() => { const Prefix = "[==👽VBN==]"; const logRecord = Object.create(null); const mapError = Object.create(null); const mapTime = Object.create(null); function logFormat({ icon, key, time, msg }) { return `${Prefix}[${icon}][${time?.toFixed?.(1) || "-"}ms][${key}] | ${msg}`; } function logStore(key, msg) { if (!logRecord[key]) logRecord[key] = []; logRecord[key].push({ msg, time: Date.now() }); } function log(key, msg = "DONE", time = 0) { const icon = "🚀"; const text = logFormat({ icon, key, time, msg }); console.log(text); logStore(key, text); } function warn(key, msg = "DEBUG", time = 0) { const icon = "🛠️"; const text = logFormat({ icon, key, time, msg }); console.warn(text); logStore(key, text); errorMark(key, msg, false); } function error(key, msg = "ERROR", time = 0) { const icon = "👾"; const text = logFormat({ icon, key, time, msg }); console.error(text); logStore(key, text); errorMark(key, msg, true); } function errorMark(key, msg = "Unknown", isFatal = true) { const mod = VBN_GLOBAL_LOGIC.get(key); if (!mod) return; mod.error = isFatal; mod.errorMSG = msg; } function infoTotal() { const all = VBN_GLOBAL_LOGIC.getAllModules?.() || {}; for (const [key, mod] of Object.entries(all)) { const icon = mod.error ? "👾" : mod.debug ? "🛠️" : mod.state ? "🚀" : "🏁"; const msg = mod.errorMSG || (mod.error ? "ERROR" : "DONE"); const time = mod.timeCost || 0; console.log(logFormat({ icon, key, time, msg })); } } return { log, warn, error, errorMark, infoTotal }; })(); // const VBN_GLOBAL_CACHE.valueStorage // const VBN_VALUE_STORE = (() => { const VBN_GLOBAL_CACHE = (() => { const regex = new Map(); const group = new Map(); const chain = new Map(); const match = new Map(); const value = new Map(); function clear(type, key) { if (type && key) { if (VBN_GLOBAL_CACHE.hasOwnProperty(type) && VBN_GLOBAL_CACHE[type] instanceof Map) { VBN_GLOBAL_CACHE[type].delete(key); } } else if (type) { if (VBN_GLOBAL_CACHE[type]) { VBN_GLOBAL_CACHE[type].clear(); } } else { regex.clear(); group.clear(); chain.clear(); match.clear(); value.clear(); } } return { regex, group, chain, match, value, clear, }; })(); const VBN_MATCH_RULE = (() => { function toRegex(pattern) { if (VBN_GLOBAL_CACHE.regex.has(pattern)) return VBN_GLOBAL_CACHE.regex.get(pattern); const escaped = pattern .replace(/([.+^${}()|[\]\\])/g, '\\$1') .replace(/\*/g, '.*') .replace(/^https?:/, 'https?:'); const regex = new RegExp('^' + escaped + '$', 'i'); VBN_GLOBAL_CACHE.regex.set(pattern, regex); return regex; } function check(pattern, target) { return toRegex(pattern).test(target); } function match({ include = [], exclude = [], url = vbnMatchURL } = {}) { if (include.length === 1 && include[0] === "*" && exclude.length === 0) { return true; } return ( include.some(rule => check(rule, url)) && !exclude.some(rule => check(rule, url)) ); } return { toRegex, check, match }; })(); const VBN_MODULE_STORE = (() => { const flat = {}; const tree = {}; function moduleBase(key, raw, parentKey = null) { return { key, parent: parentKey ?? null, fold: raw.fold ?? false, name: " ", feature: " ", state: true, default: true, debug: false, match: raw.match ?? {}, ...raw, }; } for (const [groupName, groupData] of Object.entries(VBN_GLOBAL_MODULES)) { const groupNode = {}; const groupFold = groupData.fold ?? false; for (const [modKey, modRaw] of Object.entries(groupData)) { if (modKey === "fold") continue; const mod = moduleBase(modKey, modRaw); flat[modKey] = mod; groupNode[modKey] = mod; for (const [subKey, subRaw] of Object.entries(modRaw)) { if ( ["match", "state", "default", "feature", "debug", "name", "fold"].includes(subKey) || typeof subRaw !== "object" ) continue; const subMod = moduleBase(subKey, subRaw, modKey); flat[subKey] = subMod; if (!groupNode[modKey].subs) groupNode[modKey].subs = {}; groupNode[modKey].subs[subKey] = subMod; } } tree[groupName] = { ...groupNode, fold: groupFold, }; } function getGroup(key) { if (VBN_GLOBAL_CACHE.group.has(key)) return VBN_GLOBAL_CACHE.group.get(key); for (const [groupName, modules] of Object.entries(tree)) { if (key in modules) { VBN_GLOBAL_CACHE.group.set(key, groupName); return groupName; } for (const mod of Object.values(modules)) { if (mod && mod.subs && key in mod.subs) { VBN_GLOBAL_CACHE.group.set(key, groupName); return groupName; } } } VBN_GLOBAL_CACHE.group.set(key, null); return null; } function getChain(key, { includeGroup = false } = {}) { if (VBN_GLOBAL_CACHE.chain.has(key)) return VBN_GLOBAL_CACHE.chain.get(key); const chain = []; let current = flat[key]; while (current) { chain.unshift(current.key); current = current.parent ? flat[current.parent] : null; } if (includeGroup) { const group = getGroup(key); if (group) chain.unshift(group); } VBN_GLOBAL_CACHE.chain.set(key, chain); return chain; } return { get: key => flat[key], getFlat: () => flat, getTree: () => tree, getGroup, getChain, }; })(); const VBN_ACTIVATION = (() => { const defaultMatch = { include: ["*"], exclude: [] }; function findMatch(mod) { if (!mod) return defaultMatch; if (VBN_GLOBAL_CACHE.match.has(mod.key)) return VBN_GLOBAL_CACHE.match.get(mod.key); let result; if (mod.match?.include?.length || mod.match?.exclude?.length) { result = mod.match; } else if (mod.parent) { result = findMatch(VBN_MODULE_STORE.get(mod.parent)); } else { result = defaultMatch; } VBN_GLOBAL_CACHE.match.set(mod.key, result); return result; } function getValue(key, fallback = true) { if (VBN_GLOBAL_CACHE.value.has(key)) return VBN_GLOBAL_CACHE.value.get(key); const val = GM_getValue(key, fallback); VBN_GLOBAL_CACHE.value.set(key, val); return val; } function clearCache(key) { if (key) { VBN_GLOBAL_CACHE.value.delete(key); VBN_GLOBAL_CACHE.match.delete(key); } else { VBN_GLOBAL_CACHE.value.clear(); VBN_GLOBAL_CACHE.match.clear(); } } function isBlocked(module, url = vbnMatchURL) { const blockList = VBN_GLOBAL_CONFIG.siteBlock?.[module.group]; if (!blockList?.length) return false; return blockList.some(pattern => VBN_MATCH_RULE.check(pattern, url)); } function isActive(module, options = {}) { const url = options.url ?? vbnMatchURL; const matchRule = options.matchSubjoin || findMatch(module); const matched = VBN_MATCH_RULE.match({ include: matchRule.include, exclude: matchRule.exclude, url }); if (!matched) return false; const keyChain = VBN_MODULE_STORE.getChain(module.key, { includeGroup: true }); return keyChain.every(key => getValue(key, true)); } return { isActive, isBlocked, clearCache }; })(); const VBN_GLOBAL_LOGIC = (() => { let hasPreheated = false; function preheat() { if (hasPreheated) return; hasPreheated = true; const all = VBN_MODULE_STORE.getFlat(); for (const key in all) { const mod = all[key]; VBN_MODULE_STORE.getGroup(key); VBN_MODULE_STORE.getChain(key, { includeGroup: true }); VBN_ACTIVATION.isActive(mod); } } function activate(key, rule, logic) { let options = {}; if (typeof rule === "function") { logic = rule; } else if (typeof rule === "object") { options = rule; } const mod = VBN_MODULE_STORE.get(key); if (!mod || mod.state === false) return false; if (VBN_ACTIVATION.isBlocked(mod, options.url)) { if (VBN_GLOBAL_CONFIG.debug) VBN_GLOBAL_DEBUG.warn(key, `siteBlock - ${VBN_MODULE_STORE.getGroup(key)}`); return false; } const active = VBN_ACTIVATION.isActive(mod, options); if (typeof logic !== "function") return active; if (active) { const start = performance.now(); try { logic(); mod.timeCost = performance.now() - start; if (VBN_GLOBAL_CONFIG.debug || mod.debug) VBN_GLOBAL_DEBUG.log(key, "DONE", mod.timeCost); } catch (e) { mod.timeCost = performance.now() - start; VBN_GLOBAL_DEBUG.error(key, e?.message || "ERROR", mod.timeCost); } } return active; } return { get: VBN_MODULE_STORE.get, getAllModules: VBN_MODULE_STORE.getFlat, activate, preheat, }; })(); // #endregion // #region Manager const VBN_OBSERVER_CENTER = (() => { const observerAnonym = new Set(); const observerKey = new Map(); let observerTarget = new WeakMap(); function observe(target, options = { childList: true, subtree: true }, callback, config = {}) { if (!(target instanceof Node)) return null; if (config.preventDuplicate && observerTarget.has(target)) return null; const observerBase = new MutationObserver((mutations, observerInstance) => { try { callback(mutations, observerInstance); } catch (err) { document.documentElement.classList.add("vbnTips", "correct"); } if (config.autoDisconnect || (typeof config.onceWhen === "function" && config.onceWhen(mutations))) { disconnectTarget(target, observerBase); } }); observerBase.observe(target, options); observerAnonym.add(observerBase); _addToTargetMap(target, observerBase); return observerBase; } function observeWithKey(key, target, options = { childList: true, subtree: true }, callback, config = {}) { if (!key || typeof key !== "string" || !(target instanceof Node)) return null; if (observerKey.has(key)) { observerKey.get(key).disconnect(); observerKey.delete(key); } const observerBase = new MutationObserver((mutations, observerInstance) => { try { callback(mutations, observerInstance); } catch (err) { document.documentElement.classList.add("vbnTips", "error"); } if (config.autoDisconnect || (typeof config.onceWhen === "function" && config.onceWhen(mutations))) { disconnectKey(key); _removeFromTargetMap(target, observerBase); } }); observerBase.observe(target, options); observerKey.set(key, observerBase); _addToTargetMap(target, observerBase); return observerBase; } function disconnect(target) { const observerSet = observerTarget.get(target); if (observerSet) { observerSet.forEach(observerBase => { observerBase.disconnect(); observerAnonym.delete(observerBase); }); observerTarget.delete(target); } } function disconnectTarget(target, observerBase) { observerBase.disconnect(); observerAnonym.delete(observerBase); _removeFromTargetMap(target, observerBase); } function disconnectKey(key) { const observerBase = observerKey.get(key); if (observerBase) { observerBase.disconnect(); observerKey.delete(key); } } function disconnectAll() { observerAnonym.forEach(observerBase => observerBase.disconnect()); observerKey.forEach(observerBase => observerBase.disconnect()); observerAnonym.clear(); observerKey.clear(); observerTarget = new WeakMap(); } function hasKey(key) { return observerKey.has(key); } function getActiveCount() { let totalTargeted = 0; observerTarget.forEach(set => totalTargeted += set.size); return { anonymous: observerAnonym.size, keyed: observerKey.size, byTarget: totalTargeted }; } function _addToTargetMap(target, observerBase) { if (!observerTarget.has(target)) { observerTarget.set(target, new Set()); } observerTarget.get(target).add(observerBase); } function _removeFromTargetMap(target, observerBase) { const set = observerTarget.get(target); if (set) { set.delete(observerBase); if (set.size === 0) observerTarget.delete(target); } } return { observe, observeWithKey, disconnect, disconnectKey, disconnectAll, hasKey, getActiveCount }; })(); // #endregion // #region Builder const VBN_GLOBAL_DOM = (() => { let instance = null; const callbacks = []; function init() { if (instance) return; const div = document.createElement('div'); div.id = 'vbnDOM'; document.body.insertBefore(div, document.body.firstChild); instance = div; } function ensureReady(callback) { if (callback) callbacks.push(callback); if (instance) { while (callbacks.length) { try { callbacks.shift()(instance); } catch (e) { console.error(e); } } return instance; } if (document.readyState === 'loading') { document.addEventListener('DOMContentLoaded', () => { init(); ensureReady(); }); } else { init(); ensureReady(); } } return { load(callback) { if (callback) { ensureReady(callback); } else { return new Promise(resolve => ensureReady(resolve)); } }, get() { return instance || document.querySelector('#vbnDOM'); } }; })(); // #endregion // #region Utils /** * 类名添加 | 在定位的 DOM 结构上 添加自定义类名 「支持检测链接已访问后添加」 * @param {Object} options * @param {number} [options.delay=0] - 进入页面后 延迟多久执行 「毫秒」 * @param {string|string[]} options.target - 需添加类名的目标DOM 「选择器」 「支持多个」 * @param {string|string[]} options.subjoin - 需添加的类名 「支持多个」 * @param {boolean} [options.trace=false] - 是否启用 已访问的链接痕迹 * @param {string} [options.traceQuery="a[href]"] - 需查询的链接类型 「选择器」 * @param {string[]|function} [options.traceJudge] - 增强判定 检测链接中需包含的关键词 */ const VBN_ADD_CLASS = (() => { const storageKey = 'vbnVisitedLinks'; const attrMark = 'data-vbn-trace'; function apply({ delay = 0, target, subjoin, trace = false, traceQuery = "a[href]", traceJudge, }) { const packSelector = Array.isArray(target) ? target : [target]; const packClass = Array.isArray(subjoin) ? subjoin : [subjoin]; const visitedSet = new Set(JSON.parse(localStorage.getItem(storageKey) || '[]')); const observerKey = `subjoin_${packSelector.join('_')}_${packClass.join('_')}`; function defaultShouldApply(el) { const links = el.querySelectorAll(traceQuery); return [...links].some(link => { const href = link.getAttribute("href"); if (!href) return false; const isTraceTarget = typeof traceJudge === "function" ? traceJudge(href) : Array.isArray(traceJudge) ? traceJudge.every(keyword => href.includes(keyword)) : true; return isTraceTarget && visitedSet.has(href); }); } function applyClass(el) { packClass.forEach(cls => { if (!el.classList.contains(cls)) { el.classList.add(cls); } }); el.setAttribute(attrMark, "true"); } function processDOM() { packSelector.forEach(sel => { document.querySelectorAll(sel).forEach(el => { if (el.hasAttribute(attrMark)) return; if (trace) { if (defaultShouldApply(el)) applyClass(el); } else { applyClass(el); } }); }); } function setupClickTracking() { if (!trace || window._VBN_CLICK_TRACK_INITED) return; window._VBN_CLICK_TRACK_INITED = true; document.body.addEventListener("click", e => { const anchor = e.target.closest(traceQuery); if (!anchor) return; const href = anchor.getAttribute("href"); if (!href) return; const isTraceTarget = typeof traceJudge === "function" ? traceJudge(href) : Array.isArray(traceJudge) ? traceJudge.every(keyword => href.includes(keyword)) : true; if (!isTraceTarget) return; visitedSet.add(href); localStorage.setItem(storageKey, JSON.stringify([...visitedSet])); packSelector.forEach(sel => { const el = anchor.closest(sel); if (el) applyClass(el); }); }); } function startObserve() { processDOM(); setupClickTracking(); VBN_OBSERVER_CENTER.observeWithKey( observerKey, document.body, { childList: true, subtree: true }, processDOM, { preventDuplicate: true, autoDisconnect: false } ); } if (delay > 0) setTimeout(startObserve, delay); else startObserve(); } return { apply }; })(); /** * 自动执行 | 进入页面后 自动执行一系列操作 「最多可支持10个步骤」 * @param {Object} options * @param {number} [options.delay=200] - 延迟 起始执行 「毫秒」 * @param {number} [options.delayStep=20] - 延迟 每个执行步骤间 「毫秒」 * @param {boolean} [options.backstage=false] - 后台执行 页面未激活/未在前台时 是否执行 * @param {boolean} [options.strict=false] - 严格模式 若某步骤执行失败 是否中断后续步骤 * @param {boolean} [options.debug=false] - 调试输出 * @param {Object} [options.step1.step10] - 定义每个步骤的目标及操作类型 * - target:目标选择器 * - action:执行类型 "click" | "focus" | "hover" */ const VBN_AUTO_EXECUTE = (() => { const maxAutoStep = 10; const moduleMark = "AUTO_EXECUTE"; function runAction(el, action = "click") { if (!el) return false; switch (action) { case "click": el.click(); break; case "focus": el.focus(); break; case "hover": const event = new MouseEvent("mouseover", { bubbles: true }); el.dispatchEvent(event); break; } return true; } function apply(options = {}) { const { delay = 200, delayStep = 20, backstage = false, strict = false, debug = false } = options; const steps = []; for (let i = 1; i <= maxAutoStep; i++) { const key = `step${i}`; if (options[key]) steps.push(options[key]); } if (!steps.length) return; let executed = false; const run = () => { if (executed) return; executed = true; let shouldBreak = false; setTimeout(() => { steps.forEach((step, i) => { const { target, action = "click" } = step; const delayEach = delayStep * i; setTimeout(() => { if (shouldBreak) return; try { const el = document.querySelector(target); if (el) { runAction(el, action); VBN_GLOBAL_DEBUG.log(moduleMark, `Step${i + 1} ✅ ${action} - ${target}`, { debug }); } else { VBN_GLOBAL_DEBUG.warn(moduleMark, `Step${i + 1} ❓ None - ${target}`, { debug }); if (strict) { shouldBreak = true; VBN_GLOBAL_DEBUG.error(moduleMark, `Step${i + 1} ❌ Break`, { debug }); } } } catch (e) { VBN_GLOBAL_DEBUG.error(moduleMark, `Step${i + 1} ❌ Error - ${e.message}`, { debug }); } }, delayEach); }); }, delay); }; const tryRun = () => { if (executed) return; if (!backstage && document.visibilityState !== "visible") return; run(); }; document.addEventListener("DOMContentLoaded", tryRun); document.addEventListener("visibilitychange", tryRun); } return { apply }; })(); /** * 自动加载 | 支持两种模式 无限滚动加载/每次加载多页 * @param {Object} options * @param {boolean} [options.loadInfinite=false] - 无限滚动加载 是否启用 * @param {number} [options.loadPage=9] - 加载页数 「仅在非无限滚动模式下生效」 * @param {string} [options.itemTarget="#container .c-container"] - 内容所在容器 「父选择器」 * @param {string|HTMLElement} [options.itemWrapper="#container"] - 将新加载内容插入至何处 「选择器」 * @param {string} [options.buttonPrev=".page-prev"] - 上一页按钮 「选择器」 * @param {string} [options.buttonNext=".page-next"] - 下一页按钮 「选择器」 * @param {boolean} [options.fragment=false] - 统一加载 是否启用 「加载每页的完整内容后统一插入」 * @param {boolean} [options.throttle=true] - 动态加载 是否启用 「可防止性能及其他问题」 * @param {number} [options.throttleBase=10] - 动态加载 延迟 基础 * @param {number} [options.throttleJitter=50] - 动态加载 延迟 随机波动 */ const VBN_AUTO_LOAD = (() => { function apply({ loadInfinite = false, loadPage = 9, itemTarget = "#container .c-container", itemWrapper = "#container", buttonPrev = ".page-prev", buttonNext = ".page-next", fragment = false, throttle = true, throttleBase = 10, throttleJitter = 50, } = {}) { const currentPage = getCurrentPage(); const wrapperEl = typeof itemWrapper === "string" ? document.querySelector(itemWrapper) : itemWrapper; if (!wrapperEl) return; let loading = false; let loadedPage = currentPage; // 节流加载单页函数 function loadSinglePage(pageNum) { return new Promise(resolve => { setTimeout(() => { $.get(buildPageUrl(pageNum), html => { const temp = document.createElement("div"); temp.innerHTML = html; const items = temp.querySelectorAll(itemTarget); const mount = fragment ? document.createDocumentFragment() : wrapperEl; items.forEach(el => { el.classList.add("vbnFadeInLoad"); mount.appendChild(el); }); if (fragment) wrapperEl.appendChild(mount); requestAnimationFrame(() => { wrapperEl.querySelectorAll(".vbnFadeInLoad:not(.loaded)").forEach(el => { el.classList.add("loaded"); }); }); resolve(); }); }, throttle ? (pageNum * throttleBase + Math.random() * throttleJitter) : 0); }); } // 非无限滚动 按页数加载 if (!loadInfinite) { const nextBtn = document.querySelector(buttonNext); if (nextBtn) { nextBtn.href = buildPageUrl(currentPage + loadPage + 1); nextBtn.textContent = `Next ${loadPage + 1}`; } const promises = []; for (let i = 1; i <= loadPage; i++) { const pageNum = currentPage + i; promises.push(loadSinglePage(pageNum)); } return Promise.all(promises); } // 无限滚动加载 const observer = new IntersectionObserver(entries => { const entry = entries[0]; if (!entry.isIntersecting || loading) return; loading = true; loadedPage += 1; observer.unobserve(entry.target); loadSinglePage(loadedPage).then(() => { const url = new URL(location.href); url.searchParams.set("page", loadedPage); history.replaceState(null, "", url.toString()); observeLastItem(); }).finally(() => { loading = false; }); }, { rootMargin: "500px" }); function observeLastItem() { const items = wrapperEl.querySelectorAll(itemTarget); const lastItem = items[items.length - 1]; if (lastItem) observer.observe(lastItem); } observeLastItem(); } function getCurrentPage() { const match = location.href.match(/page=(\d+)/); return match ? parseInt(match[1]) : 1; } function buildPageUrl(page) { const url = new URL(location.href); url.searchParams.set("page", page); return url.toString(); } return { apply }; })(); // #endregion // #region Derive const VBN = { SITE: VBN_SITE_GROUP, CONFIG: VBN_GLOBAL_CONFIG, MODULE: VBN_GLOBAL_MODULES, DEBUG: VBN_GLOBAL_DEBUG, CACHE: VBN_GLOBAL_CACHE, MATCH: VBN_MATCH_RULE, STORE: VBN_MODULE_STORE, ACTIVATION: VBN_ACTIVATION, LOGIC: VBN_GLOBAL_LOGIC, OBSERVER: VBN_OBSERVER_CENTER, DOM: VBN_GLOBAL_DOM, CLASS: VBN_ADD_CLASS, EXECUTE: VBN_AUTO_EXECUTE, LOAD: VBN_AUTO_LOAD, }; VBN.LOGIC.preheat(); // #endregion // #region Options (function VBN_Options() { const pendingChanges = {}; const hoverTimeoutMap = new WeakMap(); const hoverTipMap = new WeakMap(); const easterEggAttachedSet = new WeakSet(); function showTip(msg, type = "", timeout = 4126) { const tip = document.createElement("div"); tip.className = `vbnTips${type ? " " + type : ""}`; tip.textContent = msg; VBN_GLOBAL_DOM.load(dom => { dom.appendChild(tip); setTimeout(() => tip.remove(), timeout); }); } function createFoldAnimation(container, body, arrow, foldKey, initiallyFolded) { let folded = initiallyFolded; const toggleFold = () => { const isCollapsed = folded; body.classList.add("open"); if (isCollapsed) { body.classList.remove("close"); const scrollHeight = body.scrollHeight + "px"; body.style.height = "0px"; requestAnimationFrame(() => { body.style.height = scrollHeight; }); body.addEventListener("transitionend", function onEnd() { body.style.height = "auto"; body.classList.remove("open"); body.removeEventListener("transitionend", onEnd); }, { once: true }); arrow.classList.add("rotated"); GM_setValue(foldKey, false); folded = false; } else { const height = body.scrollHeight + "px"; body.style.height = height; requestAnimationFrame(() => { body.style.height = "0px"; }); setTimeout(() => { body.classList.add("close"); body.classList.remove("open"); body.style.height = "auto"; }, 226); arrow.classList.remove("rotated"); GM_setValue(foldKey, true); folded = true; } }; if (folded) { body.classList.add("close"); body.style.height = "0px"; arrow.classList.remove("rotated"); } else { body.style.height = "auto"; arrow.classList.add("rotated"); } container.addEventListener("click", e => { e.stopPropagation(); toggleFold(); }); } function attachHoverTip(element, text, onceOnly = false, afterShow = () => {}) { if (!text || text.trim() === "") return; const onEnter = e => { const timeout = setTimeout(() => { const tip = document.createElement("div"); tip.className = "vbnTipsHover"; tip.textContent = text; document.body.appendChild(tip); tip.classList.add("show"); const { clientX: x, clientY: y } = e; const { offsetWidth: w, offsetHeight: h } = tip; tip.style.left = `${Math.max(20, Math.min(x - w / 2, window.innerWidth - w - 20))}px`; tip.style.top = `${Math.max(20, y - h - 20)}px`; hoverTipMap.set(element, tip); if (typeof afterShow === "function") afterShow(); }, 500); hoverTimeoutMap.set(element, timeout); }; const onLeave = () => { const timeout = hoverTimeoutMap.get(element); if (typeof timeout === "number") { clearTimeout(timeout); hoverTimeoutMap.delete(element); } const tip = hoverTipMap.get(element); if (tip) { tip.remove(); hoverTipMap.delete(element); } if (onceOnly) { element.removeEventListener("mouseenter", onEnter); element.removeEventListener("mouseleave", onLeave); } }; element.addEventListener("mouseenter", onEnter); element.addEventListener("mouseleave", onLeave); } function attachEasterEggTip(toggleElement) { if (easterEggAttachedSet.has(toggleElement)) return; const shownCount = GM_getValue("vbn_EasterEgg_Shown_Count", 0); if (shownCount < 2) { const onceOnly = shownCount >= 1; attachHoverTip(toggleElement, "HEIHEI 彩蛋 | ClickClick", onceOnly, () => { GM_setValue("vbn_EasterEgg_Shown_Count", shownCount + 1); }); easterEggAttachedSet.add(toggleElement); } } function createToggleElement(key, value, enabled, meta) { const row = document.createElement("label"); row.className = "vbnBodyRow"; row.style.opacity = enabled ? 0.9 : 0.4; const span = document.createElement("span"); span.textContent = key; span.style.userSelect = "none"; const toggle = document.createElement("input"); toggle.type = "checkbox"; toggle.checked = value; toggle.id = `vbnChild_${key}`; toggle.disabled = !enabled; toggle.classList.add("vbnStatusDot"); if (meta.error) toggle.classList.add("error"); else if (meta.debug) toggle.classList.add("warn"); else if (toggle.checked) toggle.classList.add("correct"); toggle.addEventListener("change", () => { pendingChanges[key] = toggle.checked; toggle.classList.toggle("correct", toggle.checked); }); row.appendChild(span); row.appendChild(toggle); const hoverText = meta.error ? meta.errorMSG : (meta.feature || ""); if (hoverText) attachHoverTip(row, hoverText); return { row, toggle }; } function renderModuleEntry(modKey, mod, groupBody, groupEnabled) { if (modKey === "fold" || typeof mod.state !== "boolean") return; const currentVal = Boolean(GM_getValue(modKey, mod.default ?? true)); const foldedKey = `vbnFold_${modKey}`; const foldedRaw = GM_getValue(foldedKey, null); const folded = foldedRaw === null ? !!mod.fold : (foldedRaw === true || foldedRaw === "true"); if (mod.subs || mod.fold) { const container = document.createElement("div"); container.className = "vbnPanelGroup Sub"; const header = document.createElement("div"); header.className = "vbnGroupHeader"; const toggleSubs = document.createElement("div"); toggleSubs.className = "vbnFoldBox"; toggleSubs.style.cursor = "pointer"; attachEasterEggTip(toggleSubs); const arrow = document.createElement("div"); arrow.className = "vbnArrow"; arrow.textContent = "›"; if (!folded) arrow.classList.add("rotated"); toggleSubs.appendChild(arrow); const label = document.createElement("label"); label.className = "vbnHeaderRow"; const span = document.createElement("span"); span.textContent = modKey; span.style.marginRight = "auto"; span.style.userSelect = "none"; const toggle = document.createElement("input"); toggle.type = "checkbox"; toggle.checked = currentVal; toggle.id = `vbnChild_${modKey}`; toggle.disabled = !groupEnabled; toggle.classList.add("vbnStatusDot"); label.style.opacity = groupEnabled && currentVal ? 0.9 : 0.4; if (mod.error) toggle.classList.add("error"); else if (mod.debug) toggle.classList.add("warn"); else if (toggle.checked) toggle.classList.add("correct"); toggle.addEventListener("change", () => { pendingChanges[modKey] = toggle.checked; toggle.classList.toggle("correct", toggle.checked); label.style.opacity = groupEnabled && toggle.checked ? 0.9 : 0.4; if (mod.subs) { for (const [subKey, subMod] of Object.entries(mod.subs)) { const subCheckbox = document.querySelector(`#vbnChild_${subKey}`); if (subCheckbox) { subCheckbox.disabled = !toggle.checked; const isChecked = subCheckbox.checked; const parent = subCheckbox.closest(".vbnBodyRow"); if (parent) { parent.style.opacity = toggle.checked && isChecked ? 0.9 : 0.4; } } } } }); label.appendChild(span); label.appendChild(toggle); header.appendChild(toggleSubs); header.appendChild(label); const hoverText = mod.error ? mod.errorMSG : (mod.feature || ""); if (hoverText) attachHoverTip(header, hoverText); const body = document.createElement("div"); body.className = "vbnGroupBody"; container.appendChild(header); container.appendChild(body); createFoldAnimation(toggleSubs, body, arrow, foldedKey, folded); if (mod.subs) { for (const [subKey, subMod] of Object.entries(mod.subs)) { if (typeof subMod.state !== "boolean") continue; const curVal = Boolean(GM_getValue(subKey, subMod.default ?? true)); const enabled = groupEnabled && currentVal; const { row } = createToggleElement(subKey, curVal, enabled, subMod); row.style.opacity = enabled && curVal ? 0.9 : 0.4; body.appendChild(row); } } groupBody.appendChild(container); } else { const { row } = createToggleElement(modKey, currentVal, groupEnabled, mod); groupBody.appendChild(row); } } function onGroupToggleChange(groupKey, groupData, groupToggle) { pendingChanges[groupKey] = groupToggle.checked; groupToggle.classList.toggle("correct", groupToggle.checked); for (const [modKey, mod] of Object.entries(groupData)) { if (modKey === "fold") continue; const allKeys = [modKey]; if (mod.subs) allKeys.push(...Object.keys(mod.subs)); allKeys.forEach(k => { const checkbox = document.querySelector(`#vbnChild_${k}`); if (checkbox) { checkbox.disabled = !groupToggle.checked; const isEnabled = groupToggle.checked; const isChecked = checkbox.checked; const parent = checkbox.closest(".vbnBodyRow, .vbnHeaderRow"); if (parent) parent.style.opacity = isEnabled && isChecked ? 0.9 : 0.4; } }); } } function buildPanel() { if (document.querySelector("#vbnOptionsPanel")) return; const panel = document.createElement("div"); panel.id = "vbnOptionsPanel"; panel.className = "vbnPanelBase vbnOptionBase vbnFixed"; const title = document.createElement("h2"); title.textContent = "Options"; panel.appendChild(title); const allModules = VBN_MODULE_STORE.getTree(); for (const [groupName, groupData] of Object.entries(allModules)) { const groupKey = groupName; const groupEnabled = GM_getValue(groupKey, true); const groupContainer = document.createElement("div"); groupContainer.className = "vbnPanelGroup"; const groupHeaderWrapper = document.createElement("div"); groupHeaderWrapper.className = "vbnGroupHeader"; const arrowBox = document.createElement("div"); arrowBox.className = "vbnFoldBox"; const toggleIcon = document.createElement("div"); toggleIcon.textContent = "›"; toggleIcon.className = "vbnArrow"; const foldedRaw = GM_getValue(`vbnFold_${groupKey}`, null); const folded = foldedRaw === null ? !!groupData.fold : (foldedRaw === true || foldedRaw === "true"); arrowBox.appendChild(toggleIcon); const groupHeader = document.createElement("label"); groupHeader.className = "vbnHeaderRow"; const groupTitle = document.createElement("span"); groupTitle.textContent = groupName; groupTitle.style.marginRight = "auto"; const groupToggle = document.createElement("input"); groupToggle.type = "checkbox"; groupToggle.checked = groupEnabled; if (groupEnabled) groupToggle.classList.add("correct"); groupHeader.appendChild(groupTitle); groupHeader.appendChild(groupToggle); groupHeaderWrapper.appendChild(arrowBox); groupHeaderWrapper.appendChild(groupHeader); groupContainer.appendChild(groupHeaderWrapper); const groupBody = document.createElement("div"); groupBody.className = "vbnGroupBody"; groupContainer.appendChild(groupBody); createFoldAnimation(arrowBox, groupBody, toggleIcon, `vbnFold_${groupKey}`, folded); groupToggle.addEventListener("change", () => { onGroupToggleChange(groupKey, groupData, groupToggle); }); for (const [modKey, mod] of Object.entries(groupData)) { if (modKey === "fold") continue; renderModuleEntry(modKey, mod, groupBody, groupEnabled); } panel.appendChild(groupContainer); } const applyBtn = document.createElement("button"); applyBtn.textContent = "Apply"; applyBtn.className = "vbnButtonBase vbnButtonAdapt open"; applyBtn.addEventListener("click", () => { for (const [key, value] of Object.entries(pendingChanges)) { GM_setValue(key, !!value); } showTip("✔ 已应用", "correct"); setTimeout(() => location.reload(), 260); // 应用后 刷新页面的延迟 }); const resetBtn = document.createElement("button"); resetBtn.textContent = "Reset"; resetBtn.className = "vbnButtonBase vbnButtonAdapt close"; resetBtn.addEventListener("click", () => { const allModules = VBN_MODULE_STORE.getTree(); for (const [groupKey, groupData] of Object.entries(allModules)) { GM_setValue(groupKey, true); // 模块组默认开启 for (const [modKey, mod] of Object.entries(groupData)) { if (modKey === "fold") continue; GM_setValue(modKey, mod.default ?? true); // 功能模块 采用默认值 if (mod.subs) { for (const [subKey, subMod] of Object.entries(mod.subs)) { GM_setValue(subKey, subMod.default ?? true); // 子功能 采用默认值 } } } } for (const [groupKey, groupData] of Object.entries(allModules)) { GM_deleteValue(`vbnFold_${groupKey}`); for (const [modKey, mod] of Object.entries(groupData)) { GM_deleteValue(`vbnFold_${modKey}`); if (mod.subs) { for (const subKey of Object.keys(mod.subs)) { GM_deleteValue(`vbnFold_${subKey}`); } } } } if (typeof VBN_GLOBAL_CACHE?.clear === "function") { VBN_GLOBAL_CACHE.clear(); } showTip("✔ 已重置为默认配置", "correct"); setTimeout(() => location.reload(), 520); // 重置后 刷新页面的延迟 }); panel.appendChild(applyBtn); panel.appendChild(resetBtn); VBN_GLOBAL_DOM.load(dom => dom.appendChild(panel)); setTimeout(() => panel.classList.add("show"), 20); // 延迟 XXXXX 显示面板 setTimeout(() => { function handleClickOutside(e) { if (!panel.contains(e.target)) { panel.classList.add("hide"); setTimeout(() => { // 延迟 XXXXX 移除面板 panel.remove(); document.removeEventListener("click", handleClickOutside); }, 526); } } document.addEventListener("click", handleClickOutside); }, 100); // 延迟 XXXXX 绑定外部点击事件 } GM_registerMenuCommand("👽 Options Panel", buildPanel); })(); // #endregion // #region Theme (function VBN_Theme() { const ruleBase = { light: [ "light", "light-theme", "theme-light" ], dark: [ "dark", "dark-theme", "theme-dark" ] }; const ruleAntonym = { light: [ "darker-dark-theme-deprecate", ], dark: [ ] }; let currentTheme = null; function themeSystem() { const dark = window.matchMedia("(prefers-color-scheme: dark)").matches; const light = window.matchMedia("(prefers-color-scheme: light)").matches; return dark ? "dark" : light ? "light" : null; } function matchCount(target, keywords) { if (!target) return 0; const items = [...target.classList, ...target.getAttributeNames?.() || []].map(i => i.toLowerCase()); return keywords.reduce((count, key) => count + (items.includes(key) ? 1 : 0), 0); } function themeWebsite() { const html = document.documentElement, body = document.body; let score = 0; score += matchCount(html, ruleAntonym.dark) - matchCount(html, ruleAntonym.light); score += matchCount(body, ruleAntonym.dark) - matchCount(body, ruleAntonym.light); if (score !== 0) return score > 0 ? "dark" : "light"; score = 0; score += matchCount(html, ruleBase.dark) - matchCount(html, ruleBase.light); score += matchCount(body, ruleBase.dark) - matchCount(body, ruleBase.light); if (score !== 0) return score > 0 ? "dark" : "light"; return null; } function subjoinClass() { const html = document.documentElement; let newTheme = themeWebsite() || themeSystem(); if (!newTheme) newTheme = "light"; if (newTheme === currentTheme) return; html.classList.remove("vbnThemeLight", "vbnThemeDark"); html.classList.add(newTheme === "light" ? "vbnThemeLight" : "vbnThemeDark"); currentTheme = newTheme; } function debounce(fn, delay = 20) { let timer; return () => { clearTimeout(timer); timer = setTimeout(fn, delay); }; } function observeTargets() { const targets = [document.documentElement]; if (document.body) targets.push(document.body); const observerOptions = { attributes: true }; const handler = debounce(subjoinClass, 20); targets.forEach((target, i) => { VBN_OBSERVER_CENTER.observeWithKey( `vbnTheme_${i}`, target, observerOptions, handler, { preventDuplicate: true, autoDisconnect: false } ); }); } function init() { const start = () => { subjoinClass(); observeTargets(); window.matchMedia("(prefers-color-scheme: dark)").addEventListener("change", subjoinClass); window.matchMedia("(prefers-color-scheme: light)").addEventListener("change", subjoinClass); }; if (document.readyState === "loading") { document.addEventListener("DOMContentLoaded", start); } else { start(); } } init(); })(); // #endregion // #region LoaderBar VBN_GLOBAL_LOGIC.activate("LoaderBar", () => { (function VBN_LoaderBar() { function progressBarCreate() { let loaderBar = document.createElement('div'); loaderBar.id = 'vbnLoaderBar'; VBN_GLOBAL_DOM.load(dom => dom.appendChild(loaderBar)); function loaderBarUpdate() { let progress = (document.readyState === 'interactive') ? 80 : (document.readyState === 'complete' ? 100 : 0); loaderBar.style.width = progress + '%'; if (progress === 100) { setTimeout(() => { loaderBar.dataset.state = "vbnScrollBar"; loaderBar.style.animation = "none"; scrollBarUpdate(); if (document.documentElement.scrollHeight > window.innerHeight) { window.addEventListener('scroll', scrollBarUpdate); loaderBar.style.display = 'block'; } else { loaderBar.style.display = 'none'; } }, 260); } } function scrollBarUpdate() { let scrollTop = document.documentElement.scrollTop || document.body.scrollTop; let scrollHeight = document.documentElement.scrollHeight - document.documentElement.clientHeight; let scrollProgress = (scrollTop / scrollHeight) * 100; loaderBar.style.width = scrollProgress + '%'; } document.addEventListener('readystatechange', loaderBarUpdate); } if (document.body) { progressBarCreate(); } else { VBN_OBSERVER_CENTER.observe( document.documentElement, { childList: true, subtree: true }, (mutations, observer) => { if (document.body) { observer.disconnect(); progressBarCreate(); } }, { onceWhen: () => document.body !== null } ); } })(); }); // #endregion // #region ICON (function VBN_CustomICON() { // 配置映射关系 "网址" => "变量" 「可转至350行左右配置对应变量 支持格式 JPG PNG SVG base64...」 const vbnICON_Map = { "chat.deepseek.com": "--vbnICON-URL-Deepseek", "chatgpt.com": "--vbnICON-URL-OpenAI", "gemini.google.com": "--vbnICON-URL-Gemini-Vint", "liblib.art": "--vbnICON-URL-Liblib", "prompts.chat": "--vbnICON-URL-Prompt", "comfyworkflows.com": "--vbnICON-URL-Workflow", "ticktick.com": "--vbnICON-URL-Tick-Vint", "dida365.com": "--vbnICON-URL-Tick-Vint", "yuque.com": "--vbnICON-URL-YUQUE", "dillinger.io": "--vbnICON-URL-Markdown-Line", "m.ssone.io": "--vbnICON-URL-Network", "my.ssonegames.com": "--vbnICON-URL-Network", "ip.skk.moe": "--vbnICON-URL-Mecha", "convertio.co": "--vbnICON-URL-Transition", "bigjpg.com": "--vbnICON-URL-AIGC", "abbreviationfinder.org": "--vbnICON-URL-Character", "dict.cn": "--vbnICON-URL-Dict", "svgviewer.dev": "--vbnICON-URL-SVG", "2yu7z0.smartapps.baidu.com": "--vbnICON-URL-Music", }; const vbnICON_Matched = Object.keys(vbnICON_Map).find(site => vbnMatchHost.includes(site)); if ( VBN_GLOBAL_LOGIC.activate("CustomICON") && vbnICON_Matched ) { const vbnICON_CssVarName = vbnICON_Map[vbnICON_Matched]; const vbnICON_URL = getComputedStyle(document.documentElement) .getPropertyValue(vbnICON_CssVarName) .trim() .replace(/^url\(["']?(.*?)["']?\)$/i, '$1') .replace(/["']/g, ''); const vbnICON_TagLink = document.querySelector("link[rel*='icon']") || document.createElement('link'); if ( vbnICON_URL.startsWith('data:image/svg+xml;base64,') || vbnICON_URL.endsWith('.svg') ) { vbnICON_TagLink.type = 'image/svg+xml'; } else if ( vbnICON_URL.endsWith('.png') || vbnICON_URL.endsWith('.jpg') || vbnICON_URL.endsWith('.jpeg') || vbnICON_URL.startsWith('data:image/png;base64,') || vbnICON_URL.startsWith('data:image/jpeg;base64,') ) { vbnICON_TagLink.type = 'image/png'; } else { vbnICON_TagLink.type = 'image/x-icon'; } vbnICON_TagLink.rel = 'icon'; vbnICON_TagLink.href = vbnICON_URL; const head = document.head; head.appendChild(vbnICON_TagLink); } })(); // #endregion // #region FontStyle VBN_GLOBAL_LOGIC.activate("FontStyle", { matchSubjoin: { include: [ "file:///*", "*iconfont.cn/*", "*emojiall.com/*", "*greasyfork.org/*", "*juejin.cn/*", "*prompts.chat/*", ...VBN_SITE_GROUP.AIGC, ...VBN_SITE_GROUP.Chat, ...VBN_SITE_GROUP.ProgDev, ...VBN_SITE_GROUP.Manage, ...VBN_SITE_GROUP.Search, ...VBN_SITE_GROUP.Media, ], exclude: [ "*youtube.com/*", ...VBN_SITE_GROUP.Font, ] } }, () => { GM_addStyle( /* css */ ` *:not( .code, .pre, .inline-code, .md-code, .blob-code, .blob-code-inner, .js-file-line, .code-block, .code-container, .language-css, .cm-line, .cm-line span, ne-code, ne-text, .icon, .icon-wrap, .fa, .DPvwYc, path, svg, i, .block-pagination ul *, #sslct, .markdown-body pre, .markdown-body code, code, pre, kbd, samp, textarea, [class^="language-"], [class*="-code"], [class$="-language"], [class*="editor"], [class*="icon"], [class*="emoji"] ) { font-family: var(--vbnBaseFont) !important; } .code, .pre, .inline-code, .md-code, .blob-code, .blob-code-inner, .js-file-line, .code-block, .code-container, .language-css, .cm-line, .cm-line span, ne-code, ne-text, .Box-sc-g0xbh4-0.iJOeCH *, .markdown-body pre, .markdown-body code, code, pre, kbd, samp, textarea, [class^="language-"], [class*="-code"] { font-family: var(--vbnCodeFont) !important; } .inline-code, .ds-markdown code, .prose :where(code):not(:where([class~=not-prose] *), pre *) { padding: .126em .4em !important; font-weight: 526 !important; text-shadow: 0 0 .126em currentColor !important; } `); }); // #endregion // #region Selection VBN_GLOBAL_LOGIC.activate("Selection", () => { GM_addStyle(` ::selection { color: #E2E2E2 !important; background: var(--vbnBase04HEX) !important; } `); }); // #endregion // #region ScrollBar VBN_GLOBAL_LOGIC.activate("ScrollBar", () => { GM_addStyle( /* css */ ` ::-webkit-scrollbar { width: 5px !important; height: 5px !important; scroll-behavior: smooth !important; border-radius: 100vmax !important; } /* ========== 滑块 */ ::-webkit-scrollbar-thumb { background: hsla(var(--vbnBase05HSL), 0.4) !important; border-radius: 100vmax !important; } ::-webkit-scrollbar-thumb:vertical { background-image: "" !important;} ::-webkit-scrollbar-thumb:horizontal { background-image: "" !important;} ::-webkit-scrollbar-thumb:hover { background: linear-gradient( 90deg, hsla(var(--vbnGlow05HSL), 1), hsla(var(--vbnGlow05HSL), 1), hsla(var(--vbnGlow03HSL), 1)) !important; } /* ========== 背景 */ ::-webkit-scrollbar-track { background: transparent !important; border-radius: 100vmax !important; } /* ========== 上下按钮 */ ::-webkit-scrollbar-button { display: none !important;} /* ========== 滑块以外 */ ::-webkit-scrollbar-track-piece { display: none !important;} /* ========== 滚动条交界处角落区域 */ ::-webkit-scrollbar-corner { display: none !important;} ::-webkit-resizer { display: none !important;} `); }); // #endregion // $ ================================================== ↓ Assign // #region Baidu VBN_GLOBAL_LOGIC.activate("Search", { matchSubjoin: { include: [ "*baidu.com/*" ], exclude: [] } }, () => { GM_addStyle( /* css */ ` html #wrapper #wrapper_wrapper #container #content_left .c-container[tpl="XXXXX"] { vbn { top: var(); } } /* ============================== ↓ Global */ html #wrapper { --colorKeyWord: #3978d0; --SearchWidth: calc(var(--vbnSpaceWidthVW) / 2 ); --bgRepair: -6px; } html .wrapper_new { background: var(--vbnBase09HEX);} /* ========== ↓ 隐藏模块 */ html #searchTag, /* 顶部 - 搜索关联词 */ html #rs_new .c-color-t.rs-label_ihUhK, /* 底部 - 相关搜索 标题 */ html #wrapper #container #content_right, /* 内容区 - 右侧板块 */ html #wrapper #container .c-container[tpl="note_lead"], /* 内容区 - 模块 精选笔记 */ html #wrapper #container .c-container[tpl="yl_vd_generic_new"], /* 内容区 - 模块 电影 */ html #wrapper #container .c-container[tpl="recommend_list"] .c-color-t.title_Zinx- /* 内容区 - 大家还搜索了 标题 */ { display: none; } /* ========== ↓ 移除下划线 */ html .doc-title_3Jos6 a:hover, html .doc-title_3Jos6 a:hover em { text-decoration: none !important; } html a, html em, html :link, html a:hover, html em:hover, a:hover em, html a.cos-link:hover, html #wrapper #container .c-container .t *, html #wrapper #container .c-container .c-title *, html #wrapper #container .c-container .cosc-title-a :hover, html #wrapper #container .c-container .cosc-title-a :hover em, html #wrapper #container .c-container .cosc-title-slot, html #wrapper #container .c-container .cosc-title-slot *, html #wrapper #container .c-container .cosc-title-slot:hover, html #wrapper #container .c-container .cosc-title-slot:hover *, html #wrapper #container .c-container .title_7Iz74 .cos-link, html #wrapper #container .c-container ._sc-title_1g9za_66 *, html #wrapper #container .c-container ._sc-title_1g9za_66 :hover, html #wrapper #container .c-container ._sc-title_1g9za_66 :hover *, html #wrapper #container .c-container .video-main-title_S_LlQ:hover .title-default_518ig, html #wrapper #container .c-container .site-link_1JEbM .custom-underline a .cosc-title-slot:hover, html #wrapper #container .c-container ._head-title_1ml43_142 ._link_1ml43_146:hover ._paragraph_1ml43_156 { text-decoration: none; } /* ========== ↓ 内容区图片尺寸 */ html .c-container[tpl="ai_ecology"] .cos-row-col-12 > .cos-col-6, /* 轻秒图片转换器 */ html .c-container .cos-swiper-list .cos-swiper-item[style*="width: calc(33% - 5px)"], /* 百度有驾 */ html .c-container .video-wrap_7yrJ0 .cos-swiper-list .cos-swiper-item[style*="width: 34%;"] /* 百度翻译 */ { width: 15% !important; } html .c-container .cos-row > .cos-col[style*="width:25%"], /* 百度百科 */ html #wrapper #container .c-container[tpl="sg_kg_entity_san"] .cos-row.cos-gutter > .cos-col-3, /* 百度百科 */ html .c-container[tpl="nvl_bookstore_san"] .cos-row-col-12 > .cos-col-3, /* 在线阅读 */ html .c-container .cos-row.bottom-gap_2aWpR.single-image_6zdhC > .cos-col[style*="width:24.5%"] /* 电影 封面 */ { width: 10% !important; } /* ========== ↓ 原生模块边框 */ html .pc-fresh-smooth .c-group-wrapper::after, html .pc-fresh-smooth .cosc-card-shadow:after, html .pc-fresh-smooth .new-pmd .c-border::after, html .pc-fresh-smooth .cu-border._content-border_1ml43_4:after { border: transparent; } /* ========== ↓ 原生模块阴影 */ html .cu-border, html .new-pmd .c-border, html .cosc-card-shadow, html .re-box-shadow_3l74t, html .re-box-shadow_1FfgR, html .pc-first-style_4Jcx0 { box-shadow: none; } /* ========== ↓ 标题 */ html #wrapper #container h3:not( .cos-space-mt-md h3, .card-title_2GtKe h3, .exta-links-pc_2sXPl h3, .exta-link-pc_3aUAb h3, .c-container[tpl="wenda_generate"] h3, ) { padding: var(--vbnSpacePadding); margin: -10px -20px 10px -20px; width: 100%; background: var(--vbnBase09HEX); border-radius: var(--vbnSurfaceRadius) var(--vbnSurfaceRadius) 5px 5px; } html .cos-pc .title-box_4YBsj { width: 100%; } html .cos-pc .title-wrapper_6E6PV { margin-top: -10px; } html .cos-pc .title-wrapper_6E6PV .pre-text_6ulGP { z-index: 1; } html ._link_1iyz5_2 { margin-bottom: 0; } /* ========== ↓ 标题文字 */ html a, html a:hover, html a.cos-link, html a.cos-link:hover { color: var(--colorKeyWord); } html ._paragraph_1g9za_2.md, html .cosc-title-md, html #wrapper #container.sam_newgrid .c-container .t, html #wrapper #container.sam_newgrid .c-container .c-title { color: var(--colorKeyWord); font-size: 15px; font-weight: bold; line-height: 1.5; } /* ========== ↓ 官方标 */ html .cos-pc .title-wrapper_6E6PV .suffix-icon_3Ox2w { position: absolute; top: -.55em; right: -1em; } html .cos-pc .title-wrapper_6E6PV .suffix-icon_3Ox2w .www-tag-fill-blue_3n0y3 { border-radius: var(--vbnUIRadius); } /* ========== ↓ 标题 icon */ html .front-icon_7wpfB { z-index: 999;} /* ========== ↓ 模块 通用 */ html #wrapper #container .new-pmd.c-container, html #wrapper #container .new-pmd[tpl="app/rs"] { box-sizing: border-box; position: relative; padding: var(--vbnSpacePadding); margin: var(--vbnSpaceMargin); width: 100%; font-size: 12px; background: #FFFFFF; box-shadow: var(--vbnOftenSurfaceShadowBase); border-radius: var(--vbnSurfaceRadius); transition: var(--vbnOftenTransition); } html #wrapper #container .new-pmd.c-container:hover, html #wrapper #container .new-pmd[tpl="app/rs"]:hover { z-index: 2; box-shadow: inset 0 0 2px hsla(0, 0%, 92%, .6), var(--vbnOftenSurfaceShadowHover); transform: var(--vbnSurfaceZoomIn); } html #wrapper #container #content_left > :first-of-type:hover, /* 内容区 首个 */ html #wrapper #container .new-pmd[tpl="app/rs"]:hover, /* 相关搜索 */ html #wrapper #container .new-pmd.c-container[tpl="jr_stock"]:hover, /* 百度股市通 */ html #wrapper #container .new-pmd.c-container[tpl="jr_exchange_rate"]:hover, /* 百度股市通 */ html #wrapper #container .new-pmd.c-container[tpl="wenda_generate"]:hover, /* AI 问答生成 */ html #wrapper #container .new-pmd.c-container[tpl="ai_ask"]:hover, /* AI 提问 */ html #wrapper #container .new-pmd.c-container[tpl="image_grid_san"]:hover, /* 百度图片 */ html #wrapper #container .new-pmd.c-container[tpl="ai_agent_qa_recommend"]:hover /* 聊一下更多精彩 */ { transform: none; } /* ---------- ↓ 内容块 -> 内容 距离 */ html ._content-border_1ml43_4:not([tpl="jy_hy_zi_accu_san"] ._content-border_1ml43_4) { padding: var(--vbnSpacePadding); margin: 0 -20px; } /* ---------- ↓ 内容块 -> 内容 宽度 */ html #wrapper #container .c-container[tpl="www_index"] { vbn { top: var(); } .cos-row .cos-col.content-space-between_44mGk[style*="width:75%;"] { width: 89% !important; } } /* ========== ↓ Markdown AI 问答区 「预计更改」 */ html .cosd-markdown .marklang h3 { font-size: 14px; } html .cosd-markdown .marklang, html .cosd-markdown .marklang .marklang-paragraph { font-size: 14px; } /* ============================== ↓ Head */ html .wrapper_new #head { top: 0; width: 100%; background: var(--vbnGlassLight); backdrop-filter: var(--vbnPanelFilter); transition: var(--vbnOftenTransition); } html .wrapper_new #head.peak-down { background: transparent; } html .wrapper_new #head.no-box-shadow, html .wrapper_new #head.no-box-shadow.s_down { box-shadow: var(--vbnGlassShadow); } html #wrapper #head:not(.s-manhattan-index div, .s_form_nologin div) { vbn { top: var(); } .head_wrapper { display: flex; justify-content: space-around; transform: translate3d(-15px, 0 , 1px); width: 100%; } /* ========== ↓ 用户中心 */ .head_wrapper #u { position: fixed; right: 40px; padding: 0; } /* ========== ↓ 搜索框 */ .s_form { display: flex; justify-content: center; padding: 0; width: auto; } .s_ipt_wr { width: var(--SearchWidth); } .s_form_fresh { width: inherit; padding: 0; } .bdsug-new { width: var(--SearchWidth); } .soutu-env-new .soutu-layer .soutu-url-wrap, .soutu-env-new .soutu-layer #soutu-url-kw { width: var(--SearchWidth); } #kw.s_ipt { width: 87%; } } /* ========== ↓ 分类 */ html .result-molecule.new-pmd:has(#s_tab) { --container-left-gap: auto; display: flex; justify-content: center; } html #wrapper .new-pmd[tpl="app/head-tab"] { vbn { top: var(); } #s_tab { display: flex; justify-content: center; border: none; padding-top: 70px; padding-left: 0; } #s_tab .s_tab_inner { display: flex; justify-content: space-between; width: calc(var(--vbnSpaceWidthVW) / 2 + 260px); min-width: 920px; padding-left: 0; } } /* ========== ↓ 检索信息 搜索框下 */ html #rs_top_new, html .hit-toptip, html .hit_top_new { opacity: .6; display: flex; justify-content: center; margin-top: calc(-1.2em + -2.6px); width: auto; } html #wrapper .new-pmd[tpl="app/search-tool"] { vbn { top: var(); } br { display: none; } /* ========== ↓ 筛选信息 */ .outer_wqJjM { margin: 10px 0 -10px 0;} .options_2Vntk { opacity: .8; width: 90%; margin: 0 auto;} } html #wrapper .new-pmd[tpl="app/toptip"] { vbn { top: var(); } br { display: none; } } html #wrapper .new-pmd[tpl="app/hit-top-new"] { vbn { top: var(); } br { display: none; } .c-icon-bear-circle { transform: scale(.8); } } /* ============================== ↓ Content */ html #wrapper #wrapper_wrapper { margin: 0 auto; width: var(--vbnSpaceWidthVW); } html #wrapper #container { width: 100%; padding: 0; margin: 0 auto; } html #wrapper #container #content_left { width: 100%; padding: 0 !important; margin: 0 auto !important; } /* ========== ↓ 组件 */ /* ========== ↓ 计算器 */ html #wrapper #container .c-container[tpl="ms_new_calc"] { vbn { top: var(); } .new-pmd { width: 60%; margin: 20px auto; } .calc-oprate_24c8k { display: flex; justify-content: space-evenly; } .calc-oprate_24c8k .func-calc_3t0OK { width: 60%;} .calc-box_1qoea { box-shadow: inset 1px 1px 1px 0px rgba(255, 255, 255, 0.8), inset -1px -1px 1px 0px rgba(40, 49, 85, 0.3), 1px 1px 3px 0px rgba(40, 49, 85, 0.1); } } /* ========== ↓ 日历 */ html #wrapper #container .c-container[tpl="ms_calendar_san"] { vbn { top: var(); } &.new-pmd { width: 60%; min-width: 600px; margin: 20px auto; } ._bg-header_1ml43_46 { width: 99%; top: -5px; left: 5px; } } /* ========== ↓ 汇率换算 */ html #wrapper #container .c-container[tpl="jr_exrate_san"] { vbn { top: var(); } .aladdin_3Tvaz .bg-header_G63NE { top: var(--bgRepair); } } /* ========== ↓ 单位换算 */ html #wrapper #container .c-container[tpl="ms_measures_san"] { vbn { top: var(); } .cosc-card-light-bg { top: -18px; } .cosc-card-horizontal-gradient { width: 110%; background-position: center; } } /* ========== ↓ 模块 百度AI */ html #wrapper .c-group-wrapper { padding: 0; margin: 0; background: transparent; box-shadow: none; } html #wrapper .c-group-wrapper .result-op { width: 100% !important; } html #wrapper #container .new-pmd.c-container[tpl="wenda_generate"] { padding-top: 20px; } /* ========== ↓ 问答生成 */ html #wrapper #container .c-container[tpl="ai_index"], html #wrapper #container .c-container[tpl="wenda_generate"], html #wrapper #container .c-container[tpl="new_baikan_index"] { overflow: auto; max-height: 526px; &::-webkit-scrollbar { display: none; } /* .cosc-card-content { margin-top: var(--bgRepair); } */ .cosc-card-light-bg:not([tpl="wenda_generate"] div) { top: var(--bgRepair); } .cosd-markdown .marklang .marklang-paragraph { line-height: 1.5; } } html #wrapper #container .c-container[tpl="ai_index"] { vbn { top: var(); } div[class*="_aladdin"] { width: 97%; margin: 0 auto; padding: 0; } .swiper-box_33dzT { width: 102.6%; margin: -10px auto; margin-left: -20px; box-shadow: none; border-radius: var(--vbnPanelRadius); } ._bg-header_1ml43_46 { overflow: visible; } ._horizontal-gradient_1ml43_56 { width: 102.6%; margin: 3px auto; margin-left: -20px; background-size: 110% 100% !important; background-position: top center !important; border-radius: var(--vbnPanelRadius); } } html #wrapper #container .c-container[tpl="wenda_generate"] { vbn { top: var(); } /* ---------- ↓ ICON 听 */ .audio_63a7U { margin-top: 0; } } html #wrapper #container .c-container[tpl="new_baikan_index"] { vbn { top: var(); } } html #wrapper #container .c-container[tpl="ai_ask"] { vbn { top: var(); } } /* ========== ↓ 模块 百度健康 */ html #wrapper #container .c-container[tpl="med_aigc_guru_san"] { vbn { top: var(); } .medAigcPcCard_29xxv { margin-top: -5px; } } /* ========== ↓ 模块 百度翻译 */ html #wrapper #container .c-container[tpl="fy_fanyi_ai_san"], html #wrapper #container .c-container[tpl="fy_sg_dictwisenew_san"] { vbn { top: var(); } h3 { /* margin: -10px -20px -5px -20px; */ background: transparent; } .dict-card_Pbfer .cosc-card { padding-top: 0 !important; } .daoliu-con_3mmBo { margin-top: 15px; } .footer_6VBOp { margin-top: -5px; } .cosc-card-content { margin-top: var(--bgRepair); } .cosc-card-light-bg:not([tpl="wenda_generate"] div) { top: var(--bgRepair); } } /* ========== ↓ 模块 百度贴吧 */ html #wrapper #container .c-container[tpl="tieba_general"] { vbn { top: var(); } .cos-space-mt-md { width: 96%; } } /* ========== ↓ 模块 百度图片 */ html #wrapper #container .c-container[tpl="image_grid_san"] { vbn { top: var(); } h3 { margin: 0px -20px; background: transparent; } .image-container_7qr7Y.image-container-pc_57ELg { display: flex; gap: 40px; } .image-container_7qr7Y .row-border-list_50f1g { gap: 20px; } } /* ========== ↓ 模块 百度百科 */ html #wrapper #container .c-container[tpl="bk_polysemy"] { vbn { top: var(); } .c-span9 { width: calc(100% - 128px - 20px); } .c-span12 { width: 100%; } } html #wrapper #container .c-container[tpl="sg_kg_entity_san"] { vbn { top: var(); } .button_sx9Ei .content_7L4g2 { color: var(--colorKeyWord); } .c-span9 { width: 85%; } /* ========== ↓ 演员列表 */ .cos-swiper-list { justify-content: space-around; } } /* ========== ↓ 模块 百度文库 */ /* html #wrapper #container .c-container[tpl="www_index"][mu*="https://wenku.baidu.com/"] { vbn { top: var(); } */ html #wrapper #container .c-container[tpl="jy_wenku_wenshu"] { vbn { top: var(); } h3 { padding: 10px 45px; margin: -10px -20px 10px -43px; } .title-wrapper_6E6PV .front-icon_7wpfB { z-index: 1; font-size: 15px; } /* ========== ↓ 修复标题 */ .doc-title_3Jos6 { background: transparent; } } /* ========== ↓ 模块 百度汉语 */ html #wrapper #container .c-container[tpl="jy_hy_zi_attr_san"], html #wrapper #container .c-container[tpl="jy_hy_zi_accu_san"] { vbn { top: var(); } .bg-header_2y46S._bg-header_1ml43_46, .bg-header_5SZvD { width: 102%; top: -6px; left: -15px; right: 0; } h3 { background: transparent; } } /* ========== ↓ 模块 百度天气 */ html #wrapper #container .c-container[tpl="weather_forecast_san"] { vbn { top: var(); } --width: 10px; .content-border_2OSp3 { box-shadow: none; } /* ========== ↓ 按钮 左右翻页 */ .load_4cwYw.back_5ndVv { left: var(--width); } .load_4cwYw.more_3kyUW { right: var(--width); } } /* ========== ↓ 模块 百度有驾 */ html #wrapper #container .c-container[tpl="car_kg2_san"] { vbn { top: var(); } } /* ========== ↓ 模块 AI 工具箱 */ html #wrapper #container .c-container[tpl="ai_ecology"] { vbn { top: var(); } --width: 12%; .cos-row-col-12 > .cos-col-3 { width: var(--width); } .card-footer-normal_nPWGd { left: calc(var(--width) - 15px/4); } } /* ========== ↓ 模块 音乐 */ html #wrapper #container .c-container[tpl="yl_music_song"] { vbn { top: var(); } --width: 1260px; .table-container_39X6k .table-thead_2yUCX .th-num_390pb, .table-container_39X6k .table-tbody_3exJd .td-num_evVor { width: var(--width); } } /* ========== ↓ 模块 百家号 */ /* ========== ↓ 模块 全网热卖 */ html #wrapper #container .c-container[tpl="sp_purc_pc"] { vbn { top: var(); } h3 { margin: -22px -20px 10px -20px; } .content-wrap_2UG9e > div[style*="display: block"] { display: flex !important; justify-content: space-evenly; } .row_IIB9a { margin: 0; } .sp_purc_pc-sku-item_3KDHq { margin: 15px 40px 15px 0; } } /* ========== ↓ 模块 在线阅读 */ /* ========== ↓ 模块 在线观看 */ html #wrapper #container .c-container[tpl="yl-vd-basis"] { vbn { top: var(); } .c-span9 { width: max-content; } } /* ========== ↓ 模块 高清在线观看 */ html #wrapper #container .c-container[tpl="short_video"] { vbn { top: var(); } .content_LHXYt > div { display: flex; gap: 20px; } .content_LHXYt .c-row { display: flex; gap: 20px; } .c-gap-top-large, .c-span4 { margin: 0; } } /* ========== ↓ 模块 聊一下更多精彩 */ html #wrapper #container .c-container[tpl="ai_agent_distribute"] { vbn { top: var(); } .card-title_6qPL6 { width: 100%; } .content_EbWw1 .common-content_4dXMi { width: 95%; } } /* ========== ↓ 模块 实时智能回复 */ html #wrapper #container .c-container[tpl="ai_agent_qa_recommend"] { vbn { top: var(); } /* ========== ↓ 标题 */ .cos-space-mt-lg { margin-top: 0; } .agent-qa-card_3V5cX .card-title_2GtKe { margin: 10px 0; } } /* ========== ↓ 模块 最新信息 */ html #wrapper #container .c-container[tpl="news-realtime"] { vbn { top: var(); } .single-card-wrapper_2nlg9 { display: flex; justify-content: flex-start; border-radius: var(--vbnSurfaceRadius); box-shadow: none; } .single-card-wrapper_2nlg9 > .c-row { display: flex; } .single-card-wrapper_2nlg9 > .c-row:last-of-type { display: none; } } /* ========== ↓ 模块 最新相关信息 */ html #wrapper #container .c-container[tpl="rel_base_realtime"] { vbn { top: var(); } img { border-radius: var(--vbnBaseRadius); } .cos-image-3-2 { padding-bottom: 25%; } .cos-image-fit-cover .cos-image-background { background-size: contain; } } /* ========== ↓ 模块 最新相关信息 */ html #wrapper #container .c-container[mu*="https://wenku.baidu.com/"] { vbn { top: var(); } ._image_14uts_1 { background-size: contain !important; padding-bottom: 25% !important; } } /* ========== ↓ 模块 相关搜索 */ html #wrapper #container .c-container[tpl="recommend_list"] { vbn { top: var(); } .pc-rg-upgrade_2X3zi .item_3WKCf { margin: 5px !important; color: var(--colorKeyWord); } } html #wrapper .new-pmd[tpl="app/rs"] { vbn { top: var(); } padding: var(--vbnSpacePadding) !important; margin: var(--vbnSpaceMargin) !important; #rs_new { margin: 0; width: 100%; } #rs_new table { margin: 20px auto; } #rs_new table tr { display: flex; gap: 40px; } #rs_new table tr .rs-link_2DE3Q { color: var(--vbnBaseColor);} } /* ========== ↓ Other */ html #wrapper #container .c-container { vbn { top: var(); } .recommend-none-border { display: flex; gap: 20px; } .c-gap-top-middle { margin-top: 0; } } /* ============================== ↓ Bottom */ html #wrapper .new-pmd[tpl="app/page"] { vbn { top: var(); } #page { width: 100% !important; background: transparent; } .page_2muyV a { color: var(--colorKeyWord); } #page a:hover .pc, #page .n:hover, .page_2muyV a:hover { filter: none; color: var(--colorKeyWord); background: transparent; box-shadow: var(--vbnSurfaceShadow) hsla(var(--vbnAccentHSL), .200); } .page_2muyV .page-inner_2jZi2 { padding: 0 !important; margin: 10px auto !important; width: max-content !important; } } html #wrapper .new-pmd[tpl="app/footer"] { vbn { top: var(); } .foot-container_2X1Nt { visibility: hidden;} } `); /* ========== vbnFocal */ (function VBN_Baidu_vbnFocal() { VBN_ADD_CLASS.apply({ delay: 260, target: [ ".c-container [data-module='title']", ".c-container [class^='title_']", ".c-container h3[class*='title'] a", ], subjoin: [ "vbnFocal", "LR", ], }); })(); }); // #endregion // // #region Google // VBN_GLOBAL_LOGIC.activate("Search", { // matchSubjoin: { // include: [ "*Google.com/*" ], // exclude: [] // } }, () => { // GM_addStyle( /* css */ ` // html .main { background: var(--vbnBase09HEX);} // html .sfbg, html .Lu57id { background: transparent;} // /* ========== ↓ 隐藏模块 */ // html .b_footer, /* 底部 - XXXXX */ // html #search .dURPMd > .ULSxyf /* 内容区 - 图片模块 */ { // display: none; // } // /* ============================== ↓ Head */ // html #searchform { margin: 10px 0;} // html .minidiv .logo { top: 2px;} // html .minidiv .RNNXgb { margin: 12px 0 0;} // /* ========== ↓ Head 粘性定位 */ // html .minidiv .sfbg { // height: 90px; // background: hsla(0, 0%, 100%, 0.4); // backdrop-filter: var(--vbnPanelFilter); // box-shadow: // inset 0px -1px 3px #FFFFFF50, // var(--vbnPanelShadow) hsla(var(--vbnBase04HSL), 0.05); // } // /* ========== ↓ NAV */ // html .ym1pid.qS9jbf.KLEmSd {border: none;} // /* ---------- ↓ NAV 修正 */ // @media (max-width: 1920px) {html #hdtb-sc {margin: 0 0 0 -14vw;}} // @media (min-width: 1920px) {html #hdtb-sc {margin: 0 0 0 -5vw;}} // /* ============================== ↓ Content */ // html #main #cnt {margin: 0 auto; width: var(--vbnSpaceWidthVW);} // html div[two-father] {width: var(--vbnSpaceWidthVW) !important;} // /* ---------- ↓ 内容区 修正 */ // @media (max-width: 1920px) {html #center_col { margin: 0px 0 0 -29vw;}} // @media (min-width: 1920px) {html #center_col { margin: 0px 0 0 -21vw;}} // /* ---------- ↓ 什么 NT 玩意 */ // @media (min-width: 1675px) { // html .YNk70c { grid-template-columns: 400px repeat(20,36px) minmax(0,1fr); } // } // /* ========== ↓ 通用模块 */ // html .MjjYud, // html #rso div[two-father] div[two-child] { // width: 100% !important; // padding: var(--vbnSpacePadding) !important; // margin: var(--vbnSpaceMargin) !important; // border: none !important; // border-radius: var(--vbnSurfaceRadius) !important; // background: #FFF !important; // box-shadow: var(--vbnSurfaceShadow) hsla(var(--vbnBase04HSL), 0.050) !important; // transition: all .526s var(--vbnTransitionSoft) !important; // } // html .MjjYud:hover, // html #rso div[two-father] div[two-child]:hover { // position: relative !important; // z-index: 9 !important; // border: none !important; // box-shadow: var(--vbnSurfaceShadow) hsla(var(--vbnAccentHSL), 0.260) !important; // transition: all .6s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important; // transform: var(--vbnSurfaceZoomIn) !important; // } // /* ---------- ↓ 通用模块 修正 */ // html div[two-father] div[two-child] > div {background: transparent;} // /* ========== ↓ 标题动画 */ // html #rcnt #res h3:visited, // html #rcnt #extrares h3:visited, // html div[two-child] h3:visited, // html div[two-father] div[two-child] a h3:visited { // display: inline-block; // width: max-content; // font-weight: bold; // } // html #rcnt #res h3:after, // html #rcnt #extrares h3:after, // html div[two-child] h3:after, // html div[two-father] div[two-child] a h3:after { // content: ""; // position: absolute; // left: 100%; // bottom: -2px; // width: 0; // border-bottom: 2px solid var(--vbnAccentHEX); // transition: transform 350ms, left 350ms; // } // html #rcnt #res h3:hover:after, // html #rcnt #extrares h3:hover:after, // html div[two-child] h3:hover:after, // html div[two-father] div[two-child] a h3:hover:after { // left: 0; // width: 100%; // transition: transform .26s; // } // /* ========== ↓ 模块 用户还搜索了 */ // html #bres > .ULSxyf { width: calc(var(--vbnSpaceWidthVW) - 40px );} // html .b2Rnsc:hover { color: var(--vbnAccentHEX); text-decoration: none;} // /* ---------- ↓ 通用模块 修正 */ // #rso div[two-father] div[two-child] { width: calc(var(--vbnSpaceWidthVW) - 40px) !important;} // html .IiOSLb .rsGxI.Ww4FFb, .Ww4FFb {background-color: transparent;} // html .eqAnXb {margin: -20px 0 0 0; width: var(--vbnSpaceWidthVW);} // /* ============================== ↓ Bottom */ // html .f6F9Be.TrMVnc {border-radius: var(--vbnSurfaceRadius) var(--vbnSurfaceRadius) 0 0;} // html .b2hzT {border-bottom: none;} // /* ---------- ↓ Bottom 修正 */ // @media (max-width: 1920px) { html .SLPe5b {margin: 10px 0 0 -18vw;} } // @media (min-width: 1920px) { html .SLPe5b {margin: 10px 0 0 -12vw;} } // /* ============================== ↓ 修正 */ // /* ---------- ↓ NAV */ // html .XtQzZd {padding: 0 0 5px 0;} // /* ---------- ↓ 通用模块 第一个 */ // html .tF2Cxc.asEBEc {margin: var(--vbnSpaceMargin);} // /* ---------- ↓ 模块 用户还搜索了 */ // html .ULSxyf > .MjjYud .oIk2Cb {padding: 15px 20px;} // `); // }); // // #endregion // // #region Bing // VBN_GLOBAL_LOGIC.activate("Search", { // matchSubjoin: { // include: [ "*bing.com/*" ], // exclude: [] // } }, () => { // GM_addStyle( /* css */ ` // html body, html #b_header { background: var(--vbnBase09HEX) !important;} // /* ========== ↓ 隐藏模块 */ // html .mfa_btn, /* Head 背景 */ // html #b_mcw > #b_topw.b_results_eml, /* 内容区 - 第一个 国际版 */ // html #b_results>.b_ans.b_top, /* 内容区 - 第一个 */ // html #b_results>.b_ans.b_mop, /* 内容区 - 影片模块 & 问了以下问题 */ // html #b_results>.b_ans.b_mop.b_vidAns /* 内容区 - 影片模块 */ { // display: none; // } // /* ============================== ↓ Head */ // /* ========== ↓ 用户中心 */ // html #b_header.as_rsform #id_h, #b_header #id_h { position: fixed !important; top: 2% !important; right: 1% !important;} // /* ========== ↓ 按钮 国内版 国际版 */ // html body #b_header #est_switch { margin: 25px auto; padding: 0;} // html body #est_switch #est_cn {margin: 0 20px;} // html #est_switch .est_selected, // #est_switch .est_unselected { // width: 50px; // height: 20px; // padding: 2px 2px 2px 15px; // font-size: 14px; // font-weight: bold; // line-height: 8px; // text-align: center; // color: white; // } // #est_switch .est_selected::after { // border: none !important; // background: #007AFF; // box-shadow: none !important; // } // /* ========== ↓ Head 粘性定位 */ // html body.b_pinhead #b_header { // height: calc(20px + var(--vbnSpace4X)) !important; // background: hsla(0, 0%, 100%, 0.4) !important; // backdrop-filter: var(--vbnPanelFilter) !important; // box-shadow: // inset 0px -1px 3px #FFFFFF50, // var(--vbnPanelShadow) hsla(var(--vbnBase04HSL), 0.05) !important; // } // /* ========== ↓ 搜索框 */ // html #b_header #sb_form { margin: 12px auto;} // html .b_searchboxForm { // box-shadow: // 0px 0px 00px 1px hsla(0, 0%, 0%, .02), // 2px 5px 10px 1px hsla(0, 0%, 0%, .06); // } // /* ============================== ↓ Content */ // #b_content #b_results { width: var(--vbnSpaceWidthVW) !important; max-width: 100% !important;} // /* ---------- ↓ 通用模块 */ // html #b_content #b_results > li:not(#mfa_root) { // padding: var(--vbnSpacePadding) !important; // margin: 8px 0 !important; // border: none !important; // border-radius: var(--vbnSurfaceRadius) !important; // box-shadow: var(--vbnSurfaceShadow) hsla(var(--vbnBase04HSL), 0.050) !important; // transition: all .526s var(--vbnTransitionSoft) !important; // } // /* ========== ↓ 通用模块 Hover */ // html #b_content #b_results > li:not(#mfa_root):hover { // box-shadow: var(--vbnSurfaceShadow) hsla(var(--vbnAccentHSL), 0.260) !important; // transform: var(--vbnSurfaceZoomIn) !important; // } // /* ========== ↓ 标题动画 */ // html body #b_content #b_results a:after, // #b_content #b_results h2 a:after { // bottom: -2px; // border-bottom: 2px solid var(--vbnAccentHEX); // transition: transform .26s, left .26s; // } // /* ============================== ↓ Bottom */ // /* ============================== ↓ 修正 */ // /* ========== ↓ Head 背景 */ // html body.b_respl.bing.b_sbText.b_pinhead header#b_header {background-color: transparent !important;} // #b_results .b_ans #brsv3 { width: calc(var(--vbnSpaceWidthVW) - 100px) !important; margin: 10px auto !important;} // #b_results .b_ans #brsv3 .b_vList { padding: 0 !important;} // #b_results #brsv3 .b_vList li { width: 300px !important; padding: 0 !important; margin: 5px !important;} // #b_header .b_topbar, #b_header .b_scopebar { margin: 20px 0 0px 0 !important;} // #b_header .b_searchbox { width: 861px !important;} // `); // }); // // #endregion // #region ComfyUI VBN_GLOBAL_LOGIC.activate("ComfyUI", { matchSubjoin: { include: [ ...VBN_SITE_GROUP.AIGC ], exclude: [] } }, () => { GM_addStyle( /* css */ ` :root { --themeColor: 220, 90%, 60%; --navHeight: 50px; --rgHeight: 10px; } #vue-app { --bar-shadow: 0 0 1.5rem #00000060; } html .comfyui-menu[data-v-1545ebd4] { height: var(--navHeight); } html .comfyui-body-left[data-v-0e9641c8] { z-index: 999; } html .side-tool-bar-container[data-v-44002598], html .comfyui-menu[data-v-1545ebd4] { background: var(--vbnGlassShadow); backdrop-filter: var(--vbnSurfaceFilter); } /* ========== ↓ 右键菜单 */ html .litegraph.litecontextmenu { padding: 5px; width: max-content; min-width: 150px; max-width: 260px; border-radius: var(--vbnUIRadius); box-shadow: var(--vbnUIShadow) #00000060 !important; } /* ========== ↓ 菜单选项 */ html .litegraph.litecontextmenu .litemenu-entry:not(.separator) { display: flex; align-items: center; padding: 2px; margin: 4px 0px; height: 25px; } html .litegraph.litecontextmenu .litemenu-entry.submenu:not(.separator), html .litegraph.litecontextmenu.dark .litemenu-entry.submenu { padding: 0 8px; line-height: 1.92; border-radius: var(--vbnUIRadius); } html .litegraph .litemenu-entry.separator { border-bottom: .1em dashed #00000040; } /* ========== ↓ 箭头图标 */ html .litemenu-entry.has_submenu::after { content: ""; position: absolute; top: 50%; right: 5px; transform: translateY(-50%); height: 1.2em; width: .2rem; background: hsla(var(--themeColor), 1); box-shadow: 2px 0 6px 0px hsla(var(--themeColor), .6); border-radius: 1em; } html .litegraph .litemenu-entry.has_submenu { border-right: none;} /* ========== ↓ 取值输入框 */ html .litegraph .graphdialog { padding: 7px 10px 7px 15px; border: var(--vbnUIBorder) var(--border-color); border-radius: var(--vbnPanelRadius); } html .graphdialog { box-shadow: var(--bar-shadow); } html .graphdialog input, html .graphdialog textarea, html .graphdialog select { border-radius: var(--vbnUIRadius); } `); (function VBN_ComfyUI_manager() { if (!VBN_GLOBAL_LOGIC.activate("manager")) return; GM_addStyle( /* css */ ` html #cm-manager-dialog { --vbnColumnH: 40px; --vbnRadiusS: var(--vbnUIRadius); --vbnRadiusM: var(--vbnPanelRadius); --vbnRadiusL: var(--vbnSurfaceRadius); --vbnFont: var(--vbnCodeFont); --vbnMappingText: var(--p-text-muted-color, #FFFFFFCC); --vbnMappingBase: var(--p-dialog-background, #00000040); --vbnMappingButtonBase: var(--p-listbox-option-focus-background, #00000050); --vbnMappingInputBase: var(--p-inputtext-background, #00000050); --vbnMappingBorder: 1px solid var(--p-select-border-color, #FFFFFF20); --vbnMappingBorderColor: var(--p-dialog-border-color, #FFFFFF20); width: 50vw; height: 50vh; } html .comfy-modal { padding: 40px 20px; padding-bottom: 20px; border: 2px solid var(--vbnMappingBorderColor); background-color: var(--vbnMappingBase); box-shadow: none; border-radius: var(--vbnRadiusL); font-family: var(--vbnFont); } html .comfy-modal-content { display: flex; flex-direction: column; align-items: center; } html .cm-title, html #cm-close-button { width: calc(100% - 40px); height: calc(var(--vbnColumnH) * 2); background-color: var(--vbnMappingButtonBase); border-radius: var(--vbnRadiusM); } html body #cm-close-button { position: sticky; bottom: 0; overflow: visible; flex-shrink: 0; height: calc(var(--vbnColumnH) + 20px); box-shadow: 0 10px 25px 0 #00000020; border-radius: var(--vbnRadiusM); } html .cm-title > font { color: var(--vbnMappingText); } html .cm-menu-container { display: flex; justify-content: space-around; gap: 20px; width: calc(100% - 40px); padding: 10px 0; } html .cm-menu-column { display: flex; flex-direction: column; align-items: center; justify-content: space-between; width: auto; } html .cm-menu-column > br:first-of-type { display: none; } html .comfy-modal input, html .comfy-modal select { height: var(--vbnColumnH); padding-left: 8px; border: var(--vbnMappingBorder); font-family: var(--vbnFont); font-size: .9em; color: var(--vbnMappingText); background-color: var(--vbnMappingInputBase); border-radius: var(--vbnRadiusS); } html .comfy-btn, html .comfy-menu > button, html .comfy-menu-btns button, html .comfy-menu .comfy-list button, html .comfy-modal button { margin-top: 4px; height: var(--vbnColumnH); border: var(--vbnMappingBorder); color: var(--vbnMappingText); font-family: var(--vbnFont); background-color: var(--vbnMappingButtonBase); border-radius: var(--vbnRadiusS); } html .comfy-btn:hover:not(:disabled), html .comfy-menu > button:hover, html .comfy-menu-btns button:hover, html .comfy-menu .comfy-list button:hover, html .comfy-modal button:hover, html .comfy-menu-actions button:hover { border: var(--vbnMappingBorder); background-color: var(--vbnMappingButtonBase); will-change: auto; } html #cm-manual-button, html #cm-nodeinfo-button { height: var(--vbnColumnH); } html #workflowgallery-button {height: calc(var(--vbnColumnH) + 20px); } html .cm-notice-board { border: var(--vbnMappingBorder); color: #626262; font-size: 14px; border-radius: var(--vbnRadiusM); } html .cm-experimental { border: var(--vbnMappingBorder); } html .cm-experimental-legend { line-height: 1.7;} html .cm-experimental-legend, html .cm-button-red { background-color: #B52121 !important;} html .comfy-modal p { color: var(--vbnMappingText) !important; } html .comfy-modal p, html .cm-experimental-button, html .cm-button, html #cm-nodeinfo-button { font-size: .9em !important; } `); })(); (function VBN_ComfyUI_crystools() { if (!VBN_GLOBAL_LOGIC.activate("crystools")) return; GM_addStyle( /* css */ ` /* html .comfyui-menu-right > .flex > .comfyui-button-group:nth-child(2) { order: 1; flex-shrink: 0; } html .comfyui-menu-right > .flex > .comfyui-button-group { order: 2; flex-shrink: 0; } html .comfyui-menu #crystools-monitors-root { vbn { top: var(); } --vbnRadiusS: var(--vbnBaseRadius); order: 0; margin: 0 auto; flex: 0 1 auto; */ html .comfyui-menu #crystools-monitors-root { vbn { top: var(); } --vbnFontSize: 8px; --vbnRadiusS: 3px; position: fixed; top: calc( var(--navHeight) + var(--rgHeight) + 5px ); left: 50%; transform: translateX(-50%); width: max-content; .crystools-monitor { /* display: flex !important; */ align-content: center; justify-content: center; border-radius: var(--vbnRadiusS); background: transparent; } .crystools-monitor[class*="Crystools.ShowRam"] { order: 1 !important; .crystools-slider { background: #ef5f19 !important; } } .crystools-monitor[class*="Crystools.ShowCpu"] { order: 2 !important; .crystools-slider { background: #b5e70d !important; } /* #ff3cac */ } .crystools-monitor[class*="Crystools.ShowGpuUsageZero"] { order: 3 !important; .crystools-slider { background: #45d911 !important; } } .crystools-monitor[class*="Crystools.ShowGpuVramZero"] { order: 4 !important; .crystools-slider { background: #00F29C !important; } } .crystools-monitor[class*="Crystools.ShowGpuTemperatureZero"] { order: 5 !important; .crystools-slider { background: #8576f7 !important; } } .crystools-monitor[class*="Crystools.ShowHdd"] { order: 6 !important; .crystools-slider { background: #475295 !important; } } .crystools-slider { border-radius: var(--vbnRadiusS); } /* .crystools-monitor .crystools-content { display: flex; width: 8vw; max-width: 260px; height: 12px; } */ .crystools-monitor .crystools-content { display: flex; width: calc( 100vw / 5 - 126px); height: var(--vbnFontSize); background: #0d0f1499 !important; } .crystools-monitor .crystools-text { bottom: auto; margin-left: 0; color: #FFF; font-size: var(--vbnFontSize); font-weight: 700; } .crystools-label { top: 0; right: 10px; font-size: var(--vbnFontSize); font-weight: 700; } } `); })(); (function VBN_ComfyUI_rgthree() { if (!VBN_GLOBAL_LOGIC.activate("rgthree")) return; GM_addStyle( /* css */ ` html rgthree-progress-bar { height: var(--rgHeight) !important; } html rgthree-progress-bar { --rgthree-progress-bg-color: #171717cc; --rgthree-progress-nodes-bg-color: #524AF7cc; --rgthree-progress-steps-bg-color: #1dffb7cc; --rgthree-progress-error-bg-color: #e3520ccc; } `); })(); }); // #endregion // #region DeepSeek VBN_GLOBAL_LOGIC.activate("Chat", { matchSubjoin: { include: [ "*deepseek.com/*" ], exclude: [] } }, () => { if (!VBN_GLOBAL_LOGIC.activate("DeepSeek")) return; GM_addStyle( /* css */ ` :root { --vbnCustomWidth: calc(var(--vbnSpaceWidth02) + 24vw); --message-list-max-width: var(--vbnSpaceWidth02) !important; transition: all .526s var(--vbnTransitionSoft); } html ._9a2f8e4 { max-width: var(--vbnSpaceWidth02); } @media (max-width: 1600px){ :root { --message-list-max-width: var(--vbnCustomWidth) !important;} html ._9a2f8e4 { max-width: var(--vbnCustomWidth); } } html ._62b4800 {background: none;} `); }); // #endregion // #region ChatGPT VBN_GLOBAL_LOGIC.activate("Chat", { matchSubjoin: { include: [ "*chatgpt.com/*" ], exclude: [] } }, () => { if (!VBN_GLOBAL_LOGIC.activate("ChatGPT")) return; GM_addStyle( /* css */ ` * { --thread-content-max-width: var(--vbnSpaceWidth02) !important; } @media (max-width: 1600px){ * { --thread-content-max-width: calc(var(--vbnSpaceWidth02) + 24vw) !important;} } `); }); // #endregion // #region YUQUE VBN_GLOBAL_LOGIC.activate("YUQUE", { matchSubjoin: { include: [ "*yuque.com/*" ], exclude: [] } }, () => { GM_addStyle( /* css */ ` /* ========== ↓ 右侧边栏 文档导航 */ html .sidePanel-module_panel_Vr-DC, html .ne-toc-sidebar .ne-toc-view { background-color: transparent; } /* ========== ↓ 内容宽度 */ #main, #commonEditPage { --vbnWidth: 260px; /* 实际内容宽度为 原 750px + 设置的宽度 */ --vbnWidthOffset: -60px; /* 因原有左右侧边栏宽度不一 可设置向右偏移 调整至视觉居中 */ } @media (max-width: 2460px) { #main, #commonEditPage { --vbnWidth: 260px; --vbnWidthOffset: 0px; } } @media (max-width: 1920px) { #main, #commonEditPage { --vbnWidth: 100px; --vbnWidthOffset: 0px; } } @media (max-width: 1202px) { #main, #commonEditPage { --vbnWidth: 000px; --vbnWidthOffset: 0px; } } html .ne-viewer-body > *, html .DocReader-module_header_xAOtU { transition: all .92s var(--vbnTransitionSoft) } /* ========== ↓ 阅读模式 */ /* ========== ↓ 标题 */ html .DocReader-module_comment_eDglS, html .DocReader-module_header_xAOtU, html .DocReader-module_info_yXA4e { max-width: calc(850px + var(--vbnWidth) / 2 + var(--vbnWidthOffset)); } /* ========== ↓ 内容 */ html .ne-doc-major-viewer .ne-viewer-layout-mode-fixed .ne-viewer-body > * { max-width: calc(750px + var(--vbnWidth)); } html .article-content .ne-doc-major-viewer .ne-viewer-layout-mode-adapt .ne-viewer-body > *, html .article-content .ne-doc-major-viewer .ne-viewer-layout-mode-fixed .ne-viewer-body > * { margin-right: calc(var(--viewer-center-align-right) - var(--vbnWidth) / 2 + var(--vbnWidthOffset)) !important; } /* ========== ↓ 代码块 */ html .article-content .ne-doc-major-viewer .ne-viewer-layout-mode-fixed .ne-viewer-body > ne-alert-hole, html .article-content .ne-doc-major-viewer .ne-viewer-layout-mode-fixed .ne-viewer-body > ne-container-hole, html .article-content .ne-doc-major-viewer .ne-viewer-layout-mode-fixed .ne-viewer-body > ne-hole { width: calc(100% - var(--viewer-center-align-value) + var(--vbnWidth)); } /* ========== ↓ 编辑模式 */ /* ========== ↓ 标题 */ html .ne-doc-major-editor .ne-editor.layout-read-write:not(.ne-layout-mode-adapt) .ne-editor-extra-box { max-width: calc(890px + var(--vbnWidth) / 2 + var(--vbnWidthOffset)); } /* ========== ↓ 内容 */ html .ne-doc-major-editor .ne-editor.layout-read-write:not(.ne-layout-mode-adapt) .ne-engine>:not(.ne-full-width) { margin-right: calc(var(--center-editor-margin-right) - var(--vbnWidth) / 2 + var(--vbnWidthOffset)) !important; max-width: calc(750px + var(--vbnWidth)); } /* ========== ↓ 表格 */ html .ne-doc-major-editor .ne-layout-mode-fixed.ne-normal-toc:not(.ne-ui-sidebar-visible).ne-viewport-size-toc-XXL .ne-engine ne-table-hole { max-width: calc(752px + var(--vbnWidth)); } /* ========== ↓ Font */ /* ---------- ↓ 代码 */ html .ͼg .cm-scroller { font-family: var(--vbnCodeFont); font-size: var(--vbnCodeSize); } /* ---------- ↓ 行内代码 */ html ne-code-content { font-family: var(--vbnCodeFont); } html ne-code ne-text { font-size: var(--vbnCodeSize); } /* ========== ↓ Picture */ html .ne-image-wrap .ne-image-box { overflow: visible; background: transparent; } html .ne-image-wrap, html .ne-viewer ne-card[data-card-type=inline][data-card-name=image], /* 预览模式 */ html .ne-editor ne-card[data-card-type=inline][data-card-name=image] /* 编辑模式 */ { display: flex; justify-content: center; align-items: center; } html .ne-paragraph-spacing-relax.ne-typography-classic ne-card[data-card-name=image] img { border-radius: var(--vbnPanelRadius); filter: drop-shadow(0 20px 30px hsla(var(--vbnBase04HSL), 0.050)); transition: all .526s var(--vbnTransitionSoft); } html .ne-paragraph-spacing-relax.ne-typography-classic ne-card[data-card-name=image] img:hover { filter: drop-shadow(0 20px 30px hsla(var(--vbnAccentHSL), 0.260)); transform: var(--vbnSurfaceZoomIn); } /* ---------- ↓ 默认样式 */ /* ---------- ↓ Hover */ html .ne-editor ne-card[data-card-type=inline][data-card-name=image].ne-card-hovered .ne-image-wrap, html .ne-editor ne-card[data-card-type=inline][data-card-name=image].ne-focused .ne-image-wrap { border-color: transparent; } /* ---------- ↓ 选中图片的默认边框 */ html .ne-active .ne-ui-image-resizer-box { display: none; } /* ========== ↓ Table 「下方功能添加 vbnTable样式 此处仅作修复显示」 */ html ne-table-wrap.ne-ui-table-right-shadow:after { display: none; } /* ---------- ↓ table 外层容器 */ html .ne-table-hole > ne-table-wrap > ne-table-inner-wrap { overflow: visible !important; } /* ---------- ↓ 标题 */ html table[ne-table-row-head=true]:not([ne-table-head-text-gradient=true]) tr:first-child td .ne-td-content>.ne-b-filler, html table[ne-table-row-head=true]:not([ne-table-head-text-gradient=true]) tr:first-child td ne-text { font-weight: 700 !important; color: #4D4D4D !important; } /* ---------- ↓ 标题 背景及边框 */ html table[ne-table-row-head=true]:not([ne-table-head-text-gradient=true]) tr:first-child td { background-color: #FAFAFA !important; border-color: #00000000 !important; } html table[ne-table-row-head=true]:not([ne-table-head-text-gradient=true]) tr:first-child td:not(:first-child, :last-child) { border-left: 1px solid #00000010 !important; border-right: 1px solid #00000010 !important; } /* ---------- ↓ Sticky */ html ne-table-hole[class="ne-table-hole"] > ne-table-wrap > div[style*="top: 0px"] { top: -27px !important; } html tr.ne-tr.ne-tr-sticky { top: calc(79px - 27px) !important; border-radius: 0 0 var(--vbnSurfaceRadius) var(--vbnSurfaceRadius); } /* ========== ↓ 标题 */ html #article-title, html ant-input lake-title, html .ne-viewer ne-h1 ne-text, html .ne-engine ne-h1 ne-text { color: var(--vbnMarkdownH1);} html .ne-viewer ne-h2 ne-text, html .ne-engine ne-h2 ne-text { color: var(--vbnMarkdownH2);} html .ne-viewer ne-h3 ne-text, html .ne-engine ne-h3 ne-text { color: var(--vbnMarkdownH3);} html .ne-viewer ne-h4 ne-text, html .ne-engine ne-h4 ne-text { color: var(--vbnMarkdownH4);} html .ne-viewer ne-h5 ne-text, html .ne-engine ne-h5 ne-text { color: var(--vbnMarkdownH5);} html .ne-viewer ne-h6 ne-text, html .ne-engine ne-h6 ne-text { color: var(--vbnMarkdownH6);} html .lake-title-editor .lake-title { background-color: transparent; } /* ========== ↓ 工具栏 */ /* ---------- ↓ 选中图片 */ html .ne-card-toolbar { magic: 10px 0 0; border-radius: var(--vbnPanelRadius); } `); (function VBN_YUQUE_vbnTable() { if (!VBN_GLOBAL_LOGIC.activate("vbnTable")) return; VBN_ADD_CLASS.apply({ delay: 260, target: [ "#main.BookReader-module_content_BGKYX table", ], subjoin: [ "vbnTable", ], }); })(); (function VBN_YUQUE_vbnGrid() { if (!VBN_GLOBAL_LOGIC.activate("vbnGrid")) return; VBN_ADD_CLASS.apply({ delay: 260, target: [ ".BookReader-module_wrapper_s6Jdt", ".ne-layout-mode-adapt .ne-editor-wrap-box", ".ne-layout-mode-fixed .ne-editor-wrap-box", ], subjoin: [ "vbnGridSolid", ], }); })(); }); // #endregion // #region TickTick VBN_GLOBAL_LOGIC.activate("TickTick", { matchSubjoin: { include: [ "*dida365.com/*", "*ticktick.com/*", ], exclude: [ ] } }, () => { GM_addStyle( /* css */ ` /* ---------- ↓ 默认阴影 */ html .shadow-default, html .shadow-md { box-shadow: var(--vbnUIShadow) hsla(var(--vbnBase04HSL), .12); } /* ---------- ↓ 左下角 小日历 */ html .bg-sidebar-bg-color { background: transparent; } /* ---------- ↓ 看板 各列 */ html #column-list-inner > article { width: var(--vbnSpace4Y) !important; } `); }); // #endregion // #region Youtube VBN_GLOBAL_LOGIC.activate("Youtube", { matchSubjoin: { include: [ "*youtube.com/*" ], exclude: [ ] } }, () => { GM_addStyle( /* css */ ` @media (min-width: 1500px) { /* ---------- ↓ Video */ html ytd-rich-grid-renderer[is-default-grid] ytd-rich-item-renderer[rendered-from-rich-grid] { --ytd-rich-grid-items-per-row: 6 !important; } /* ---------- ↓ Shots */ html ytd-rich-shelf-renderer[is-shorts] ytd-rich-item-renderer[items-per-row][is-slim-media] { --ytd-rich-grid-items-per-row: 8 !important; } /* ---------- ↓ News */ html ytd-rich-shelf-renderer[elements-per-row] ytd-rich-item-renderer[is-shelf-item] { --ytd-rich-grid-items-per-row: 6 !important; } } `); }); // #endregion // #region Bilibili VBN_GLOBAL_LOGIC.activate("Bilibili", { matchSubjoin: { include: [ "*Bilibili.com/*" ], exclude: [ ] } }, () => { GM_addStyle( /* css */ ` /* ---------- ↓ 默认小按钮 */ html.vbn .video-pod .video-pod__header .header-bottom .right .subscribe-btn { border-radius: var(--vbnBaseRadius); } /* ---------- ↓ 播放列表高度 */ html.vbn .video-container-v1 .video-pod .video-pod__body { max-height: 43vh; } `); }); // #endregion // #region Other /* ========== Greasyfork */ if ( VBN_MATCH_RULE.match({ include: [ "*greasyfork.org/*", ], exclude: [ ] }) ) { GM_addStyle( /* css */ ` /* html .install-help-link { font-size: 1.08em; } html .install-link[data-ping-url] { font-size: 1.08em; } */ `); /* ========== vbnLink */ (function VBN_Greasyfork_vbnLink() { VBN_ADD_CLASS.apply({ delay: 260, target: [ "body a[href]:not(#script-links [href], #install-area [href], #script-list-option-groups [href], #main-header [href]):not(:has(img))", "#main-header a[href]:not(#site-name [href])", ".browser-list-selector:not(.browser-list-selector-active)", ], subjoin: [ "vbnLink", ], }); })(); } /* ========== Dillinger */ if ( VBN_MATCH_RULE.match({ include: [ "*dillinger.io/*" ], exclude: [ ] }) ) { GM_addStyle( /* css */ ` .vbn { & html, body { font-family: var(--vbnBaseFont); } } `); } /* ========== Bigjpg */ if ( VBN_MATCH_RULE.match({ include: [ "*bigjpg.com/*" ], exclude: [ ] }) ) { GM_addStyle( /* css */ ` @media (min-width: 768px) { html .container { max-width: none; } html .jumbotron { padding-top: 80px; padding-bottom: 80px; } } `); } /* ========== 115 */ if ( VBN_MATCH_RULE.match({ include: [ "*://115.com/*" ], exclude: [ ] }) ) { GM_addStyle( /* css */ ` /* ========== 云下载 弹窗 */ html .offline-box { position: fixed !important; top: 50% !important; left: 50% !important; transform: translate(-50%, -50%); width: 43vw !important; height: 50vh; border-radius: var(--vbnSurfaceRadius); transition: all .43s var(--vbnTransitionSoft); } /* ---------- 云下载 输入框 */ html .dialog-input.input-offline textarea { height: 32vh; border-radius: var(--vbnSurfaceRadius); } @media (max-width: 1200px) { html .offline-box { width: 59vw !important; height: 92vh;} html .dialog-input.input-offline textarea { height: 70vh;} } `); } /* ========== XXXXX */ if ( VBN_MATCH_RULE.match({ include: [ "*mp.weixin.qq.com/*" ], exclude: [ ] }) ) { GM_addStyle( /* css */ ` html .pages_skin_pc.wx_wap_desktop_fontsize_2 .rich_media_area_primary_inner { max-width: var(--vbnSpaceWidth02); } `); } /* ========== XXXXX */ if ( VBN_MATCH_RULE.match({ include: [ "*douyin.com/*" ], exclude: [ ] }) ) { GM_addStyle( /* css */ ` html.vbn, html body, html body > div:first-child { height: auto; } `); } /* ========== XXXXX */ if ( VBN_MATCH_RULE.match({ include: [ "*periodic-table-tags-mu-six.vercel.app/*" ], exclude: [ ] }) ) { GM_addStyle( /* css */ ` html .title h1 { display: none; } html .star { margin: 100px 0; } html .intro { margin: 24vh 0 14vh 20vw; } html .elements[data-v-ff33deea] { border-radius: var(--vbnUIRadius); transition: all .526s var(--vbnTransitionSoft); width: 5rem; font-family: var(--vbnCodeFont); font-size: var(--vbnCodeSize); } html .elements:hover { z-index: var(--vbnPriority00); box-shadow: var(--vbnPanelShadow) hsla(var(--vbnBase02HSL), 0.8), 0 0 0 2px #00000080 !important; transform: var(--vbnUIZoomIn); } html .elements .info[data-v-ff33deea] { z-index: var(--vbnPriority00); border-radius: var(--vbnPanelRadius); } `); } // #endregion // $ ================================================== ↓ Micro // #region NetDisk.Check VBN_GLOBAL_LOGIC.activate("NetDisk_Check", () => { GM_addStyle( /* css */ ` /* ========== 连接正确 */ html .one-pan-tip { text-decoration: none;} html .one-pan-tip::before { height: .95em; width: .95em; margin: 0 .15em .15em; background-image: var(--vbnICON-URL-Correct); } /* ========== 连接错误 */ html .one-pan-tip-error { text-decoration: none;} html .one-pan-tip-error::before { background-image: var(--vbnICON-URL-Error); } /* ========== 带提取码 */ html .one-pan-tip-lock::before { background-image: var(--vbnICON-URL-Safety); } /* ========== 夸克 */ html .one-pan-tip-partial::before { background-image: var(--vbnICON-URL-Info); } `); }); // #endregion })();