黑暗模式 / 清爽模式:斗鱼 ________ <斗鱼>:抽奖、抄袭、循环弹幕,关键词回复 ____ 批量取关____ 暂停播放、静音、关闭滚动弹幕、默认画质、宽屏模式、签到、自动维持亲密度
// ==UserScript== // @name H2P: 斗鱼小工具 // @namespace http://tampermonkey.net/ // @version 2.2.20 // @icon http://www.douyutv.com/favicon.ico // @description 黑暗模式 / 清爽模式:斗鱼 ________ <斗鱼>:抽奖、抄袭、循环弹幕,关键词回复 ____ 批量取关____ 暂停播放、静音、关闭滚动弹幕、默认画质、宽屏模式、签到、自动维持亲密度 // @author H2P // @compatible chrome // @require https://greasyfork.org/scripts/411278-h2p-utils/code/H2P:%20utils.js?version=847435 // @require https://greasyfork.org/scripts/411280-h2p-notify-util/code/H2P:%20notify%20util.js?version=847422 // @match *://*.douyu.com/0* // @match *://*.douyu.com/1* // @match *://*.douyu.com/2* // @match *://*.douyu.com/3* // @match *://*.douyu.com/4* // @match *://*.douyu.com/5* // @match *://*.douyu.com/6* // @match *://*.douyu.com/7* // @match *://*.douyu.com/8* // @match *://*.douyu.com/9* // @match *://*.douyu.com/topic/* // @match *://www.douyu.com/directory/myFollow // @match *://*.bilibili.com/ // @match *://*.bilibili.com/?* // @match *://*.bilibili.com/video/* // @match *://*.t.bilibili.com/* // @match *://*.bilibili.com/ranking?* // @match *://live.bilibili.com/* // @match *://*.huya.com/* // @note 2021.02.02-V2.2.20 弹幕栏不显示直播时长,不获取现在人数 // ==/UserScript== (($util, $notifyMgr) => { 'use strict'; /** * 根据 xpath 查询元素 * @param {String} xpath * @param {Boolean} queryOneElement */ const $H2P = (xpath = 'body', queryOneElement = true) => queryOneElement ? document.querySelector(xpath) : Array.from(document.querySelectorAll(xpath)); const isDouyu = location.href.includes('douyu.com'); const isDouyuTopic = location.href.startsWith('https://www.douyu.com/topic/'); const isDouyuFollow = location.href.startsWith('https://www.douyu.com/directory/myFollow'); const isBilibili = location.href.includes('bilibili.com'); const isBilibiliHome = location.href === 'https://www.bilibili.com' || location.href === 'https://www.bilibili.com/' || location.href.startsWith('https://www.bilibili.com/?'); const isBilibiliVideo = location.href.startsWith('https://www.bilibili.com/video/'); const isBilibiliAct = location.href.startsWith('https://t.bilibili.com/'); const isBilibiliRank = location.href.startsWith('https://www.bilibili.com/ranking?'); const isBilibiliLive = location.href.startsWith('https://live.bilibili.com/'); const isHuya = location.href.includes('huya.com'); const isHuyaFollow = location.href.includes('huya.com/myfollow'); // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // // 全局样式 // // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // let eleStyle = document.createElement('style'); eleStyle.innerHTML += ` .h2p-flex-main-start { height : 22px; margin : 0 0 15px 0; display : flex; flex-flow : row wrap; justify-content : flex-start; align-items : center; } .h2p-flex-main-center { height : 22px; margin : 0 0 15px 0; display : flex; flex-flow : row wrap; justify-content : center; align-items : center; } .h2p-flex-main-end { height : 22px; margin : 0 0 15px 0; display : flex; flex-flow : row wrap; justify-content : flex-end; align-items : center; } .h2p-item-100p { width: 100%; } .h2p-item-75p { width: 75%; } .h2p-item-50p { width: 50%; } .h2p-item-33p { width: 33.33%; } .h2p-item-25p { width: 25%; } `; document.head.appendChild(eleStyle); // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // // 黑暗模式 // // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // const LSClear = 'h2p-DY-config-clear'; let config_clear = $util.LS.init(LSClear, { isClearNav : false, isClearInfo : false, isClearAside: false, isClearGift : false, isClearBar : false, isClearPlay : false, blackMode : false, clearMode : false, BMGrey : true, BMBlack : false, BMDIY : false, BMBGDeep : '#2d2e37', BMBGLight : '#363636', BMFontDeep : '#a7a7a7', BMFontLight : '#888888', }); function blackMode () { console.log(`${config_clear.blackMode ? '启动' : '关闭'} : 黑暗模式`); let black = { bg: { deep : config_clear.BMDIY ? config_clear.BMBGDeep : (config_clear.BMBlack ? '#000000' : '#2d2e37'), light : config_clear.BMDIY ? config_clear.BMBGLight : (config_clear.BMBlack ? '#121212' : '#282930'), }, font: { deep : config_clear.BMDIY ? config_clear.BMFontDeep : (config_clear.BMBlack ? '#999999' : '#a7a7a7'), light : config_clear.BMDIY ? config_clear.BMFontLight : (config_clear.BMBlack ? '#676767' : '#777777'), } }; if (config_clear.blackMode) { if ($H2P('style#h2p-style-blackMode')) { $H2P('style#h2p-style-blackMode').remove(); } let eleStyle = document.createElement('style'); eleStyle.id = 'h2p-style-blackMode'; eleStyle.innerHTML += ` .h2p-dropdown-menu { background-color: ${black.bg.light}; color: ${black.font.deep}; border-color: ${black.bg.light}; box-shadow: 0 2px 6px ${black.bg.light}; } `; if (isDouyu) { // 隐藏背景图片 eleStyle.innerHTML += ` .video-header { display: none!important; } #bc6 { background: none!important; } `; eleStyle.innerHTML += ` body, div.Header-wrap, main.layout-Main, div.FishpondTreasure-v4-area { background-color: ${black.bg.deep}!important; } `; // header 左边 eleStyle.innerHTML += ` div.Header-wrap { border-bottom-color: ${black.bg.deep}; } #js-header div.HeaderNav a.EntryNav-desc, #js-header ul.Header-menu > li a, svg.Header-icon use, .DropMenuList-name { color: ${black.font.deep}; } .public-DropMenu-drop { background-color: ${black.bg.deep}; box-shadow: 0 2px 6px ${black.bg.light}; } a.Category-item { background-color: ${black.bg.light}; } `; // 搜索框 eleStyle.innerHTML += ` #js-header div.Header-right div.Search { background-color: ${black.bg.light}; border: 1px solid ${black.bg.light}; } #js-header div.Header-right div.Search svg.Header-icon, .Search-hot-title { color: ${black.font.deep}; } .Search-hotList a { color: ${black.font.light}; } .Search-hotList li:hover { background-color: ${black.bg.light}; } .Search-direct { background-color: ${black.bg.light}; border-color: ${black.bg.light}; } `; // header 右边 eleStyle.innerHTML += ` #js-header div.Header-right a.public-DropMenu-link, .User-nickname a, .DropPaneList.HistoryList .DropPaneList-title, .DropPaneList span.DropPaneList-title, .YubaMessage-link { color: ${black.font.deep}; } .DropPaneList > a:hover, .YubaMessage-link:hover { background-color: ${black.bg.light}; } `; // 侧边栏 eleStyle.innerHTML += ` .Aside-main--shrink, .Aside-toggle { background-color: ${black.bg.deep}; } .Aside-toggle>i:before { border-right-color: ${black.bg.deep}; } .Aside-shrink-item:last-child { border-top-color: ${black.bg.deep}; } `; // 主播信息 eleStyle.innerHTML += ` div#js-player-title { background-color: ${black.bg.deep}; border-color: ${black.bg.light}; border-bottom-color: ${black.bg.deep}; } div.Title-roomInfo div.Title-row h3.Title-header, div.Title-roomInfo div.Title-row h2.Title-anchorNameH2, div.Title-roomInfo div.Title-row a.Title-anchorHot div.Title-anchorText, div.Title-roomInfo div.Title-anchorLocation span, div.Title-roomInfo div.Title-sharkWeight span, div.Title-roomInfo div.Title-row div.Title-blockInline span { color: ${black.font.deep}; } `; // 礼物栏 eleStyle.innerHTML += ` div#js-player-toolbar, .GiftInfoPanel-cont { background-color: ${black.bg.deep}; border-color: ${black.bg.light}; } div#js-player-toolbar div.PlayerToolbar-ywInfo span, div#js-player-toolbar div.PlayerToolbar-ycInfo span, .GiftExpandPanel-descName, .GiftInfoPanel-name { color: ${black.font.deep}; } div#js-player-toolbar div.PlayerToolbar-Content:nth-child(2) div.PlayerToolbar-ContentCell:nth-child(1) { visibility: hidden; } div.GiftExpandPanel { background-color: ${black.bg.deep}; border-color: ${black.bg.deep}; } span.BatchGiveForm-num { background-color: ${black.bg.light}; border-color: ${black.bg.light}; color: ${black.font.deep}; } div.ShieldTool-list { background-color: ${black.bg.light}; border-color: ${black.bg.light}; } `; // 背包 eleStyle.innerHTML += ` .Backpack { background-color: ${black.bg.deep}; border-color: ${black.bg.deep}; } .Backpack-name { color: ${black.font.deep}; } .Backpack-propPanel, .Backpack-prop.is-blank { background-color: ${black.bg.deep}; } .Backpack-arrowInner { border-color: ${black.bg.deep}; } `; // 弹幕栏 eleStyle.innerHTML += ` div#js-player-asideMain { background-color: ${black.bg.deep}; border-color: ${black.bg.light}; } `; // 弹幕栏 - 公告 eleStyle.innerHTML += ` div.layout-Player-announce { background-color: ${black.bg.deep}; border-bottom-color: ${black.bg.light}; } div.layout-Player-rank ul.ChatTabContainer-titleWraper--tabTitle li { background-color: ${black.bg.deep}; border-color: ${black.bg.deep}; } `; // 弹幕栏 - 周榜 eleStyle.innerHTML += `div.ChatRankWeek-headerContent { background-color: ${black.bg.deep}; }`; // 弹幕栏 - 贵宾 eleStyle.innerHTML += `div.NobleRank, div.NobleRankTips { background-color: ${black.bg.deep}; }`; // 弹幕栏 - 粉丝团 eleStyle.innerHTML += ` div.FansRankInfo, div.ChatTabContainer { background-color: ${black.bg.deep}; } div.FansRankInfo span { color: ${black.font.deep}; } `; // 弹幕栏 - 主体 eleStyle.innerHTML += ` div#js-player-barrage, div.Barrage-main { background-color: ${black.bg.deep}; } span.Barrage-content { color: ${black.font.deep}; } div.Barrage { border-color: ${black.bg.light}; } `; // 弹幕栏 - 聊天框 eleStyle.innerHTML += ` div.layout-Player-chat { background-color: ${black.bg.deep}; } div.layout-Player-chat textarea.ChatSend-txt { background-color: ${black.bg.deep}; color: ${black.font.deep}!important; } `; // 弹幕栏脚本面板 eleStyle.innerHTML += ` div#h2p-div-clear-anchorHot { background-color: ${black.bg.deep}; border-bottom: 1px solid ${black.bg.deep}} div#h2p-div-clear-anchorHot div.Title-anchorText, div#h2p-div-clear-anchorHot div.Title-blockInline:nth-child(2) span.Title-row-icon, div#h2p-div-clear-anchorHot div.Title-blockInline:nth-child(2) i.Title-row-text { color: ${black.font.deep}; } `; // 互动预言 eleStyle.innerHTML += ` div#guess-main-panel { background: ${black.bg.deep}; border-color: ${black.bg.light}; } div.GuessMainPanelHeader-panelLeft span.GuessMainPanelHeader-slogon { color: ${black.font.deep}; } div.GuessGameBox, div.GuessReturnYwFdSlider-numIptWrap { background: ${black.bg.deep}; border-color: ${black.bg.light}; } div.GuessGameBox-header div.boxLeft, div.GuessReturnYwFdSlider-giftName { color: ${black.font.deep}; } div.GuessRankPanel-rank { border-color: ${black.bg.light}; } div.GuessReturnYwFdSlider-numIptWrap, div.GuessRankPanel, input.GuessReturnYwFdSlider-numIpt { background-color: ${black.bg.light}; border-color: ${black.bg.light}; color: ${black.font.deep}; } a.GuessGuideList-itemBox { background-color: ${black.bg.light}; } h2.guessGame--ell { color: ${black.font.deep}; } .GuessGuideList-item:hover { background-color: ${black.bg.deep}; } `; // 友邻 eleStyle.innerHTML += ` div#js-bottom-right { background-color: ${black.bg.deep}; } div.AnchorFriendPane-title { border-bottom-color: ${black.bg.light}!important } div.AnchorFriendPane-title h3 { color: ${black.font.deep}!important; } div.AnchorLike-ItemBox { border-color: ${black.bg.light}; } div.AnchorFriend-footer { border-top-color: ${black.bg.light}; } div.AnchorFriend-footer a { background-color: ${black.bg.deep}; color: ${black.font.deep}; } div.GuessReturnYwFdSlider { background-color: ${black.bg.deep}; border-color: ${black.bg.deep};} div.AnchorFriendPane-title a:first-child { display: none; } `; // 聊天框 eleStyle.innerHTML += ` .main-left { background-color: ${black.bg.deep}; border-right: 1px solid ${black.bg.light}; } .motorcadeHeader-motorcadeName-3mPkv { color: ${black.font.deep}; } .cl-item-username { color: ${black.font.light}; } .cl-item-line { background-color: ${black.bg.light}; } .main-left-header.main-left-header-small, .jumpBox-jumpBox-2BlGl { border-color: ${black.bg.light}; } `; if (isDouyuFollow) { eleStyle.innerHTML += ` div.layout-Module-head.ScrollTabFrame-head { background-color: ${black.bg.deep}; color: ${black.font.deep}; } div.layout-Cover-card { background-color: ${black.bg.deep}; } `; // 特别关注等按钮 eleStyle.innerHTML += ` .layout-Module-label { background-color: ${black.bg.light}; border-color: ${black.bg.light}; } `; // 可能感兴趣 eleStyle.innerHTML += ` .AthenaBoothPanel-wrapper, .AthenaBoothPanel-item { background-color: ${black.bg.light}; } .AthenaBoothPanel-des h3 { color: ${black.font.deep}; } .AthenaBoothPanel-followBtn { border-color: ${black.font.light}; color: ${black.font.light}; } `; // 每个卡片 eleStyle.innerHTML += ` .DyLiveCover-wrap, .DyLiveCover-wrap.is-hover, .DyLiveRecord { background-color: ${black.bg.light}; } .DyLiveCover-intro, .DyLiveRecord-intro { color: ${black.font.deep}; } `; } if (isDouyuTopic) { eleStyle.innerHTML += ` div.wm-general div.wm-general-bgblur, div.wm-general div.wm-general-wrapper { background: ${black.bg.deep}!important; } `; } } else if (isBilibili) { // 导航栏 eleStyle.innerHTML += ` body, #internationalHeader, #internationalHeader > div.mini-header { background: ${black.bg.deep}; } .international-header .nav-search #nav_searchform { background-color: ${black.bg.light}; } .international-header .mini-type .nav-link .nav-link-ul .nav-link-item .link, .mini-type .nav-user-center .user-con .item .name, .video-toolbar .ops > span, .video-toolbar .appeal-text, .international-header .nav-search .nav-search-keyword, .bilibili-search-history .history-item a { color: ${black.font.deep}; } .international-header .mini-type .user-con.logout .item a { color: ${black.font.deep}!important; } .international-header .mini-type .nav-search #nav_searchform, .bilibili-search-history { background: ${black.bg.light}; border-color: ${black.bg.light}; color: ${black.font.deep}; } .bili-banner[data-v-3120f830] { background: ${black.bg.deep}!important; } `; // 导航栏头像下拉框 eleStyle.innerHTML += ` .van-popover { background: ${black.bg.light}!important; } .van-popper-avatar .nickname, .van-popper-avatar .links .link-title { color: ${black.font.deep}!important; } .van-popper-avatar .level-info .grade, .van-popover a, .van-popper-avatar .count-item .item-value { color: ${black.font.light}!important; } .van-popper-avatar .coins, .van-popper-avatar .counts, .van-popper-avatar .links { border-bottom-color: ${black.bg.light}!important; } .van-popper-avatar .links .link-item:hover, .van-popper-avatar .logout a:hover { background: ${black.bg.deep}!important; } .van-popper-avatar .level-intro { background: ${black.bg.light}!important; color: ${black.font.light}!important; } .title { color: ${black.font.deep}!important; } `; // 收藏下拉框 eleStyle.innerHTML += ` .header-video-card .video-info .line-2 { color: ${black.font.deep}!important; } .header-video-card:hover { background: ${black.bg.deep}!important; } .van-popper-favorite .tab-item--normal:hover { background: ${black.bg.deep}!important; } `; // 登录 eleStyle.innerHTML += ` .van-popper-login .title[data-v-106692e2], .lang-intro-item, .lang-change .lang-title { color: ${black.font.deep}; } .van-popper-login .vp-container[data-v-106692e2], .lang-change { background-color: ${black.bg.deep}; border-color: ${black.bg.deep}; } .lang-change .lang-intro { background-color: ${black.bg.deep}; } .lang-change .lang-intro-item:hover { background-color: ${black.bg.light}; } .lang-change .lang-item:hover { background-color: ${black.bg.light}; } `; if (isBilibiliHome) { // 导航栏下边 eleStyle.innerHTML += ` .page-tab .con li { border: 1px solid transparent; } .international-header a { color: ${black.font.deep}; } .tab-line-itnl { border-color: ${black.font.deep}; } `; // 主体部分 eleStyle.innerHTML += ` a { color: ${black.font.deep}; } div.international-home { background-color: ${black.bg.deep}; } .contact-help { box-shadow: none; } `; // 主体部分 - 推广 eleStyle.innerHTML += ` .storey-title .no-link, .storey-title .text-info a, .video-card-common .ex-title { color: ${black.font.deep}; } `; // 主体部分 - 正在直播 eleStyle.innerHTML += ` .storey-title .name, .storey-title .text-info, .live-card .up .txt .name, .live-card .up .txt .desc, .exchange-btn .btn { color: ${black.font.deep}; } `; // 主体部分 - 动画 eleStyle.innerHTML += ` .rank-header .name, .live-tabs .tab-switch, .rank-header .more { color: ${black.font.deep}; } `; // 主体部分 - 番剧 eleStyle.innerHTML += ` .time-line .tab-switch .tab-switch-item, .special-recommend header { color: ${black.font.deep}; } .time-line .tl-link { background-color: ${black.bg.deep}; } `; // 主体部分 - 漫画 eleStyle.innerHTML += ` .time-line .tab-switch .tab-switch-item, .manga-panel .tab-switch .tab-switch-item, .manga-panel .app-download-link, .special-recommend header, .manga-rank .tab-switch .tab-switch-item, .manga-panel .manga-list-box .manga-card .manga-title { color: ${black.font.deep}; } `; // 底部 eleStyle.innerHTML += ` body, .international-footer { background: ${black.bg.deep}; } .international-footer a, .international-footer .link-box .link-item.link-c p { color: ${black.font.deep}; } .international-footer .link-box .link-item { border-color: ${black.bg.light}; } `; // 右边导航栏 eleStyle.innerHTML += ` .elevator .list-box { background-color: ${black.bg.light}; border-color: ${black.bg.light}; } .elevator .list-box .item { background-color: ${black.bg.light}; color: ${black.font.deep}; } .elevator .list-box .item.sort { border-top-color: ${black.bg.light}; } .elevator .list-box .item.back-top { border-color: ${black.bg.light}; } `; } else if (isBilibiliVideo) { // 信息栏 eleStyle.innerHTML += ` .video-info .video-title .tit { color: ${black.font.deep}; } `; // 播放器 eleStyle.innerHTML += ` #bilibiliPlayer { box-shadow: none; } .bilibili-player-video-sendbar, .bilibili-player-video-sendbar .bilibili-player-video-inputbar { background-color: ${black.bg.light}; } .video-desc .info, .bilibili-player-video-info, .bilibili-player * { color: ${black.font.deep}; } .video-toolbar, .v-wrap .s_tag { border-bottom-color: ${black.bg.light}; } .bilibili-player-video-sendbar .bilibili-player-video-inputbar .bilibili-player-video-inputbar-wrap { background-color: ${black.bg.deep}; border-color: ${black.bg.deep}; } .s_tag .tag-area > li { background-color: ${black.bg.light}; border-color: ${black.bg.light}; } .bilibili-player-video-sendbar .bilibili-player-video-inputbar .bilibili-player-video-danmaku-input, .s_tag .tag-area>li>a { color: ${black.font.deep}; } .s_tag .btn-add { background-color: ${black.bg.light}; } `; // 相关推荐 eleStyle.innerHTML += ` .v-wrap .danmaku-wrap, .bui-collapse .bui-collapse-wrap, .bui-collapse .bui-collapse-header, .player-auxiliary-area .player-auxiliary-filter, .video-page-card .card-box .pic-box { background-color: ${black.bg.light}; } .up-info .u-info .name .message, .info .title[data-v-3220bba8], .up-info .u-info .name .username, .player-auxiliary-area .player-auxiliary-filter-title, .bui-collapse .bui-collapse-header .bui-collapse-arrow, .recommend-list .rec-title, .video-page-card .card-box .info .title { color: ${black.font.deep}; } `; // 活动 eleStyle.innerHTML += ` .activity-m .inside-wrp { border-color: ${black.bg.light}; color: ${black.font.deep}; } `; // 评论 eleStyle.innerHTML += ` .bb-comment .comment-send .textarea-container textarea { background-color: ${black.bg.light}!important; border-color: ${black.bg.light}!important; } .bb-comment .comment-send .comment-emoji { border-color: ${black.bg.light}!important; } .bb-comment { background: ${black.bg.deep}!important; } .comment-m .b-head, .bb-comment .comment-header .tabs-order li, .paging-box, .paging-box .tcd-number, .bb-comment * { color: ${black.font.deep}!important; } .bb-comment .comment-list .list-item .con { border-top-color: ${black.bg.light}!important; } .bb-comment .comment-send .comment-submit { color: #fff!important; } `; // 创作团队 eleStyle.innerHTML += ` .members-info__header, .members-info .up-card .avatar[data-v-f843d968], .rec-footer { background-color: ${black.bg.light}!important; } .members-info__header .title { color: ${black.font.deep}; } `; // 返回顶端 eleStyle.innerHTML += ` .float-nav .nav-menu .item { background-color: ${black.bg.light}!important; border-color: ${black.bg.light}; } `; } else if (isBilibiliAct) { // 主体 eleStyle.innerHTML += ` #app, .fixed-bg { background: ${black.bg.deep}!important; } `; // 导航栏 eleStyle.innerHTML += ` .international-header .mini-type .nav-link .nav-link-ul .nav-link-item .link:hover { color: ${black.font.deep}!important; } .channel-menu-mini { background-color: ${black.bg.light}!important; } .channel-menu-mini .box a { color: ${black.font.light}!important; } .channel-menu-mini .box a:hover { background-color: ${black.bg.deep}; color: ${black.font.deep}!important; } `; // 个人信息 eleStyle.innerHTML += ` .user-panel[data-v-f8464120], .user-panel .content[data-v-f8464120], .feed-card .loading-content .loading-text[data-v-38950b07] { background: ${black.bg.light}; } .tc-black, .user-panel .content .bottom .number-part .numbers[data-v-f8464120] { color: ${black.font.deep}; } `; // 正在直播 eleStyle.innerHTML += ` .live-panel, .scroll-content { background: ${black.bg.light}!important; } .live-panel-item .live-detail .up-name { color: ${black.font.deep}!important; } `; // 话题 eleStyle.innerHTML += ` .new-topic-panel, .new-topic-panel .tag-item .label { background-color: ${black.bg.light}!important; } .new-topic-panel .tag-item .content { color: ${black.font.light}!important; } `; // 公告栏 eleStyle.innerHTML += ` .notice-panel .img-container .notice-img[data-v-64440e39] { background-color: ${black.bg.light}; } `; // 发布动态 eleStyle.innerHTML += ` .editor, .publish-panel, .home-page .home-container .home-content .center-panel .section-block { background-color: ${black.bg.light}!important; } .core-style { background-color: ${black.bg.light}!important; color: ${black.font.deep} } .static-popup, .static-popup { background-color: ${black.bg.deep}; border-color: ${black.bg.deep} } `; // 动态 eleStyle.innerHTML += ` .card, .card-list { background-color: ${black.bg.light}!important; } .feed-title[data-v-baaa0e9e], .feed-card[data-v-38950b07], .most-viewed-panel[data-v-28eb68ea], .tab-bar[data-v-58304b2a], .img-content[data-v-2ef3df58] { background-color: ${black.bg.light}; color: ${black.font.deep}; } .card[data-v-62336402], .video-container[data-v-3022fc8b], .article-container[data-v-3d352df6] { background-color: ${black.bg.light}; border-color: ${black.bg.light}!important; } .card .main-content .user-name > a { color: ${black.font.deep}!important; } .content > .content-full, .content > .content-ellipsis { color: ${black.font.light}!important; } .card-content .repost[data-v-0ff3934a] { background-color: ${black.bg.light}; } .article-container .text-area .title[data-v-3d352df6], .video-container .text-area .title[data-v-3022fc8b], .article-container:hover .text-area[data-v-3d352df6] { box-shadow: none; } .card .button-area .more-button[data-v-62336402] { color: ${black.font.deep}; } .card .more-panel[data-v-62336402], .card .more-panel[data-v-62336402]:after { background-color: ${black.bg.deep}; border-color: ${black.bg.deep}!important; color: ${black.font.deep}; } `; // 登陆板子 eleStyle.innerHTML += ` .login-panel[data-v-23be4e6a], .notice-panel[data-v-64440e39] { background-color: ${black.bg.light}; } .title h1[data-v-23be4e6a], .notice-panel .title[data-v-64440e39] { color: ${black.font.deep}; } `; } else if (isBilibiliRank) { // 导航栏下面 eleStyle.innerHTML += ` .primary-menu-itnl, .page-tab .con li { border-color: transparent; } .international-header a, .rank-menu li { color: ${black.font.deep}; } .other { border-color: ${black.font.light};; } `; // 主体 eleStyle.innerHTML += ` .rank-tab-wrap, .rank-list-head .rank_tips { background-color: ${black.bg.light}; } .rank-tab-wrap .rank-dropdown { background-color: ${black.bg.deep}; border-color: ${black.bg.deep}; color: ${black.font.deep}; } .rank-tab-wrap .rank-tab, .rank-list-head .rank_tips, .rank-item .content .info .title, .other .other-link .title { color: ${black.font.deep}; } .rank-item { border-bottom-color: ${black.bg.light}; } .rank-item:hover { box-shadow: 0 2px 5px ${black.bg.light}; } `; } else if (isBilibiliLive) { // 导航栏 eleStyle.innerHTML += ` .link-navbar[data-v-1118c224] { background: ${black.bg.deep}; } .link-navbar .main-ctnr .nav-logo[data-v-1118c224], .link-navbar .nav-item[data-v-3c413834], .shortcuts-ctnr[data-v-250967d4] { color: ${black.font.deep}; } .search-bar-ctnr .search-bar[data-v-7b227b1e] { background-color: ${black.bg.light}; } .search-bar-ctnr .search-bar input[data-v-7b227b1e] { color: ${black.font.light}; } .link-navbar-ctnr { background: ${black.bg.deep}; box-shadow: none; } `; // 主体 eleStyle.innerHTML += ` .room-bg[data-v-0654e230]:after { background: ${black.bg.deep}; } `; // 主播信息 eleStyle.innerHTML += ` #head-info-vm { background: ${black.bg.deep}!important; border-color: ${black.bg.light}!important; } .room-title[data-v-3d2a7540] { color: ${black.font.deep}; } `; // 礼物栏 eleStyle.innerHTML += ` #gift-control-vm { background: ${black.bg.deep}!important; border-color: ${black.bg.deep}!important; } .gift-sender-panel[data-v-1a9c7a62] { background: ${black.bg.light}; } .gift-info-title[data-v-2a59e9ce] { color: ${black.font.deep}; } .count-choice[data-v-2a59e9ce] { background: ${black.bg.light}; border-color: ${black.bg.light}; } .choice-item[data-v-8932cea6] { background: ${black.bg.light}; color: ${black.font.light}; } .choice-item.active[data-v-8932cea6], .choice-item[data-v-8932cea6]:hover { background: ${black.bg.light}; } .link-input[data-v-d24aeb24] { background: ${black.bg.deep}; color: ${black.font.deep}; } .gift-item.buy.hover[data-v-43f6afd4], .gift-item.buy[data-v-43f6afd4]:hover { background: ${black.bg.deep}; } .gift-control-panel .right-part .gift-presets .gift-panel-box[data-v-5e37006c] { background: ${black.bg.light}; } .gift-item .label[data-v-43f6afd4] { color: ${black.font.light}; } .count-choice[data-v-04fb3a0e] { background: ${black.bg.light}; border-color: ${black.bg.light}; } .awarding-panel[data-v-7e6fabd1] { background: ${black.bg.deep}; border-color: ${black.bg.deep}; color: ${black.font.deep}; } `; // 简介 eleStyle.innerHTML += ` .content-wrapper[data-v-2e6a8a0b] { background: ${black.bg.deep}; border-color: ${black.bg.deep}; } .room-introduction-tags[data-v-325717da] { border-bottom-color: ${black.font.light}; } `; // 弹幕 eleStyle.innerHTML += ` .chat-history-panel, .live-room-app .app-content .app-body .player-and-aside-area .aside-area .chat-control-panel { background: ${black.bg.deep}; } .chat-input[data-v-4a6a1454] { background-color: ${black.bg.light}; border-color: ${black.bg.light}; color: ${black.font.light}; } .danmaku-content { color: ${black.font.deep}; } #aside-area-vm { border-color: ${black.bg.light}; } #rank-list-vm, #rank-list-ctnr-box { background-color: ${black.bg.deep}!important; } `; // 主播公告 eleStyle.innerHTML += ` .announcement-cntr[data-v-74afbc60] { background-color: ${black.bg.deep}; border-color: ${black.bg.deep}; } .announcement-cntr .content[data-v-74afbc60] { border-top-color: ${black.font.light}; color: ${black.font.light}; } .glory-name[data-v-550db3af] { color: ${black.font.deep}; } `; // 绘马祈愿 eleStyle.innerHTML += ` .ema-wishing.ema-wishing[data-v-86b8b1ec] { background-color: ${black.bg.deep}; border-color: ${black.bg.deep}; } .title[data-v-86b8b1ec] { color: ${black.font.deep}; } `; // 动态 eleStyle.innerHTML += ` .feed-title[data-v-648a58c6] { background-color: ${black.bg.deep}; color: ${black.font.deep}; } .card[data-v-71e01794] { background-color: ${black.bg.deep}; border-color: ${black.bg.deep}!important; } .content-full[data-v-77d7458b] { color: ${black.font.deep}; } .card-content .repost[data-v-4f2a88dc] { background-color: ${black.bg.light}; } .video-container[data-v-3022fc8b] { background-color: ${black.bg.light}; border-color: ${black.bg.light}; } .video-container .text-area .title[data-v-3022fc8b] { color: ${black.font.deep}; } `; // 右部侧边栏 eleStyle.innerHTML += ` .side-bar-cntr[data-v-75105314] { background-color: ${black.bg.deep}; border-color: ${black.bg.deep}; } `; // 底部 eleStyle.innerHTML += ` .link-footer[data-v-237d6c0f] { background-color: ${black.bg.deep}; border-top-color: ${black.bg.deep}; } `; } } else if (isHuya) { eleStyle.innerHTML += ` body { background-color: ${black.bg.deep}!important; } `; // 导航栏 eleStyle.innerHTML += ` .hy-header-style-normal .duya-header-wrap { background-color: ${black.bg.deep}!important; border-bottom-color: ${black.bg.deep}!important; } .hy-header-style-normal .hy-nav-link, .hy-header-style-normal .hy-nav-title, .duya-header .nav-user .nav-user-title span { color: ${black.font.deep}!important; } .hy-header-style-normal .duya-header-search input, .hy-header-style-normal .duya-header-search input:focus { background-color: ${black.bg.light}!important; } .search-suggest .search-item { color: ${black.font.light}!important; } .search-suggest .search-item:hover { background-color: ${black.bg.deep}!important; } .nav-expand-list { background-color: ${black.bg.light}!important; } .nav-expand-game dt { color: ${black.font.deep}!important; } .nav-expand-game dd a { color: ${black.font.light}!important; border-color: ${black.font.light}!important; } .video-title, .hy-header-match-sec-hd { color: ${black.font.deep}!important; } .video-item, span.match-name { color: ${black.font.light}!important; } .video-item:hover { background-color: ${black.bg.light}!important; } .nav-expand-list-more, .tt-user-card .u-links { background-color: ${black.bg.light} } .nav-expand-history .history-bd li a, .tt-user-card .u-info .exp .between, .tt-user-card .u-info .nick, .tt-user-card .u-assets, .tt-user-card .u-task .task-mod .mod-tit { color: ${black.font.deep}!important; } .search-suggest { background-color: ${black.bg.light}!important; } .tt-user-card .u-task .task-mod { border-top-color: ${black.bg.light}!important; } `; // 侧边栏 eleStyle.innerHTML += ` .sidebar-hide { background-color: ${black.bg.deep}!important; border-bottom-color: ${black.bg.deep}!important; } .sidebar-hide .sidebar-icon-item { border-bottom-color: ${black.bg.deep}!important; } `; // 主体 eleStyle.innerHTML += ` #J_spbg, .room-wrap, #J_roomPlayerLayer, body.mode-page-theater .room-core, .match_body_wrap { background-color: ${black.bg.deep}!important; } #J_mainRoom { background: ${black.bg.deep}!important; } #J_spbg > img { display: none; } `; // 主播信息 eleStyle.innerHTML += ` .room-hd, #share-entrance { background-color: ${black.bg.deep}!important; } .room-hd .host-info .host-title h1 { color: ${black.font.deep}!important; } `; // 礼物栏 eleStyle.innerHTML += ` #player-gift-wrap, .player-face .player-face-arrow { background-color: ${black.bg.deep}!important; } .player-face .player-face-arrow:hover { background-color: ${black.bg.deep}!important; } .player-face li .plaer-face-icon-bg { border-color: ${black.bg.light}!important; } .player-face li:hover .plaer-face-icon-bg { background-color: ${black.bg.deep}!important; } #player-gift-tip, #player-gift-tip .bottom { background-color: ${black.bg.deep}!important; border-color: ${black.bg.deep}!important; } #player-gift-tip .arrow1:after, #player-gift-tip .arrow1:before { border-color: ${black.bg.deep}!important; } #player-gift-tip .btns li { background-color: ${black.bg.light}; border-color: ${black.bg.light}!important; color: ${black.font.light}!important; } .player-gift-left, .player-gift-right { background-color: ${black.bg.deep}!important; } #player-gift-tip .txt h3 { color: ${black.font.deep}!important; } `; // 弹幕栏 eleStyle.innerHTML += ` .room-profileNotice, .room-profileNotice div { background-color: ${black.bg.light}!important; border-color: ${black.bg.light}!important; } .liveStatus-replay .week-rank__btn { background-color: ${black.bg.light}!important; color: ${black.font.light}!important; } .week-rank__bd .week-rank__unit { background-color: ${black.bg.light}!important; border-color: ${black.bg.light}!important; color: ${black.font.deep}!important; } .week-rank__bd li:hover { background-color: ${black.bg.light}!important; } .room-sidebar { background-color: ${black.bg.deep}!important; border-color: ${black.bg.light}!important; } .chat-room__list .msg-nobleSpeak { background-color: ${black.bg.deep}!important; } .chat-room__list .msg { color: ${black.font.deep}; } #tipsOrchat { border-top-color: ${black.bg.deep}!important; } .chat-room__ft { background-color: ${black.bg.deep}!important; } .chat-room__ft .chat-room__ft__chat, .chat-room__input { border-color: ${black.bg.deep}!important; } .chat-room__input .msg-input textarea { background-color: ${black.bg.light}!important; color: ${black.font.light}!important } .fansBadge-box { background-color: ${black.bg.deep}!important; color: ${black.font.light}!important; } .room-panel { background-color: ${black.bg.light}!important; border-color: ${black.bg.light}!important; color: ${black.font.light}!important; } .fansBadge-hig { color: ${black.font.light}!important; } .chat-room__list .msg-timed span { background-color: ${black.bg.light}!important; } `; // 主播动态 eleStyle.innerHTML += ` .room-moments .moments-nav .moments-nav-item { color: ${black.font.deep}!important; } .room-moments .moments-content { background-color: ${black.bg.deep}!important; } .moment-item { background-color: ${black.bg.deep}!important; border-color: ${black.bg.deep}!important; } .moment-item .moment-cnt { color: ${black.font.deep}!important; } .moment-item .interacts-comment { color: ${black.font.light}!important; } .moment-item .moment-comment { background-color: ${black.bg.light}!important; border-color: ${black.bg.light}!important; } ._1ZYvj2uEXcHWFv7awTHSeB { color: ${black.font.light}!important; } ._2YIUQGPP7SUwr8QErlnVDk._3nr_XoL7ZMsSeLA84_9TNq { border-color: ${black.font.light}!important; } .moment-item .moment-video { background-color: ${black.bg.deep}!important; } `; // 签约工会 eleStyle.innerHTML += ` .room-union .union-title { color: ${black.font.deep}!important; } .room-union .union-box { background-color: ${black.bg.light}!important; border-color: ${black.bg.light}!important; } .room-union .union-name { color: ${black.font.deep}!important; } `; // 猜你喜欢 eleStyle.innerHTML += ` .room-youlike .youlike-title { color: ${black.font.deep}!important; } .room-youlike .youlike-box, .youlike-item .amount { background-color: ${black.bg.light}!important; } .youlike-item .nick { color: ${black.font.deep}!important; } .youlike-item .title { color: ${black.font.light}!important; } `; if (isHuyaFollow) { eleStyle.innerHTML += ` .list-hd .title, .subscribe-live-item .txt .msg-row .nick { color: ${black.font.deep}!important; } .subscribe-live-item, .hy-side .hy-side-nav-item { background-color: ${black.bg.light}!important; } .subscribe-live-item:hover { box-shadow: 2px 2px 10px ${black.bg.light}; } .list-hd .follow-ctrl { background-color: ${black.bg.deep}!important; } `; } } document.body.appendChild(eleStyle); } else { if ($H2P('style#h2p-style-blackMode')) { $H2P('style#h2p-style-blackMode').remove(); } } } if (config_clear.blackMode) { blackMode(); } const whiteBase64s = { douyu: '###i0xOTkuODkzMzMzek01MTIgNzY4Yy0xNDEuNDQgMC0yNTYtMTE0LjU2LTI1Ni0yNTZzMTE0LjU2LTI1NiAyNTYtMjU2IDI1NiAxMTQuNTYgMjU2IDI1Ni0xMTQuNTYgMjU2LTI1NiAyNTZ6IiBwLWlkPSIyMTIwIiBmaWxsPSIjZmZmZmZmIj48L3BhdGg+PC9zdmc+', bilibili: '###i0xOTkuODkzMzMzek01MTIgNzY4Yy0xNDEuNDQgMC0yNTYtMTE0LjU2LTI1Ni0yNTZzMTE0LjU2LTI1NiAyNTYtMjU2IDI1NiAxMTQuNTYgMjU2IDI1Ni0xMTQuNTYgMjU2LTI1NiAyNTZ6IiBwLWlkPSIyMTIwIiBmaWxsPSIjZmZmZmZmIj48L3BhdGg+PC9zdmc+', bilibiliVideo: '###i0xOTkuODkzMzMzek01MTIgNzY4Yy0xNDEuNDQgMC0yNTYtMTE0LjU2LTI1Ni0yNTZzMTE0LjU2LTI1NiAyNTYtMjU2IDI1NiAxMTQuNTYgMjU2IDI1Ni0xMTQuNTYgMjU2LTI1NiAyNTZ6IiBwLWlkPSIyMTIwIiBmaWxsPSIjMjEyMTIxIj48L3BhdGg+PC9zdmc+', finally: '', }; const blackBase64 = ''; const whiteBase64 = isDouyu ? whiteBase64s.finally : (isBilibili ? (isBilibiliHome || isBilibiliRank ? whiteBase64s.bilibili : whiteBase64s.bilibiliVideo) : whiteBase64s.finally); new Promise((resolve, reject) => { let eleStyle = document.createElement('style'); eleStyle.innerHTML += ` #h2p-img-blackMode { cursor: pointer; } .h2p-dropdown { position : relative; display : inline-block; vertical-align: middle; } .h2p-dropdown:hover .h2p-dropdown-menu { display : flex; visibility : visible; } .h2p-dropdown-menu { position : absolute; left : -97px; top : ${isDouyu ? '' : (isBilibili ? '20px' : '')}; width : 210px; padding : 10px; border : 1px solid #d2d2d2; border-radius: 5px; box-shadow : 0 2px 6px rgba(0,0,0,.1); background : #ffffff; color : #000000; display : flex; visibility : hidden; flex-flow : row wrap; font-size : 15px; font-family : WeibeiSC-Bold, STKaiti; z-index : 999; } .h2p-dropdown .h2p-flex-main-start, .h2p-dropdown .h2p-flex-main-center { margin : 0; } .h2p-dropdown span { cursor : default; user-select : none; } #h2p-div-blackMode-select span { margin-left : 2px; } .h2p-dropdown .input-color-show { cursor : pointer; width : 50px; height : 20px; padding : 0; margin-left : 10px; outline : none; } #h2p-div-blackMode-BG { position : fixed; top : 0; left : 0; width : 100%; height : 100%; display : none; opacity : 0; } `; if (isDouyu) {} else if (isBilibili) { eleStyle.innerHTML += ` a.link.van-popover__reference[href$="app.bilibili.com"], a.link.van-popover__reference[href$="app.bilibili.com/"] { display: none!important; } `; } document.head.appendChild(eleStyle); let div = document.createElement('div'); div.className = 'h2p-dropdown'; div.title = '黑暗模式'; if (isDouyu) { div.style = 'position: relative; float: left; margin: 15px -20px 15px 20px;'; div.innerHTML = ` <img id="h2p-img-blackMode" class="h2p-dropdown-img" style="width: 30px; height: 30px;" src="${config_clear.blackMode ? blackBase64 : whiteBase64}"> `; } else if (isBilibili) { if (isBilibiliHome || isBilibiliAct || isBilibiliRank || isBilibiliVideo) { div.style = 'display: flex; justify-content: center;'; div.classList.add('nav-link-item'); } else if (isBilibiliLive) { div.style = 'margin: 0 13px; justify-content: center;'; } div.innerHTML = ` <img id="h2p-img-blackMode" style="width: 20px; height: 20px;" src="${config_clear.blackMode ? blackBase64 : whiteBase64}"> `; } else if (isHuya) { div.classList.add('hy-nav-right'); div.style = 'position: absolute; right: -35px;'; div.innerHTML = ` <img id="h2p-img-blackMode" style="width: 25px; height: 25px;" src="${config_clear.blackMode ? blackBase64 : whiteBase64}"> `; } else { div.style = ''; div.innerHTML = ` <img id="h2p-img-blackMode" style="width: 25px; height: 25px;" src="${config_clear.blackMode ? blackBase64 : whiteBase64}"> `; } let divDropDown = document.createElement('div'); divDropDown.className = 'h2p-dropdown-menu'; if (isDouyu) { } else if (isBilibili) { } else if (isHuya) { divDropDown.style = 'left: -112px;'; } divDropDown.innerHTML += ` <div id="h2p-div-blackMode-select" style="width: 100%;"> <div class="h2p-flex-main-center h2p-item-100p" style="margin-bottom: 5px;"> <div class="h2p-flex-main-start h2p-item-50p"> <input id="h2p-input-blackMode-grey" type="checkbox"> <span>灰色</span> </div> <div class="h2p-flex-main-start h2p-item-50p"> <input id="h2p-input-blackMode-black" type="checkbox"> <span>黑色</span> </div> </div> <div class="h2p-flex-main-start h2p-item-100p" style="margin-bottom: 5px;"> <div class="h2p-flex-main-start h2p-item-50p"> <input id="h2p-input-blackMode-DIY" type="checkbox"> <span>自定义</span> </div> </div> </div> <div id="h2p-div-blackMode-set" style="width: 100%;"> <div class="h2p-flex-main-start h2p-item-100p" style="margin-bottom: 5px;"> <div class="h2p-flex-main-start h2p-item-50p"> <span>背景</span> <input id="h2p-input-blackMode-DIY-BG-deep" class="input-color-show" type="color" value="#2d2e37"> </div> <div class="h2p-flex-main-start h2p-item-50p"> <span>面板</span> <input id="h2p-input-blackMode-DIY-BG-light" class="input-color-show" type="color" value="#363636"> </div> </div> <div class="h2p-flex-main-start h2p-item-100p" style="margin-bottom: 5px;"> <div class="h2p-flex-main-start h2p-item-50p"> <span>标题</span> <input id="h2p-input-blackMode-DIY-font-deep" class="input-color-show" type="color" value="#a7a7a7"> </div> <div class="h2p-flex-main-start h2p-item-50p"> <span>正文</span> <input id="h2p-input-blackMode-DIY-font-light" class="input-color-show" type="color" value="#888888"> </div> </div> </div> `; div.appendChild(divDropDown); let INVL_render = setInterval(() => { if ($H2P('img#h2p-img-blackMode')) { clearInterval(INVL_render); INVL_render = null; console.log('启动完毕 : BlackMode 初始化'); resolve(); return; } if (isDouyu && $H2P('div.Header-right')) { $H2P('div.Header-right').appendChild(div); } else if (isBilibili) { if (isBilibiliHome || isBilibiliAct || isBilibiliRank || isBilibiliVideo) { if ($H2P('ul.nav-link-ul > li:nth-child(8)')) { $H2P('ul.nav-link-ul').appendChild(div); } } else if (isBilibiliLive) { let ele = $H2P('ul.nav-link-ul > li:nth-child(8)') || $H2P('div.dp-table-cell.v-middle > a:nth-child(10)'); if (ele) { ele.parentNode.appendChild(div); } } } else if (isHuya && $H2P('div#J_duyaHeaderRight')) { $H2P('div.duya-header-bd').appendChild(div); } if (!isDouyu && !isBilibili && !isHuya) { div.style.left = '250px'; document.body.appendChild(div); } }, 500); }) .then(() => { // 黑暗模式快捷键 document.addEventListener('keydown', (e) => { if (e.shiftKey && e.which == $util.keyCode.z) { $H2P('img#h2p-img-blackMode').click(); } }); $H2P('img#h2p-img-blackMode').addEventListener('click', (event) => { config_clear.blackMode = !config_clear.blackMode; $util.LS.set(LSClear, config_clear); event.currentTarget.src = config_clear.blackMode ? blackBase64 : whiteBase64; updateClearModeIcon(); blackMode(); }); $H2P('div#h2p-div-blackMode-select').addEventListener('click', (event) => { if (event.target.tagName.toLowerCase() !== 'input') { return; } const target = event.target; config_clear.BMGrey = target.id.endsWith('-grey'); config_clear.BMBlack = target.id.endsWith('-black'); config_clear.BMDIY = target.id.endsWith('-DIY'); $H2P('input#h2p-input-blackMode-grey').checked = config_clear.BMGrey; $H2P('input#h2p-input-blackMode-black').checked = config_clear.BMBlack; $H2P('input#h2p-input-blackMode-DIY').checked = config_clear.BMDIY; $util.LS.set(LSClear, config_clear); blackMode(); }); $H2P('input#h2p-input-blackMode-DIY-BG-deep').addEventListener('change', (event) => { config_clear.BMBGDeep = event.target.value; $util.LS.set(LSClear, config_clear); blackMode(); }, false); $H2P('input#h2p-input-blackMode-DIY-BG-light').addEventListener('change', (event) => { config_clear.BMBGLight = event.target.value; $util.LS.set(LSClear, config_clear); blackMode(); }, false); $H2P('input#h2p-input-blackMode-DIY-font-deep').addEventListener('change', (event) => { config_clear.BMFontDeep = event.target.value; $util.LS.set(LSClear, config_clear); blackMode(); }, false); $H2P('input#h2p-input-blackMode-DIY-font-light').addEventListener('change', (event) => { config_clear.BMFontLight = event.target.value; $util.LS.set(LSClear, config_clear); blackMode(); }, false); }) .then(() => { $H2P('input#h2p-input-blackMode-grey').checked = config_clear.BMGrey; $H2P('input#h2p-input-blackMode-black').checked = config_clear.BMBlack; $H2P('input#h2p-input-blackMode-DIY').checked = config_clear.BMDIY; $H2P('input#h2p-input-blackMode-DIY-BG-deep').value = config_clear.BMBGDeep; $H2P('input#h2p-input-blackMode-DIY-BG-light').value = config_clear.BMBGLight; $H2P('input#h2p-input-blackMode-DIY-font-deep').value = config_clear.BMFontDeep; $H2P('input#h2p-input-blackMode-DIY-font-light').value = config_clear.BMFontLight; }) // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // // 清爽模式 // // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // function clearNav () { console.log(`${config_clear.isClearNav ? '启动' : '关闭'} : 清爽导航栏`); if (config_clear.isClearNav) { if ($H2P('style#h2p-style-clear-nav')) { return; } let eleStyle = document.createElement('style'); eleStyle.id = 'h2p-style-clear-nav'; if (isDouyu) { // 斗鱼 logo、游戏、活动 eleStyle.innerHTML += ` a.Header-logo, div.public-DropMenu.Game, div.HeaderNav, .HeaderGif-left, .HeaderGif-right { display: none!important; } `; // 客户端、开播 eleStyle.innerHTML += ` div.Header-download-wrap, div.Header-broadcast-wrap { display: none!important; } `; // 用户头像 hover eleStyle.innerHTML += ` div.UserInfo div.Task, div.UserInfo div.CloudGameLink, div.Promotion { display: none!important; } `; } else if (isBilibili) { if (isBilibiliVideo) { // 游戏中心 eleStyle.innerHTML += ` ul.nav-link-ul > li.nav-link-item:nth-child(3) { display: none!important; } `; // 评论上方的活动 eleStyle.innerHTML += ` #activity_vote { display: none!important; } `; } else if (isBilibiliLive) { // 游戏中心 eleStyle.innerHTML += ` a.link.van-popover__reference[href$="game.bilibili.com"], a.link.van-popover__reference[href$="game.bilibili.com/"] { display: none!important; } `; // 全部、下载 eleStyle.innerHTML += ` div.dp-table-cell.v-middle > a[data-v-3c413834]:nth-child(4), div.shortcuts-ctnr > div[data-v-250967d4]:nth-child(3) { display: none!important; } `; } } else if (isHuya) { // logo、开播、下载 eleStyle.innerHTML += ` #duya-header-logo, .hy-nav-kaibo, #hy-nav-download { display: none!important; } `; // 游戏广告 eleStyle.innerHTML += ` .nav-expand-list.nav-expand-game > a > img { display: none!important; } `; } document.body.appendChild(eleStyle); } else { if ($H2P('style#h2p-style-clear-nav')) { $H2P('style#h2p-style-clear-nav').remove(); } } } function clearInfo () { console.log(`${config_clear.isClearInfo ? '启动' : '关闭'} : 清爽主播信息`); if (config_clear.isClearInfo) { if ($H2P('style#h2p-style-clear-info')) { return; } let eleStyle = document.createElement('style'); eleStyle.id = 'h2p-style-clear-info'; if (isDouyu) { eleStyle.innerHTML += ` div#js-player-title { min-height: auto!important; } div.Title { height: 100%!important; } `; // 直播间左下角水印 eleStyle.innerHTML += ` .watermark-442a18 { display: none!important; } `; // 背景图片、神秘超# eleStyle.innerHTML += ` .shark-webp .Title.is-emperor8, .Title.is-emperor8 { background: transparent!important; } .Title-EmperorRecommend-wrap { display: none!important; } `; // 头像、举报、友邻 eleStyle.innerHTML += ` div.Title-anchorPic, div.Title-roomInfo div.Title-col.is-left > div.Title-blockInline:nth-child(2), .Title-addFriend { display: none!important; } .Title { padding: 8px 10px 8px 15px; } `; // 官方称号、认证、房间导航 eleStyle.innerHTML += ` div.Title-roomInfo > div.Title-row:nth-child(2) > div.Title-col:nth-child(1) > div.Title-blockInline:last-child, .Title-txAuthentication, .Title-category { display: none!important; } `; // 友邻、工会、体重 eleStyle.innerHTML += ` div.Title-roomInfo > div.Title-row:nth-child(2) > div.Title-col:nth-child(2), div.Title-roomInfo > div.Title-row:nth-child(3) { display: none!important; } `; } else if (isBilibili) { // 头像框、右下角闪电 eleStyle.innerHTML += ` .up-info .u-face .pendant, .bili-avatar-pendent { display: none!important; } .bili-avatar-icon { display: none!important; } `; if (isBilibiliVideo) { // 禁止转载 eleStyle.innerHTML += ` .video-info .video-title { width: 100%; } div#viewbox_report { margin-bottom: 11px; display: flex; flex-flow: row wrap; } .video-info .video-data { width: 50%; margin-top: 0; } .video-info .video-data .copyright { display: none!important; } #viewbox_report .video-data:nth-child(3) { justify-content: flex-end; } `; // 主播介绍、发消息 eleStyle.innerHTML += ` .up-info .u-info .desc, .up-info .u-info .name .message { display: none!important; } .up-info .btn-panel { clear: none; width: 257px; } `; } else if (isBilibiliLive) { // 主播状态 // 区域、时间排行榜 eleStyle.innerHTML += ` h1 > span.live-status-label, div.week-star-rank, .area-text, .hour-rank { display: none!important; } `; // 排名礼物、挑战、第几关 eleStyle.innerHTML += ` .icon-label, .chaos-pk-banner, .june-activity-entry { display: none!important; } `; // 头像框 eleStyle.innerHTML += ` .header-info-ctnr .pendant-item.bg-no-repeat.bg-center.bg-cover.face-avatar-box, .loli-ctnr { display: none!important; } `; // 关注、举报、分享 eleStyle.innerHTML += ` .attention-btn-ctnr, div.upper-right-ctnr > div:nth-child(1), div.upper-right-ctnr > div:nth-child(2) { display: none!important; } `; } } else if (isHuya) { // 房间导航、关注人数、房间活动 eleStyle.innerHTML += ` .main-room .box-crumb, .room-hd .host-channel { display: none!important; } .room-hd .host-control .subscribe-entrance { display: none!important; } .room-business-game { display: none!important; } `; // 守护、认证 eleStyle.innerHTML += ` .room-hd .host-info .open-souhu, .room-hd .tencent-identification { display: none!important; } `; // 视频、房间号、举报、分享、客户端看、下载游戏 eleStyle.innerHTML += ` .room-hd .host-video, .room-hd .host-rid { display: none!important; } .illegal-report, #share-entrance { display: none!important; } .room-hd .host-control .jump-to-phone { display: none!important; } #J_roomGameBuy { display: none!important; } `; } document.body.appendChild(eleStyle); } else { if ($H2P('style#h2p-style-clear-info')) { $H2P('style#h2p-style-clear-info').remove(); } } } function clearAside () { console.log(`${config_clear.isClearAside ? '启动' : '关闭'} : 清爽侧边栏`); if (config_clear.isClearAside) { if ($H2P('style#h2p-style-clear-aside')) { return; } let eleStyle = document.createElement('style'); eleStyle.id = 'h2p-style-clear-aside'; if (isDouyu) { eleStyle.innerHTML += ` aside#js-aside { display: none!important; } `; } else if (isBilibili) { eleStyle.innerHTML += ` div.item.help { display: none!important; } `; if (isBilibiliVideo) { eleStyle.innerHTML += ` .v-wrap { max-width: 75%; } .v-wrap .r-con { display: none!important; } .v-wrap .l-con { width: 100%!important; } #bofqi { width: 100%!important; height: auto!important; } `; } else if (isBilibiliLive) { eleStyle.innerHTML += ` div#sidebar-vm { display: none!important; } `; } } else if (isHuya) { // 侧边栏 eleStyle.innerHTML += ` .mod-sidebar { display: none!important; } `; } document.body.appendChild(eleStyle); } else { if ($H2P('style#h2p-style-clear-aside')) { $H2P('style#h2p-style-clear-aside').remove(); } } } (() => { // 转移预言的位置 const start = new Date().$times(); let INVL_wait_div_quiz = setInterval(() => { if ($H2P('div.ToolbarActivityArea > div > div') && $H2P('div.ActiviesExpandPanel div.ActivityItem[data-flag="anchor_quiz"]')) { clearInterval(INVL_wait_div_quiz); INVL_wait_div_quiz = null; $H2P('div.ToolbarActivityArea > div > div').appendChild($H2P('div.ActiviesExpandPanel div.ActivityItem[data-flag="anchor_quiz"]')); } // 最多等待 5min else if ((new Date().$times() - start) > 2 * 60) { clearInterval(INVL_wait_div_quiz); INVL_wait_div_quiz = null; } }, 1000); })() function clearGift () { console.log(`${config_clear.isClearGift ? '启动' : '关闭'} : 清爽礼物栏`); if (config_clear.isClearGift) { if ($H2P('style#h2p-style-clear-gift')) { return; } let eleStyle = document.createElement('style'); eleStyle.id = 'h2p-style-clear-gift'; if (isDouyu) { // 全民乐 PK、礼物、欢乐开黑、打弱#、幸运寻宝、鱼丸夺宝 eleStyle.innerHTML += ` div.ToolbarActivityArea div.PlayerToolbar-Task, div.SuperFansBubble, div.ToolbarActivityArea div.BattleShipEnter, div.ToolbarActivityArea div.RomanticDateComponent, .PlayFishBallEnter, .HappyPlayIcon, .EggLudoActEntry, .FishballTreasure { display: none!important; } .PlayerToolbar-signCont { visibility: hidden; } `; // 鱼购精选、打赏君、超级擂主、充值送鱼丸、许愿池、环游星空、弱#总动员 eleStyle.innerHTML += ` .ActivityItem[data-flag=douyugoods], .ActivityItem[data-flag=projectLiveReward], .ActivityItem[data-flag=''], .ActiviesExpanel-ExpandBtn, .Act202006fansTips, .ActConfigPay, .WishPondEnter, .TurntableLottery, .HitWeakChickenEnter { display: none!important; } `; // 礼物红包、房间等级、周的标签 eleStyle.innerHTML += ` .ActivityItem[data-flag=propRedEnvelope], .ActivityItem[data-flag=room_level], .GiftItem-leftConnerMark { display: none!important; } `; } else if (isBilibili) { if (isBilibiliLive) { // 开通大航海、心愿、礼物图 eleStyle.innerHTML += ` div.m-guard-ent, .wish-icon.no-wish, .mailbox-cntr { display: none!important; } `; } } else if (isHuya) { // 礼物周星榜、超星榜、贵族 eleStyle.innerHTML += ` #week-star-btn, #super-star-rank, #player-noble-btn { display: none!important; } `; // 星际巡航、欢乐对对碰、零点战神 eleStyle.innerHTML += ` #diy-activity-icon-1373, #diy-activity-icon-1599, #diy-activity-icon-1149 { display: none!important; } .diy-activity-icon { display: none!important; } `; // 宝箱文字、礼物栏大小 eleStyle.innerHTML += ` #player-box .player-box-tip { display: none!important; } .player-face .player-face-list { width: 335px!important; } `; } document.body.appendChild(eleStyle); } else { if ($H2P('style#h2p-style-clear-gift')) { $H2P('style#h2p-style-clear-gift').remove(); } } } function clearBar () { console.log(`${config_clear.isClearBar ? '启动' : '关闭'} : 清爽弹幕栏`); if (config_clear.isClearBar) { if ($H2P('style#h2p-style-clear-bar')) { return; } let eleStyle = document.createElement('style'); eleStyle.id = 'h2p-style-clear-bar'; if(isDouyu) { eleStyle.innerHTML += ` div#js-player-barrage { top: 32px!important; } `; // 公告、开通贵族公告 // 聊天室、战队牌子 eleStyle.innerHTML += ` div.AnchorAnnounce, div.layout-Player-rankAll, div.layout-Player-rank { display: none!important; } div.BarrageBanner { display: none!important; } div.MatchSystemChatRoomEntry, div.MatchSystemTeamMedal { display: none!important; } `; // 弹幕标签、置顶弹幕、签到手速王 eleStyle.innerHTML += ` .FansMedal.is-made, .RoomLevel, .shark-webp .Motor, .Barrage-noble, .Medal, .BarrageTips, .FansMedal, .ChatAchievement-image { display: none!important; } .Barrage-notice--noble { background: transparent!important; border: none; padding: 0 10px; } #js-floatingbarrage-container { display: none!important; } .Baby { display: none!important; } `; // 喇叭、贵族弹幕、超链弹幕、火力全开、名字前标志、表情 // 房管弹幕、房间通知、超链接弹幕、房管标签 eleStyle.innerHTML += ` div.Horn4Category, div.ChatNobleBarrage, div.Barrag###perLink, div.Barrage-firstCharge, .FirePowerIcon, .RoleAvatar-wrapper, .Emot-image { display: none!important; } .Barrage--paddedBarrage, .Barrage-icon--sys { padding: 0 10px; } .Barrage-notice, .HyperLink, .shark-webp .Barrage-icon--roomAdmin { display: none!important; } `; } else if (isBilibili) { if (isBilibiliVideo) { // 弹幕列表 eleStyle.innerHTML += ` div#danmukuBox { display: none; } `; } else if(isBilibiliLive) { // 榜单 eleStyle.innerHTML += ` div#rank-list-vm { display: none!important; } .live-room-app .app-content .app-body .player-and-aside-area .aside-area .chat-history-panel { border-radius: 11px 11px 0 0; height: calc(100% - 145px); } .chat-history-panel .chat-history-list.with-penury-gift { height: 100%; } `; // 牌子、活动牌子、舰长标志、爷、弹幕对齐 // 牌子 eleStyle.innerHTML += ` .fans-medal-item-ctnr, .live-title-icon, .guard-icon, .vip-icon, .title-label { display: none!important; } `; // 房管弹幕 eleStyle.innerHTML += ` .guard-level-1, .guard-level-2 { padding: 4px 5px!important; margin: 0!important; } .chat-history-panel .chat-history-list .chat-item.danmaku-item.guard-level-1:before, .chat-history-panel .chat-history-list .chat-item.danmaku-item.guard-level-2:before { background-color: transparent!important; border-image: none!important; } .chat-history-panel .chat-history-list .chat-item.danmaku-item.guard-level-1:after, .chat-history-panel .chat-history-list .chat-item.danmaku-item.guard-level-2:after { background: none!important; } `; // 投喂信息、礼物弹幕 eleStyle.innerHTML += ` .chat-item.misc-msg.guard-buy, .chat-item.gift-item, #penury-gift-msg { display: none!important; } `; // 自己名称颜色 eleStyle.innerHTML += ` .chat-history-panel .chat-history-list .chat-item.danmaku-item .user-name.my-self { color: #903d95; } `; } } else if (isHuya) { // 周榜、营收 eleStyle.innerHTML += ` #J_roomSideHd, #wrap-income { display: none!important; } #chatRoom { height: calc(100% - 100px)!important; } .chat-room__bd { height: 100%!important; } `; // 弹幕标签、房管等标签 eleStyle.innerHTML += ` .J_msg[data-id="0"], .chat-room__list .msg-normal-decorationSuffix, .chat-room__list .msg-nobleSpeak-decorationSuffix { display: none!important; } .msg-normal-decorationPrefix, .msg-nobleSpeak-decorationPrefix { display: none!important; } .chat-room__list .msg-nobleSpeak { padding: 2px 9px; margin: 0; } .chat-room__list .msg-normal { padding: 2px 9px; } `; // 表情、续费通知、官方通知 eleStyle.innerHTML += ` span.msg > img, .msg-noble.noble-recharge-level-1, .msg-sys { display: none!important; } `; // 弹幕背景、系统消息、爵位标签、置顶弹幕 eleStyle.innerHTML += ` .chat-room__list .msg-nobleSpeak { background-color: transparent; } .chat-room__list .msg-auditorSys { display: none!important; } .box-noble-level-1:after, .box-noble-level-2:after, .box-noble-level-3:after, .box-noble-level-4:after, .box-noble-level-5:after, .box-noble-level-6:after { display: none!important; } #J_box_msgOfKing { display: none!important; } `; // 进入直播间、粉丝动员大会 eleStyle.innerHTML += ` .msg-nobleEnter, #wrap-ext { display: none!important; } `; // 粉丝牌、上电视、弹幕大小 eleStyle.innerHTML += ` .fans-icon, .msg-onTVLottery-text { display: none!important; } .chat-room__list .msg-normal { font-size: 13px; } `; } document.body.appendChild(eleStyle); } else { if ($H2P('style#h2p-style-clear-bar')) { $H2P('style#h2p-style-clear-bar').remove(); } } } function clearPlay () { console.log(`${config_clear.isClearPlay ? '启动' : '关闭'} : 清爽播放器`); if (config_clear.isClearPlay) { if ($H2P('style#h2p-style-clear-play')) { return; } let eleStyle = document.createElement('style'); eleStyle.id = 'h2p-style-clear-play'; if (isDouyu) { // 悬浮广告、鱼吧、友邻、全名吃# eleStyle.innerHTML += ` #js-room-activity, .layout-Bottom-mainEntity, #js-bottom-right, .css-widgetWrapper-EdVVC { display: none!important; } `; // 互动预言位置 eleStyle.innerHTML += ` .guessGameContainer { margin-bottom: 15px; } `; // 背景高度 eleStyle.innerHTML += ` #bc6 { height: 1000px!important; } #root > div.bc-wrapper:last-child { display: none!important; } `; if (isDouyuTopic) { if (location.href.includes('lolylyx')) { eleStyle.innerHTML += ` div#root > div.wm-general:nth-child(4) { margin-top: 70px; } div#root > div.wm-general:nth-child(3), .wm-h5-view, .wm-h5-tab { display: none!important; } div.wm-general-bgblur, div.wm-general-wrapper { background: none!important; } `; } else { eleStyle.innerHTML += ` div#root > div.wm-general:nth-child(2), div#root > div.wm-general:nth-child(n+4), div.wm_footer, div#root > div.bc-wrapper { display: none!important; } div#root > div.wm-general:nth-child(3) { margin-top: 70px; } div#root > div.wm-general:nth-child(3) > div { background: none!Important; } `; } } else if (isDouyuFollow) { eleStyle.innerHTML += ` section.layout-Banner, .Prompt-container, .AdView { display: none!important; } `; } } else if (isBilibili) { if (isBilibiliHome) { // 联系客服、左下角的猫 eleStyle.innerHTML += ` .contact-help { display: none!important; } .mascot { display: none!important; } `; // 下载 APP eleStyle.innerHTML += ` .app-download-link { display: none!important; } `; } else if (isBilibiliVideo) { // 大家围观的直播、用户头像框、评论 eleStyle.innerHTML += ` #live_recommand_report, .bb-comment .comment-list .list-item .user-face .pendant img, .v-wrap #comment { display: none!important; } `; // 相关推荐 eleStyle.innerHTML += ` .rec-list .video-page-card:nth-child(n+7) { display: none; } .rec-list .video-page-card:nth-child(n+21) { display: inherit; } `; // 广告 eleStyle.innerHTML += ` div#slide_ad, div#right-bottom-banner, .ad-report.ad-floor { display: none!important; } `; } else if (isBilibiliLive) { // 视频 logo eleStyle.innerHTML += ` .bilibili-live-player-video-logo { display: none!important; } `; // 背景 eleStyle.innerHTML += ``; // 礼物栏下滚动条目、他的动态、底部公司信息 eleStyle.innerHTML += ` div.left-container > div.flip-view { display: none!important; } .room-feed { display: none!important; } div#link-footer-vm { display: none!important; } `; // 绘马祈愿 eleStyle.innerHTML += ` .wish-part { display: none!important; } `; // 直播间背景图 eleStyle.innerHTML += ` section.container-wrapper, .t-space-container.plat-section-space { height: auto!important; } .t-background-image { display: none!important; } .t-space-container { padding-top: 10px!important; } .handle-bar { margin-bottom: 10px!important; } `; // 分享、b 站信息 eleStyle.innerHTML += ` #webShare, .international-footer { display: none!important; } `; // 边角弧度 eleStyle.innerHTML += ` body.lite-room #head-info-vm { border-radius: 12px 12px 0 0!important; } body.lite-room #gift-control-vm, body.lite-room #chat-control-panel-vm { border-radius: 0 0 12px 12px!important; } `; } else if (isBilibiliAct) { // 头像框、用户反馈论坛、2233娘 eleStyle.innerHTML += ` .card .user-head .user-decorator, .notice-panel, .card-decorator { display: none!important; } `; } } else if (isHuya) { // 背景图片、KPL 背景图 eleStyle.innerHTML += ` #J_spbg { display: none!important; } .diy-comps-wrap { display: none!important; } #J_mainRoom { background: transparent!important; } .sidebar-min .main-room { padding: 10px 40px 0; } `; // 动态、签约工会、猜你喜欢 eleStyle.innerHTML += ` .room-core { margin-bottom: 20px; } .room-footer { display: none!important; } `; // 滚动弹幕、虎扯 eleStyle.innerHTML += ` #player-marquee-wrap, .ball-view--19sRps-ih3GIs4n1CGztMM { display: none!important; } `; if (isHuyaFollow) { eleStyle.innerHTML += ` div.hy-mm { display: none!important; } `; } } document.body.appendChild(eleStyle); } else { if ($H2P('style#h2p-style-clear-play')) { $H2P('style#h2p-style-clear-play').remove(); } } } function clearMode () { console.log(`${config_clear.clearMode ? '启动' : '关闭'} : 清爽模式`); if (config_clear.isClearNav) { if (config_clear.clearMode) { clearNav(); } else { config_clear.isClearNav = false; clearNav(); config_clear.isClearNav = true; } } if (config_clear.isClearInfo) { if (config_clear.clearMode) { clearInfo(); } else { config_clear.isClearInfo = false; clearInfo(); config_clear.isClearInfo = true; } } if (config_clear.isClearAside) { if (config_clear.clearMode) { clearAside(); } else { config_clear.isClearAside = false; clearAside(); config_clear.isClearAside = true; } } if (config_clear.isClearGift) { if (config_clear.clearMode) { clearGift(); } else { config_clear.isClearGift = false; clearGift(); config_clear.isClearGift = true; } } if (config_clear.isClearBar) { if (config_clear.clearMode) { clearBar(); } else { config_clear.isClearBar = false; clearBar(); config_clear.isClearBar = true; } } if (config_clear.isClearPlay) { if (config_clear.clearMode) { clearPlay(); } else { config_clear.isClearPlay = false; clearPlay(); config_clear.isClearPlay = true; } } } if (config_clear.clearMode) { clearMode(); } const clearBase64s = { clear: { white: '', grey: '', black: '', }, back: { white: '', grey: '', black: '', } }; const clearBase64 = { black: clearBase64s.clear.grey, white: isDouyu ? clearBase64s.clear.grey : (isBilibiliHome || isBilibiliRank ? clearBase64s.clear.white : (isHuya ? clearBase64s.clear.grey : clearBase64s.clear.black)), } const backBase64 = { black: clearBase64s.back.grey, white: isDouyu ? clearBase64s.back.grey : (isBilibiliHome || isBilibiliRank ? clearBase64s.back.white : (isHuya ? clearBase64s.back.grey : clearBase64s.back.black)), } new Promise((resolve, reject) => { let eleStyle = document.createElement('style'); eleStyle.innerHTML += ` #h2p-img-clearMode { cursor: pointer; } #h2p-div-clearMode-select span { margin-left: 2px; } `; if (isDouyu) {} else if (isBilibili) { eleStyle.innerHTML += ` a.link.van-popover__reference[href$="app.bilibili.com"], a.link.van-popover__reference[href$="app.bilibili.com/"] { display: none!important; } `; if (isBilibiliVideo) { eleStyle.innerHTML += ` .h2p-dropdown-menu input[type=checkbox] { -webkit-appearance: checkbox!important; } `; } } document.head.appendChild(eleStyle); let div = document.createElement('div'); div.className = 'h2p-dropdown'; div.title = '清爽模式'; if (isDouyu) { div.style = 'position: relative; float: left; margin: 15px -20px 15px 30px;'; div.innerHTML = ` <img id="h2p-img-clearMode" class="h2p-dropdown-img" style="width: 30px; height: 30px;" src="${config_clear.clearMode ? (config_clear.blackMode ? backBase64.black : backBase64.white) : (config_clear.blackMode ? clearBase64.black : clearBase64.white)}"> `; } else if (isBilibili) { if (isBilibiliHome || isBilibiliAct || isBilibiliRank || isBilibiliVideo) { div.style = 'display: flex; justify-content: center;'; div.classList.add('nav-link-item'); } else if (isBilibiliLive) { div.style = 'margin: 0 10px; justify-content: center;'; } div.innerHTML = ` <img id="h2p-img-clearMode" style="width: 20px; height: 20px;" src="${config_clear.clearMode ? (config_clear.blackMode ? backBase64.black : backBase64.white) : (config_clear.blackMode ? clearBase64.black : clearBase64.white)}"> `; } else if (isHuya) { div.classList.add('hy-nav-right'); div.style = 'position: absolute; right: -70px;'; div.innerHTML = ` <img id="h2p-img-clearMode" style="width: 25px; height: 25px;" src="${config_clear.clearMode ? (config_clear.blackMode ? backBase64.black : backBase64.white) : (config_clear.blackMode ? clearBase64.black : clearBase64.white)}"> `; } else { div.style = ''; div.innerHTML = ` <img id="h2p-img-clearMode" style="width: 20px; height: 20px;" src="${config_clear.clearMode ? (config_clear.blackMode ? backBase64.black : backBase64.white) : (config_clear.blackMode ? clearBase64.black : clearBase64.white)}"> `; } let divDropDown = document.createElement('div'); divDropDown.className = 'h2p-dropdown-menu'; if (isDouyu) { } else if (isBilibili) { } else if (isHuya) { divDropDown.style += 'left: -147px;'; } divDropDown.innerHTML += ` <div id="h2p-div-clearMode-select" style="width: 100%;"> <div class="h2p-flex-main-center h2p-item-100p" style="margin-bottom: 5px;"> <div class="h2p-flex-main-start h2p-item-50p"> <input id="h2p-input-clearMode-nav" type="checkbox"> <span>导航栏</span> </div> <div class="h2p-flex-main-start h2p-item-50p"> <input id="h2p-input-clearMode-info" type="checkbox"> <span>主播信息</span> </div> </div> <div class="h2p-flex-main-center h2p-item-100p" style="margin-bottom: 5px;"> <div class="h2p-flex-main-start h2p-item-50p"> <input id="h2p-input-clearMode-aside" type="checkbox"> <span>侧边栏</span> </div> <div class="h2p-flex-main-start h2p-item-50p"> <input id="h2p-input-clearMode-gift" type="checkbox"> <span>礼物栏</span> </div> </div> <div class="h2p-flex-main-center h2p-item-100p" style="margin-bottom: 5px;"> <div class="h2p-flex-main-start h2p-item-50p"> <input id="h2p-input-clearMode-bar" type="checkbox"> <span>弹幕栏</span> </div> <div class="h2p-flex-main-start h2p-item-50p"> <input id="h2p-input-clearMode-play" type="checkbox"> <span>播放器</span> </div> </div> </div> `; div.appendChild(divDropDown); let INVL_render = setInterval(() => { if ($H2P('img#h2p-img-clearMode')) { clearInterval(INVL_render); INVL_render = null; console.log('启动完毕 : clearMode 初始化'); resolve(); return; } if (isDouyu && $H2P('div.Header-right')) { $H2P('div.Header-right').appendChild(div); } else if (isBilibili) { if (isBilibiliHome || isBilibiliAct || isBilibiliRank || isBilibiliVideo) { if ($H2P('ul.nav-link-ul > li:nth-child(8)')) { $H2P('ul.nav-link-ul').appendChild(div); } } else if (isBilibiliLive) { let ele = $H2P('ul.nav-link-ul > li:nth-child(8)') || $H2P('div.dp-table-cell.v-middle > a:nth-child(10)'); if (ele) { ele.parentNode.appendChild(div); } } } else if (isHuya && $H2P('div#J_duyaHeaderRight')) { $H2P('div.duya-header-bd').appendChild(div); } if (!isDouyu && !isBilibili && !isHuya) { div.style.left = '300px'; document.body.appendChild(div); } }, 500); }) .then(() => { // 清爽模式快捷键 document.addEventListener('keydown', (e) => { if (e.shiftKey && e.which == $util.keyCode.x) { $H2P('img#h2p-img-clearMode').click(); } }); $H2P('img#h2p-img-clearMode').addEventListener('click', (event) => { config_clear.clearMode = !config_clear.clearMode; $util.LS.set(LSClear, config_clear); event.currentTarget.src = config_clear.clearMode ? (config_clear.blackMode ? backBase64.black : backBase64.white) : (config_clear.blackMode ? clearBase64.black : clearBase64.white); clearMode(); }); $H2P('div#h2p-div-clearMode-select').addEventListener('click', (event) => { if (event.target.tagName.toLowerCase() !== 'input') { return; } const target = event.target; if (target.id === 'h2p-input-clearMode-nav') { config_clear.isClearNav = !config_clear.isClearNav; if (config_clear.clearMode) { clearNav(); } } else if (target.id === 'h2p-input-clearMode-info') { config_clear.isClearInfo = !config_clear.isClearInfo; if (config_clear.clearMode) { clearInfo(); } } else if (target.id === 'h2p-input-clearMode-aside') { config_clear.isClearAside = !config_clear.isClearAside; if (config_clear.clearMode) { clearAside(); } } else if (target.id === 'h2p-input-clearMode-gift') { config_clear.isClearGift = !config_clear.isClearGift; if (config_clear.clearMode) { clearGift(); } } else if (target.id === 'h2p-input-clearMode-bar') { config_clear.isClearBar = !config_clear.isClearBar; if (config_clear.clearMode) { clearBar(); } } else if (target.id === 'h2p-input-clearMode-play') { config_clear.isClearPlay = !config_clear.isClearPlay; if (config_clear.clearMode) { clearPlay(); } } $util.LS.set(LSClear, config_clear); }, false); }) .then(() => { $H2P('input#h2p-input-clearMode-nav').checked = config_clear.isClearNav; $H2P('input#h2p-input-clearMode-info').checked = config_clear.isClearInfo; $H2P('input#h2p-input-clearMode-aside').checked = config_clear.isClearAside; $H2P('input#h2p-input-clearMode-gift').checked = config_clear.isClearGift; $H2P('input#h2p-input-clearMode-bar').checked = config_clear.isClearBar; $H2P('input#h2p-input-clearMode-play').checked = config_clear.isClearPlay; }) function updateClearModeIcon () { $H2P('img#h2p-img-clearMode').src = config_clear.clearMode ? (config_clear.blackMode ? backBase64.black : backBase64.white) : (config_clear.blackMode ? clearBase64.black : clearBase64.white); } if (isBilibili && !isBilibiliLive) { return; } // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // // 取消关注 // // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // if (isDouyuFollow) { let anchorsSelected = []; new Promise((resolve, reject) => { let INVL_AddBtnCancelFollow = setInterval(() => { if ($H2P('div#filter-tab-expandable-wrapper') && !$H2P('a#h2p-a-cancelFollow')) { clearInterval(INVL_AddBtnCancelFollow); INVL_AddBtnCancelFollow = null; resolve(); } }, 500); }) .then(() => { let a_cancelFollow = document.createElement('a'); a_cancelFollow.id = 'h2p-a-cancelFollow'; a_cancelFollow.className = 'layout-Module-label'; a_cancelFollow.innerHTML = `<strong>取消关注</strong>`; $H2P('div#filter-tab-expandable-wrapper').appendChild(a_cancelFollow); }) .then(() => { $H2P('a#h2p-a-cancelFollow').addEventListener('click', () => { let anchorSelected = $H2P('li.layout-Cover-item div.DyLiveCover-selectArea.is-active', false); anchorSelected.forEach(anchor => { let anchorHref = anchor.nextSibling.href; const anchorName = (anchor.nextSibling.querySelector('div.DyLiveCover-content div.DyLiveCover-userName') || anchor.nextSibling.querySelector('div.DyLiveRecord-content div.DyLiveRecord-userName')).textContent if (!anchorHref || anchorHref.length == 0) { anchorHref = anchor.parentNode.href; } let anchorId = anchorHref.split('/').pop(); anchorsSelected.push({ anchorId, anchorName }); }); console.log(anchorsSelected); setTO_cancelFollow(); }); }) .catch(error => { console.log(error); }) function setTO_cancelFollow () { if (anchorsSelected && anchorsSelected.length > 0) { for (let i = 0; i < anchorsSelected.length; i++) { let { anchorId, anchorName } = anchorsSelected[i]; setTimeout(() => { cancelFollow(anchorId, anchorName); }, (i + 1) * 1000); } } } function cancelFollow (anchorId, anchorName) { fetch(`https://www.douyu.com/room/follow/cancel_confuse/${anchorId}`, { method: 'POST' }) .then(res => res.json()) .then(res => { if (res && 'error' in res && res.error === 0) { console.log(`成功取消关注主播 : ${anchorName}`); $notifyMgr.createNotify({ msg: `成功取消关注主播 : ${anchorName}`, type: $notifyMgr.type.success }); let parentEle = $H2P(`a[href="/${anchorId}"]`).parentNode; // 从主播 id 找到主播信息所在 ele 的根节点 while (!parentEle.classList.contains('layout-Cover-item') && parentEle.tagName.toLowerCase() !== 'body') { parentEle = parentEle.parentNode; } if (parentEle.classList.contains('layout-Cover-item') && parentEle.tagName.toLowerCase() !== 'body') { parentEle.remove(); } } else { console.log(`取消关注主播 : ${anchorId} 失败`); } }); } return; } // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // // 全局变量 // // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // let userInfo = { nickName : '', // 昵称 isAnchorFan : false, // 是否拥有主播的粉丝牌 }; let roomInfo = { id : '', showT : 0, online : 0, } // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // // 主播信息获取 // // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // 获取 roomInfo.id let regNums = /\d+/; if (regNums.test($H2P('head > title').textContent)) { roomInfo.id = regNums.exec($H2P('head > title').textContent)[0]; } else { roomInfo.id = regNums.exec(location.href) ? regNums.exec(location.href)[0] : location.href.split('/www.huya.com/').pop(); } const LSInfo = 'h2p-DY-config-info'; let config_info = $util.LS.init(LSInfo, { anchorFanUpdatedTime: '', anchorFanRooms: {}, showTs: {}, }); if (false) { // 获取在线人数 let urlId = isDouyuTopic ? location.href.split('=').pop() : roomInfo.id; fetch(`https://bojianger.com/data/api/common/search.do?keyword=${urlId}`) .then(res => res.json()) .then(res => { try { if (res.data) { if (res.data.online) { roomInfo.online = Number(res.data.online); } else if (res.data.anchorVo) { roomInfo.online = Number(res.data.anchorVo.audience_count); } } else { let res = JSON.parse(JSON.stringify(res)); roomInfo.online = Number(res.split('online":')[1].split(',')[0]); } console.log(`Succeed getting online: ${roomInfo.online}`); $notifyMgr.createNotify({ msg: `成功获取在线人数: ${roomInfo.online}`, type: $notifyMgr.type.success }) } catch (error) { console.log(error); console.log('Fail to get online'); $notifyMgr.createNotify({ msg: `获取在线人数失败`, type: $notifyMgr.type.error }) } }); // 获取直播时间 let showTs = {}; if (Array.isArray(config_info.showTs)) { config_info.showTs = {}; $util.LS.set(LSInfo, config_info); } else { showTs = config_info.showTs || {}; } let [showT, getT] = [0, 0]; if (showTs[roomInfo.id]) { showT = $util.timeMS(showTs[roomInfo.id].showT); getT = $util.timeMS(showTs[roomInfo.id].getT); } // 获取时间 < 6h if (((Date.now() - getT) / 3600000.0) < 6) { roomInfo.showT = showT; roomInfo.getT = getT; console.log(`Succeed getting anchor showTime: ${new Date(showT).$formatTime()}`); $notifyMgr.createNotify({ msg: `成功获取直播时间: ${new Date(showT).$formatTime()}`, type: $notifyMgr.type.success }); } else { fetch('https://www.douyu.com/betard/' + roomInfo.id) .then(res => res.json()) .then(res => { try { if (res) { if (res.cache_time) { roomInfo.showT = $util.timeMS(res.cache_time); } else { let r = res.split('"cache_time":')[1]; let showT = r.substr(0, r.indexOf(',')); roomInfo.showT = $util.timeMS(showT); } config_info.showTs[roomInfo.id] = { 'showT' : roomInfo.showT, "getT" : Date.now() }; console.log(`Succeed getting anchor showTime: ${new Date(roomInfo.showT).$formatTime()}`); $notifyMgr.createNotify({ msg: `成功获取直播时间: ${new Date(roomInfo.showT).$formatTime()}`, type: $notifyMgr.type.success }); $util.LS.set(LSInfo, config_info); } else { console.log('Fail to get anchor showTime.') } } catch (error) { console.log(error); console.log('Fail to get anchor showTime.') } }); } // 根据 cookie 获取用户昵称 let cookies = document.cookie.split(/;\s/g); for (let i = 0; i < cookies.length; i++) { let cookie = cookies[i]; let keyVal = cookie.split('='); if (keyVal && keyVal.length == 2 && keyVal[0] == 'acf_nickname') { userInfo.nickName = keyVal[1]; break; } } // 自动获取已有粉丝牌的主播 if (config_info.anchorFanUpdatedTime !== new Date().$formatDate()) { new Promise((resolve, reject) => { let iframe = document.createElement('iframe'); iframe.id = 'h2p-fansBadgeList'; iframe.style = 'display: none;' iframe.src = '/member/cp/getFansBadgeList'; document.body.appendChild(iframe); setTimeout(resolve, 250); }) .then(() => { let iframe = $H2P('iframe#h2p-fansBadgeList'); iframe.addEventListener('load', () => { // 获取有粉丝牌的主播房间号 config_info.anchorFanRooms = {}; let idoc = iframe.contentWindow.document; let ele_anchors = Array.from(idoc.querySelectorAll('table.aui_room_table.fans-badge-list > tbody > tr')); for ( let i = 0; i < ele_anchors.length; i++ ) { let ele = ele_anchors[i]; let anchorURL = ele.querySelector('td:nth-child(2)').querySelector('a').getAttribute('href'); let anchorName = ele.querySelector('td:nth-child(2)').querySelector('a').textContent; let anchorRoom = ele.getAttribute('data-fans-room'); let anchorUp = Number(ele.querySelector('td:nth-child(4)').querySelector('span').textContent); config_info.anchorFanRooms[anchorRoom] = {anchorName, anchorURL, anchorUp}; } config_info.anchorFanUpdatedTime = new Date().$formatDate(); $util.LS.set(LSInfo, config_info); console.log('有粉丝牌的主播房间号'); console.log(config_info.anchorFanRooms); let anchorRoom= location.href.split('/').pop(); userInfo.isAnchorFan = anchorRoom in config_info.anchorFanRooms; setTimeout(() => { $H2P('iframe#h2p-fansBadgeList').remove(); }, 2000); }); }) .catch(error => console.log(error)); } else { console.log('今日已获取已有粉丝牌的主播'); } new Promise((resolve, reject) => { // 主播热度、在线人数、直播时长 let divBar = document.createElement('div'); divBar.id = 'h2p-div-clear-anchorHot'; divBar.classList = 'h2p-flex-main-start h2p-h-100p'; divBar.style = 'padding: 3px 10px 0; margin: 0;'; // divBar.innerHTML = ` // <div class="Title-blockInline h2p-item-33p"> // <a id="a-anchorHot" class="Title-anchorHot" title="直播热度"> // <i class="Title-anchorHotIcon" style="margin-top: -4px"> // <svg style="width: 16px; height: 16px;"> // <use xlink:href="#hot_84f8212"></use> // </svg> // </i> // <div class="Title-anchorText" style="margin-left: 2px;">0</div> // </a> // </div> // <div class="Title-blockInline h2p-item-33p"> // <div id="div-online" title="真实人数" style="margin-top: -7px"> // <div class="Title-anchorFriendWrapper"> // <div class="Title-row-span"> // <span class="Title-row-icon"> // <svg style="width:15px; height:15px"> // <use xlink:href="#friend_b0b6380"></use> // </svg> // </span> // <i class="Title-row-text" style="margin-left: 2px;">0</i> // </div> // </div> // </div> // </div> // <div class="Title-blockInline h2p-item-33p"> // <a id="a-anchorShowT" class="Title-anchorHot" title="直播时长"> // <div class="AnchorFriendCard-avatar is-live" style="height: 19px; border: none; margin: 2px 5px 0 -4px;"></div> // <div class="Title-anchorText" style="margin-left: 2px;">0</div> // </a> // </div> // `; let eleStyle = document.createElement('style'); eleStyle.innerHTML += ` .layout-Player-rank { top: 70px; } #js-player-barrage { top: 287px; } `; let setINVL_wait_div_announce = setInterval(() => { if ($H2P('div.layout-Player-asideMainTop') && $H2P('div.ShieldTool-content') && $H2P('div.ChatToolBar')) { clearInterval(setINVL_wait_div_announce); setINVL_wait_div_announce = null; setTimeout(() => { $H2P('div.layout-Player-announce').appendChild(divBar); document.body.appendChild(eleStyle); resolve(); }, 2000); } }, 500); }) .then(() => { setTO_showAnchorHot(); }) function setTO_showAnchorHot () { return setTimeout(() => { let anchorHot = Number($H2P('a.Title-anchorHot > div.Title-anchorText').textContent) || 0; let str_anchorHot = '' + anchorHot; if (anchorHot > 9999) { str_anchorHot = parseInt(anchorHot/10000) + 'w'; } $H2P('a#a-anchorHot > div.Title-anchorText').textContent = str_anchorHot; if (roomInfo.showT) { let showT = Date.now() - roomInfo.showT; let { h, m, s } = $util.HMS(showT); $H2P('a#a-anchorShowT > div.Title-anchorText').textContent = `${h}:${m}:${s}`; // 设置直播时长 setInterval(() => { showT += 1000; let { h, m, s } = $util.HMS(showT); $H2P('a#a-anchorShowT > div.Title-anchorText').textContent = `${h}:${m}:${s}`; }, 1000); } // 直播热度和在线人数 setInterval(() => { let anchorHot = Number($H2P('a.Title-anchorHot div.Title-anchorText').textContent) || 0; if (anchorHot > 9999) { anchorHot = Number.parseInt(anchorHot / 10000) + 'w'; } if ($H2P('a#a-anchorHot > div.Title-anchorText')) { $H2P('a#a-anchorHot > div.Title-anchorText').textContent = anchorHot; } let online = roomInfo.online; if (online > 9999) { online = Number.parseInt(online / 10000) + 'w'; } $H2P('div#div-online i.Title-row-text').textContent = online; }, 5000); }, 200); } } // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // // 🐯和面板初始化 // // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // const LSScript = 'h2p-DY-config-script'; let config_script = $util.LS.init(LSScript, { icon : '🐯' }); let viewShow_bar = false; let viewShow_config = false; let viewShow_script = false; new Promise((resolve, reject) => { // 创建元素样式 let eleStyle = document.createElement('style'); eleStyle.type = 'text/css'; eleStyle.innerHTML += ` #h2p-div-sign { width : 18px; height : 18px; display : inline-block; vertical-align: middle; } #h2p-div-sign span { font-size : 18px; cursor : pointer; } #div-DYScript input, #div-DYScript button, #div-DYScript select { outline : none; line-height : 10px; } #div-DYScript { position : absolute; bottom : ${isBilibiliLive ? 147 : 1}px; width : calc(100%); border : none; margin : 0 0 0 -1px; box-shadow : #c7c7c7 0 -5px 5px 0; display : flex; flex-flow : row wrap; z-index : 999; } #div-DYScript .h2p-div-inlinepanel { width : calc(100% - 20px); padding : 10px; border-width : 0 0 1px 0; font-family : WeibeiSC-Bold, STKaiti; font-size : 16px; background : #f5f5f5; } #div-DYScript .h2p-div-inlinetab { width : calc(100%); border-top : 1px solid #DCDCDC; border-radius : 2px; font-family : WeibeiSC-Bold, STKaiti; font-size : 16px; background : #f5f5f5; display : flex; flex-flow : row wrap; } #div-DYScript .h2p-div-layer { position : relative; width : 100%; height : 24px; } #div-DYScript .h2p-div-layer-half { position : absolute; width : 50%; height : 24px; } #div-DYScript .h2p-input-normal { height : 22px; padding : 0px 5px; border : 1px solid #708090; border-radius : 5px; font-size : 13px; } #div-DYScript .h2p-input-disable { background : #DCDCDC; cursor : default; } #div-DYScript .h2p-input-able { background : white; cursor : text; } #div-DYScript .h2p-div-tab { display : flex; width : 50%; height : 25px; padding : 2px 0; justify-content : center; align-items : center; } #div-DYScript .h2p-div-tab:hover { cursor : pointer; background : #DDDDDD; } #div-DYScript .h2p-hover-pointer:hover { cursor : pointer; background : #DDDDDD; } .h2p-bg-close { background : #00ddbb } .h2p-bg-close:hover{ background : #00ccaa } .h2p-bg-open { background : #99aaff } .h2p-bg-open:hover { background : #8899cc } div#div-DYScript button { font-family: inherit; } `; document.head.appendChild(eleStyle); // 弹幕框上的 🐯 let div_sign = undefined; div_sign = document.createElement('div'); if (isDouyu) { div_sign.id = 'h2p-div-sign'; div_sign.style = 'margin: -8px 0 0 -3px;'; div_sign.title = '斗鱼脚本'; div_sign.innerHTML = `<span id="h2p-span-DYScript">${config_script.icon}</span>`; } else if (isHuya) { div_sign.id = 'h2p-div-sign'; div_sign.classList = 'room-chat-tool'; div_sign.style = 'font-size: 21px; line-height: 21px;'; div_sign.title = '虎牙脚本'; div_sign.innerHTML = `<span id="h2p-span-DYScript">${config_script.icon}</span>`; } else if (isBilibiliLive) { div_sign.id = 'h2p-div-sign'; div_sign.classList = 'icon-item icon-font'; div_sign.style = 'margin: -10px 5px 0 5px; display: inline-block;'; div_sign.title = 'B 站脚本'; div_sign.innerHTML = `<span id="h2p-span-DYScript">${config_script.icon}</span>`; } // 整个面板 =============================================================== let div_DYScript = document.createElement('div'); div_DYScript.id = 'div-DYScript'; div_DYScript.style = 'display: none;'; // 检查弹幕面板挂载点(斗鱼弹幕显示区域)是否加载完成 // 检查弹幕图标挂载点(斗鱼弹幕输入框)是否加载完成 let check_mountPoint_barPanel = setInterval(() => { if (isDouyu && $H2P('div.layout-Player-asideMainTop') && $H2P('div.ShieldTool-content') && $H2P('div.ChatToolBar')) { clearInterval(check_mountPoint_barPanel); check_mountPoint_barPanel = null; setTimeout(() => { $H2P('div.layout-Player-asideMainTop').appendChild(div_DYScript); $H2P('div.ChatToolBar').appendChild(div_sign); resolve(); }, 2000); } else if (isHuya && $H2P('div.room-chat-tools') && $H2P('div.room-chat-tools > .room-chat-tool') && $H2P('div#watchChat_pub')) { clearInterval(check_mountPoint_barPanel); check_mountPoint_barPanel = null; setTimeout(() => { $H2P('div#watchChat_pub').appendChild(div_DYScript); $H2P('div.room-chat-tools').appendChild(div_sign); resolve(); }, 2000); } else if (isBilibiliLive && $H2P('div.chat-history-panel') && $H2P('div.icon-left-part')) { clearInterval(check_mountPoint_barPanel); check_mountPoint_barPanel = null; setTimeout(() => { $H2P('div.chat-history-panel').appendChild(div_DYScript); $H2P('div.icon-left-part').appendChild(div_sign); resolve(); }, 2000); } else if (!isDouyu && !isHuya && !isBilibili) { clearInterval(check_mountPoint_barPanel); check_mountPoint_barPanel = null; document.body.appendChild(div_DYScript); document.body.appendChild(div_sign); resolve(); } }, 1000); }) .then(() => { $H2P('span#h2p-span-DYScript').addEventListener('click', () => { viewShow_script = !viewShow_script; $H2P('div#div-DYScript').style.display = viewShow_script ? '' : 'none'; }); }) .then(() => { let div_DYScriptTab = document.createElement('div'); div_DYScriptTab.id = 'div-DYScriptTab'; div_DYScriptTab.className = 'h2p-div-inlinetab'; div_DYScriptTab.style = 'order: 20;' div_DYScriptTab.innerHTML = ` <div id="h2p-div-tab-bar" class="h2p-div-tab" style="background: #DDDDDD;" title="发弹幕">📢</div> <div id="h2p-div-tab-config" class="h2p-div-tab" title="自动化设置">⏲️</div> `; $H2P('div#div-DYScript').appendChild(div_DYScriptTab); }) .then(() => { $H2P('div#div-DYScriptTab').addEventListener('click', (event) => { const target = event.target; viewShow_bar = target.id.endsWith('-bar'); viewShow_config = target.id.endsWith('-config'); $H2P('div#h2p-div-bar').style.display = viewShow_bar ? '' : 'none'; $H2P('div#h2p-div-config').style.display = viewShow_config ? '' : 'none'; $H2P('div#h2p-div-tab-bar').style.backgroundColor = viewShow_bar ? '#DDDDDD' : '#f5f5f5'; $H2P('div#h2p-div-tab-config').style.backgroundColor = viewShow_config ? '#DDDDDD' : '#f5f5f5'; }, false); }); // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // // 发弹幕 // // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // const LSChat = 'h2p-DY-config-chat'; let config_chat = $util.LS.init(LSChat, { invlStart : 3, invlEnd : 4, isLuck : false, luckTime : 2, isKeyRe : false, keyReBar : [], isCopy : false, copyInvl : 0, isLoop : false, loopBar : [], isSendNow : false, isSend : false, sendRooms : [], }); config_chat.isSendNow = config_chat.sendRooms.includes(roomInfo.id); let [Chat, INVL_SendBar, INVL_ShowCD] = [undefined, undefined, undefined]; let invl = 0; // 间隔时间 let luckBar = ''; // 抽奖弹幕内容 let luckCD = 0; // 弹幕抽奖活动倒计时 let luckTime = 0; // 抽奖弹幕发送次数 let Index_keyRe = 0; // 关键词回复弹幕列表已经检测的位置 let keyRes = []; // 已经回复的弹幕 ID // 初始化自动发弹幕界面 =============================================================== new Promise((resolve, reject) => { let eleStyle = document.createElement('style'); eleStyle.type = 'text/css'; eleStyle.innerHTML += ` #h2p-div-bar input[type="checkbox"] { margin : 3px; } #h2p-div-bar .h2p-input-invl { width : 23px; margin : 0 2px; } #h2p-div-bar .h2p-ta-bar-loopBar { width : calc(100% - 33px); height : 73px; padding : 5px; border : 1px solid #708090; border-radius : 5px; font-size : 13px; resize : none; font-family : inherit; } #h2p-div-bar .h2p-btn-keyRe { width : 16px; height : 16px; padding : 0; margin : 3px; border : 1px solid rgb(216, 216, 216); border-radius : 50%; background-color: white; text-align : center; } #h2p-div-bar #h2p-btn-bar-send, #h2p-div-bar #h2p-btn-bar-sendAll { line-height : 18px; font-size : 15px; width : 95%; padding : 4px 0; border : none; border-radius : 5px; cursor : pointer; transition : all 0.5s } #h2p-div-bar .h2p-btn-active { background: #ffbb77!important; } #h2p-div-bar input { font-size: 10px!important; } .sendingDisabled {} `; document.head.appendChild(eleStyle); let div = document.createElement('div'); div.id = 'h2p-div-bar'; div.className = 'h2p-div-inlinepanel'; div.style = ''; div.innerHTML += ` <!-- 发送弹幕的速度 And 倒计时 --> <div class="h2p-flex-main-center"> <div class="h2p-flex-main-start h2p-item-50p"> <label>间隔</label> <input id="h2p-input-bar-invl-start" class="h2p-input-normal h2p-input-invl sendingDisabled" placeholder="≥3" /> <span>~</span> <input id="h2p-input-bar-invl-end" class="h2p-input-normal h2p-input-invl sendingDisabled" /> <label>秒</label> </div> <div class="h2p-flex-main-end h2p-item-50p"> <input id="h2p-input-cd" class="h2p-input-normal h2p-input-disable" style="width: 32px;" disabled/> </div> </div> <!-- 是否参加弹幕抽奖 --> <div class="h2p-flex-main-center" style="display: ${isDouyu ? '' : 'none'}"> <div class="h2p-flex-main-start h2p-item-50p"> <input id="h2p-input-bar-isLuck" type="checkbox" /> <label>抽奖弹幕</label> </div> <div class="h2p-flex-main-end h2p-item-50p"> <label>抽奖发送</label> <input id="h2p-input-bar-luck-time-now" class="h2p-input-normal h2p-input-invl h2p-input-disable" disabled /> <span>/</span> <input id="h2p-input-bar-luck-time" class="h2p-input-normal h2p-input-invl sendingDisabled" style="margin-right: 0;" placeholder="≥1" value="1" /> </div> </div> <!-- 是否使用关键词自动回复 --> <div class="h2p-flex-main-center" style="margin: 0 0 8px 0; display: ${isDouyu ? '' : 'none'}"> <div class="h2p-flex-main-start h2p-item-50p"> <input id="h2p-input-bar-isKeyRe" type="checkbox" /> <label>关键词回复</label> <button id="h2p-btn-addKeyRe" class="h2p-btn-keyRe h2p-hover-pointer" title="添加关键词">+</button> </div> <div class="h2p-flex-main-end h2p-item-50p"> <select id="h2p-select-keyRe" style="width: 100%; height: 24px;"> </select> </div> </div> <div class="h2p-flex-main-center" style="display: ${isDouyu ? '' : 'none'}"> <div class="h2p-flex-main-start h2p-item-50p"> <button id="h2p-btn-delKeyRe" class="h2p-btn-keyRe h2p-hover-pointer" title="删除关键词">-</button> <input id="h2p-input-key" class="h2p-input-normal" style="width: 70%;" placeholder="关键词" /> </div> <div class="h2p-flex-main-end h2p-item-50p"> <input id="h2p-input-re" class="h2p-input-normal" style="width: 90%; padding: 0 4.2%;" placeholder="自动回复弹幕" /> </div> </div> <!-- 是否发送抄袭弹幕 --> <div class="h2p-flex-main-center"> <div class="h2p-flex-main-start h2p-item-50p"> <input id="h2p-input-bar-isCopy" type="checkbox" /> <label>抄袭弹幕</label> </div> <div class="h2p-flex-main-end h2p-item-50p"> <label>抄袭间隔</label> <input id="h2p-input-bar-copy-invl" class="h2p-input-normal" style="margin-left: 5px; width: 48px;" placeholder="0 ~ 200" value="0"/> </div> </div> <!-- 是否发送循环弹幕 --> <div class="h2p-flex-main-center" style="height: 85px;"> <input id="h2p-input-bar-isLoop" type="checkbox" /> <textarea id="h2p-ta-bar-loopBar" class="h2p-ta-bar-loopBar" placeholder="循环弹幕"></textarea> </div> <!-- 开启弹幕发送按钮 --> <div class="h2p-flex-main-center" style="margin: 0 0 5px 0;"> <div class="h2p-flex-main-start h2p-item-50p"> <button id="h2p-btn-bar-send" class="h2p-bg-close" ${isBilibili ? 'disabled' : ''}>${isBilibiliLive ? '暂不可用' : '发送(本房间)'}</button> </div> <div class="h2p-flex-main-end h2p-item-50p"> <button id="h2p-btn-bar-sendAll" class="h2p-bg-close" ${isBilibili ? 'disabled' : ''}>${isBilibiliLive ? '暂不可用' : '发送(所有)'}</button> </div> </div> `; let setINVL_wait_div_DYScript = setInterval(() => { if ($H2P('div#div-DYScript')) { clearInterval(setINVL_wait_div_DYScript); setINVL_wait_div_DYScript = null; $H2P('div#div-DYScript').appendChild(div); resolve(); } }, 500); }) // 元素绑定监听 .then(() => { let eleBar = $H2P('div#h2p-div-bar'); eleBar.addEventListener('click', (event) => { let target = event.target; if (target.id === 'h2p-input-bar-isCopy') { config_chat.isCopy = target.checked; } else if (target.id === 'h2p-input-bar-isLoop') { config_chat.isLoop = target.checked; } else if (target.id === 'h2p-input-bar-isKeyRe') { config_chat.isKeyRe = target.checked; } else if (target.id === 'h2p-input-bar-isLuck') { config_chat.isLuck = target.checked; } $util.LS.set(LSChat, config_chat); }, false) // 间隔最小值 let eleInvlStart = $H2P('input#h2p-input-bar-invl-start'); eleInvlStart.addEventListener('input', () => { eleInvlStart.value = eleInvlStart.value.replace(/[^\d]/g, '').slice(0, 3); }); eleInvlStart.addEventListener('focusout', () => { eleInvlStart.value = Math.max(eleInvlStart.value, 3); config_chat.invlStart = eleInvlStart.value; $util.LS.set(LSChat, config_chat); }); // 间隔最大值 let eleInvlEnd = $H2P('input#h2p-input-bar-invl-end'); eleInvlEnd.addEventListener('input', () => { eleInvlEnd.value = eleInvlEnd.value.replace(/[^\d]/g, '').slice(0, 3); }); eleInvlEnd.addEventListener('focusout', () => { eleInvlEnd.value = Math.max(eleInvlEnd.value, Number(eleInvlStart.value) + 1, 4); config_chat.invlEnd = eleInvlEnd.value; $util.LS.set(LSChat, config_chat); }); // 抽奖弹幕最大次数 let eleBarLuckTime = $H2P('input#h2p-input-bar-luck-time'); eleBarLuckTime.addEventListener('input', () => { eleBarLuckTime.value = eleBarLuckTime.value.replace(/[^\d]/g, '').slice(0, 2); }); eleBarLuckTime.addEventListener('focusout', () => { eleBarCopyInvl.value = Math.max(eleBarCopyInvl.value, 1); config_chat.luckTime = Number(eleBarLuckTime.value); $util.LS.set(LSChat, config_chat); }); // 添加关键词回复 let eleAddKeyRe = $H2P('button#h2p-btn-addKeyRe'); eleAddKeyRe.addEventListener('click', () => { config_chat.keyReBar.push({key: 'default', re: 'default'}); $util.LS.set(LSChat, config_chat); $H2P('select#h2p-select-keyRe').options.add(new Option('default', 'default')); $H2P('select#h2p-select-keyRe').selectedIndex = config_chat.keyReBar.length - 1; $H2P('input#h2p-input-key').value = $H2P('select#h2p-select-keyRe').selectedOptions[0].textContent; $H2P('input#h2p-input-re').value = $H2P('select#h2p-select-keyRe').selectedOptions[0].value; }); // 删除关键词回复 let eleDelKeyRe = $H2P('button#h2p-btn-delKeyRe'); eleDelKeyRe.addEventListener('click', () => { config_chat.keyReBar.splice($H2P('select#h2p-select-keyRe').selectedIndex, 1); $util.LS.set(LSChat, config_chat); $H2P('select#h2p-select-keyRe').options.remove($H2P('select#h2p-select-keyRe').selectedIndex); $H2P('input#h2p-input-key').value = $H2P('select#h2p-select-keyRe').selectedOptions[0].textContent; $H2P('input#h2p-input-re').value = $H2P('select#h2p-select-keyRe').selectedOptions[0].value; }); // 选择关键词回复 let eleSelectKeyRe = $H2P('select#h2p-select-keyRe'); eleSelectKeyRe.addEventListener('change', () => { $H2P('input#h2p-input-key').value = $H2P('select#h2p-select-keyRe').selectedOptions[0].textContent; $H2P('input#h2p-input-re').value = $H2P('select#h2p-select-keyRe').selectedOptions[0].value; }); // 修改关键词 let eleKey = $H2P('input#h2p-input-key'); eleKey.addEventListener('keyup', () => { config_chat.keyReBar[$H2P('select#h2p-select-keyRe').selectedIndex].key = eleKey.value; $H2P('select#h2p-select-keyRe').selectedOptions[0].textContent = eleKey.value; }); eleKey.addEventListener('focusout', () => { if (!eleKey.value) { eleKey.value = 'default'; config_chat.keyReBar[$H2P('select#h2p-select-keyRe').selectedIndex].key = eleKey.value; $H2P('select#h2p-select-keyRe').selectedOptions[0].textContent = eleKey.value; } $util.LS.set(LSChat, config_chat); }); // 修改回复 let eleRe = $H2P('input#h2p-input-re'); eleRe.addEventListener('keyup', () => { config_chat.keyReBar[$H2P('select#h2p-select-keyRe').selectedIndex].re = eleRe.value; $H2P('select#h2p-select-keyRe').selectedOptions[0].value = eleRe.value; }); eleRe.addEventListener('focusout', () => { if (!eleRe.value) { eleRe.value = 'default'; config_chat.keyReBar[$H2P('select#h2p-select-keyRe').selectedIndex].re = eleRe.value; $H2P('select#h2p-select-keyRe').selectedOptions[0].value = eleRe.value; } $util.LS.set(LSChat, config_chat); }); // 抄袭弹幕最大间隔 let eleBarCopyInvl = $H2P('input#h2p-input-bar-copy-invl'); eleBarCopyInvl.addEventListener('input', () => { eleBarCopyInvl.value = eleBarCopyInvl.value.replace(/[^\d]/g, '').slice(0, 3); }); eleBarCopyInvl.addEventListener('focusout', () => { eleBarCopyInvl.value = Math.min(eleBarCopyInvl.value, 200); config_chat.copyInvl = Number(eleBarCopyInvl.value); $util.LS.set(LSChat, config_chat); }); // 循环弹幕 let eleLoop = $H2P('textarea#h2p-ta-bar-loopBar'); eleLoop.addEventListener('focusout', () => { if (eleLoop.value && eleLoop.value.replace(/\s/g, '')) { config_chat.loopBar = eleLoop.value.split('\n'); $util.LS.set(LSChat, config_chat); } }); // 发送按钮 let eleSend = $H2P('button#h2p-btn-bar-send'); eleSend.addEventListener('click', () => { config_chat.isSendNow = !config_chat.isSendNow; $H2P('div#h2p-div-tab-bar').textContent = config_chat.isSendNow ? '🔥' : '📢'; $H2P('input.sendingDisabled', false).forEach(ele => { ele.classList.toggle('h2p-input-disable'); ele.disabled = !ele.disabled; }); clearTimeout(INVL_SendBar); INVL_SendBar = null; clearInterval(INVL_ShowCD); INVL_ShowCD = null; if (config_chat.isSendNow) { setINVL_SendBar(); eleSend.classList.add('h2p-bg-open'); eleSend.textContent = "发送中(本房间)"; if (!config_chat.sendRooms.includes(roomInfo.id)) { config_chat.sendRooms.push(roomInfo.id); } } else { $H2P('input#h2p-input-cd').value = ''; $H2P('input#h2p-input-bar-luck-time-now').value = ''; eleSend.classList.remove('h2p-bg-open'); eleSend.textContent = "发送(本房间)"; luckCD = 0; luckBar = undefined; luckTime = 0; let index = config_chat.sendRooms.indexOf(roomInfo.id); config_chat.sendRooms = [...config_chat.sendRooms.slice(0, index), ...config_chat.sendRooms.slice(index+1)]; } $util.LS.set(LSChat, config_chat); }, false); // 发送所有按钮 let eleSendAll = $H2P('button#h2p-btn-bar-sendAll'); eleSendAll.addEventListener('click', () => { config_chat.isSend = !config_chat.isSend; if (config_chat.isSend) { eleSendAll.classList.add('h2p-bg-open'); eleSendAll.textContent = "发送中(所有)"; } else { eleSendAll.classList.remove('h2p-bg-open'); eleSendAll.textContent = "发送(所有)"; } if ((config_chat.isSend && !config_chat.isSendNow) || (!config_chat.isSend && config_chat.isSendNow)) { eleSend.click(); } $util.LS.set(LSChat, config_chat); }, false); }) .catch(error => console.log(error)) // 读取配置参数 .then(() => { $H2P('input#h2p-input-bar-isLuck').checked = config_chat.isLuck || false; $H2P('input#h2p-input-bar-luck-time').value = config_chat.luckTime || 1; $H2P('input#h2p-input-bar-invl-start').value = config_chat.invlStart || ''; $H2P('input#h2p-input-bar-invl-end').value = config_chat.invlEnd || ''; $H2P('input#h2p-input-bar-isKeyRe').checked = config_chat.isKeyRe || false; if (!config_chat.keyReBar || !Array.isArray(config_chat.keyReBar)) { config_chat.keyReBar = []; } for (let {key, re} of config_chat.keyReBar) { $H2P('select#h2p-select-keyRe').options.add(new Option(key, re)); } $H2P('input#h2p-input-bar-isCopy').checked = config_chat.isCopy || false; $H2P('input#h2p-input-bar-copy-invl').value = config_chat.copyInvl || '', $H2P('input#h2p-input-bar-isLoop').checked = config_chat.isLoop || false; $H2P('textarea#h2p-ta-bar-loopBar').value = Array.isArray(config_chat.loopBar) ? config_chat.loopBar.join('\n') : ''; if (config_chat.isSend) { config_chat.isSendNow = false; config_chat.isSend = false; $H2P('button#h2p-btn-bar-sendAll').click(); } else if (config_chat.isSendNow) { config_chat.isSendNow = false; $H2P('button#h2p-btn-bar-send').click(); } if (!Chat) { Chat = setBar(); } }) .then(() => { if (config_chat.keyReBar && config_chat.keyReBar.length > 0) { $H2P('input#h2p-input-key').value = $H2P('select#h2p-select-keyRe').selectedOptions[0].textContent; $H2P('input#h2p-input-re').value = $H2P('select#h2p-select-keyRe').selectedOptions[0].value; } }) .catch(error => { console.log(error); }) function getBar () { let barrage = undefined; // 抽奖弹幕 if (config_chat.isLuck && $H2P('div.LotteryDrawEnter-desc')) { // 计算目前倒计时 let luckCD_now = Number($H2P('div.LotteryDrawEnter-desc').textContent.split(':').reduce((m, s) => Number(m) * 60 + Number(s))); // 新一轮抽奖 if (luckCD_now > luckCD) { luckBar = undefined; luckTime = 0; // 显示抽奖内容 $H2P('div.LotteryDrawEnter-enter').click(); try { // 获取抽奖弹幕条件 let barREQM = $H2P('div.ULotteryStart-joinRule').textContent.split(':')[1]; const REQMs = ['发弹幕', '发弹幕+关注主播']; // 不是赠送、礼物、福袋、数字、盛典 let regex = /[\u8d60\u9001\u793c\u7269\u798f\u888b\d\u76db\u5178]+/g; if (barREQM.search(regex) < 0) { if (REQMs.indexOf(barREQM) > -1 || (userInfo.isAnchorFan && barREQM.includes('成为粉丝'))) { // 一键参与 $H2P('div.ULotteryStart-joinBtn').click(); // 获取抽奖弹幕内容 luckBar = $H2P('div.ULotteryStart-demandDanmu > span:nth-child(1)').textContent; luckBar = luckBar.split(' : ')[1] ? luckBar.split(' : ')[1] : luckBar.split(' : ')[0]; if (luckBar.includes('复制')) { luckBar = luckBar.slice(0, -2); } if (luckBar.includes('弹幕:')) { luckBar = luckBar.slice(3); } } } else { console.log('出现:赠送、礼物、福袋、数字、盛典'); } } catch (error) { console.log(error); } finally { $H2P('span.LotteryContainer-close').click(); } } barrage = luckTime < config_chat.luckTime ? luckBar : undefined; if (barrage) { if ($H2P('div.ChatSend-button') && $H2P('div.ChatSend-button').classList.contains('is-gray')) { console.log(`发送弹幕冷却中 : ${$H2P('div.ChatSend-button').textContent}`); } else { luckTime++; $H2P('input#h2p-input-bar-luck-time-now').value = luckTime; console.log(`抽奖弹幕 : ${barrage},剩余时间 ${luckCD}`); } } luckCD = Number.isNaN(luckCD_now) ? 0 : luckCD_now; } // 关键词弹幕回复 if (!barrage && config_chat.isKeyRe && Array.isArray(config_chat.keyReBar)) { let bars = $H2P('ul#js-barrage-list > li', false); for (let i = Index_keyRe; i < bars.length && !barrage; i++) { Index_keyRe++; let ele = bars[i]; try { let bar_check = ele.querySelector('span[class^="Barrage-content"]').textContent.replace(/\s/g, ''); if (ele.querySelector('span[class^="Barrage-nickName"]').title !== userInfo.nickName) { for (let j = 0; j < config_chat.keyReBar.length; j++) { let keyRe = config_chat.keyReBar[j]; if (bar_check.includes(keyRe.key)) { if (!keyRes.includes(ele.id)) { barrage = keyRe.re; keyRes.push(ele.id); while (keyRes.length > 200) { keyRes.shift; } console.log(`关键词弹幕回复 : ${barrage}`); break; } } } } } catch (error) { console.log(error); } } if (Index_keyRe >= bars.length) { Index_keyRe = 0; } } // 抄袭弹幕 if (!barrage && config_chat.isCopy) { let elePath = isDouyu ? 'ul#js-barrage-list > li' : isHuya ? 'ul#chat-room__list > li' : isBilibiliLive ? 'div#chat-items > div' : ''; let bars = $H2P(elePath, false); let index = 0; if (config_chat.copyInvl) { if (config_chat.copyInvl > 0 && config_chat.copyInvl < bars.length) { index = bars.length - config_chat.copyInvl; } else { index = bars.length - 1; } } let elePath2 = isDouyu ? 'span[class^="Barrage-content"]' : isHuya ? 'span.msg' : isBilibiliLive ? 'span.danmaku-content' : ''; barrage = bars[index].querySelector(elePath2).textContent.replace(/\s/g, ''); } // 循环弹幕 if (!barrage && config_chat.isLoop && Array.isArray(config_chat.loopBar)) { let index = Math.floor(Math.random() * (config_chat.loopBar.length)); barrage = config_chat.loopBar[index]; } return barrage ? barrage : ''; } function setINVL_SendBar () { let {invlStart = 2, invlEnd = 2} = config_chat; let [start, end] = [Number(invlStart), Number(invlEnd)]; invl = Math.floor(Math.random() * (end - start)) + start; setINVL_ShowCD(invl); INVL_SendBar = setTimeout(() => { let barrage = getBar(); if (barrage) { console.log(`弹幕: ${barrage}`); Chat.setMsg(barrage); Chat.sendMsg(); } setINVL_SendBar(); }, invl * 1000); } function setINVL_ShowCD (invl) { new Promise((resolve, reject) => { clearInterval(INVL_ShowCD); INVL_ShowCD = null; resolve(invl); }).then((invl)=> { let cd = invl + 0.3; INVL_ShowCD = setInterval(() => { cd = Math.max(Math.floor((cd - 0.1) * 10) / 10.0, 0); $H2P('input#h2p-input-cd').value = cd; }, 100); }) } function setBar () { let [eleSetBar, eleSendBar] = [undefined, undefined]; return { setMsg : (msg)=>{ if (!eleSetBar) { let elePath = isDouyu ? '.ChatSend-txt' : isHuya ? '#pub_msg_input' : isBilibiliLive ? 'textarea.chat-input.border-box' : ''; eleSetBar = $H2P(elePath); } if (eleSetBar && msg) { eleSetBar.value = msg; } }, sendMsg : ()=>{ if (!eleSendBar) { let elePath = isDouyu ? '.ChatSend-button' : isHuya ? '#msg_send_bt' : isBilibiliLive ? 'div.live-skin-coloration-area > button.bl-button.live-skin-highlight-button-bg > span' : ''; eleSendBar = $H2P(elePath); } if (eleSendBar && eleSetBar.value) { if (isHuya) { eleSendBar.classList.add('enable'); } else if (isBilibiliLive) { $H2P('div.live-skin-coloration-area > button.bl-button.live-skin-highlight-button-bg').disabled = false; } eleSendBar.click(); } } } } // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // // 快捷键设置 // // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // document.addEventListener('keydown', (e) => { // ESC 按键 if (e.which === 27) { if (config_tool.wideMode) $H2P('button#h2p-btn-config-wideMode').click(); else if (config_tool.fullMode) $H2P('button#h2p-btn-config-fullMode').click(); } // shift a if (e.shiftKey && e.which == $util.keyCode.a) { if ($H2P('span#h2p-span-DYScript')) { if (!viewShow_script) { $H2P('span#h2p-span-DYScript').click(); $H2P('div#h2p-div-tab-bar').click(); } else { if (viewShow_bar) { $H2P('span#h2p-span-DYScript').click(); } else { $H2P('div#h2p-div-tab-bar').click(); } } } } // shift s else if (e.shiftKey && e.which == $util.keyCode.s) { if ($H2P('span#h2p-span-DYScript')) { if (!viewShow_script) { $H2P('span#h2p-span-DYScript').click(); $H2P('div#h2p-div-tab-config').click(); } else { if (viewShow_config) { $H2P('span#h2p-span-DYScript').click(); } else { $H2P('div#h2p-div-tab-config').click(); } } } } // 清爽模式快捷键 else if (e.shiftKey && e.which == $util.keyCode.o) { $H2P('button#h2p-btn-config-wideMode').click(); } else if (e.shiftKey && e.which == $util.keyCode.p) { $H2P('button#h2p-btn-config-fullMode').click(); } // 清空弹幕 else if (e.shiftKey && e.which == $util.keyCode.e) { let elePath = isDouyu ? 'a.Barrage-toolbarClear' : 'p.clearBtn'; $H2P(elePath).click(); } // 锁定弹幕 else if (e.shiftKey && e.which == $util.keyCode.w) { let elePath = isDouyu ? 'a.Barrage-toolbarLock' : 'p.lockBtn'; $H2P(elePath).click(); } }); // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // // 自动化设置 // // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // 暂停 let auto_pausePlay = () => { let INVL_checkIconReady = setInterval(() => { let elePathIn = isDouyu ? 'div[class="pause-c594e8"]' : isHuya ? 'div.player-pause-btn' : isBilibiliAct ? 'button.blpui-btn.icon-btn[data-title="暂停"]' : ''; let elePathOut =isDouyu ? 'div[class="play-8dbf03"]' : isHuya ? 'div.player-play-btn' : isBilibiliLive ? 'button.blpui-btn.icon-btn[data-title="播放"]' : ''; if ($H2P(elePathOut)) { clearInterval(INVL_checkIconReady); INVL_checkIconReady = null; console.log('启动完毕 : 暂停'); return; } if ($H2P(elePathIn)) { $H2P(elePathIn).click(); } }, 500); } // 静音 let auto_hideSound = () => { let INVL_checkIconReady = setInterval(() => { let elePathIn = isDouyu ? 'div[class="volume-8e2726"]' : isHuya ? 'div.player-sound-on' : isBilibiliLive ? 'button.blpui-btn.icon-btn[data-title="静音"]' : '';; let elePathOut =isDouyu ? 'div[class="volume-silent-3eb726"]' : isHuya ? 'div.player-sound-off' : isBilibiliLive ? 'button.blpui-btn.icon-btn[data-title="取消静音"]' : ''; if ($H2P(elePathOut)) { clearInterval(INVL_checkIconReady); INVL_checkIconReady = null; console.log('启动完毕 : 静音'); return; } if ($H2P(elePathIn)) { $H2P(elePathIn).click(); } }, 500); } // 禁止弹幕 let auto_hideBar = () => { let INVL_checkIconReady = setInterval(() => { let elePathIn = isDouyu ? 'div[class="showdanmu-42b0ac"]' : isHuya ? 'div.danmu-show-btn' : isBilibiliLive ? 'button.blpui-btn.icon-btn[data-title="隐藏弹幕"]' : ''; let elePathOut =isDouyu ? 'div[class="hidedanmu-5d54e2"]' : isHuya ? 'div.danmu-hide-btn' : isBilibiliLive ? 'button.blpui-btn.icon-btn[data-title="显示弹幕"]' : ''; if ($H2P(elePathOut)) { clearInterval(INVL_checkIconReady); INVL_checkIconReady = null; console.log('启动完毕 : 禁止弹幕'); return; } if ($H2P(elePathIn)) { $H2P(elePathIn).click(); } }, 500); } // 默认画质 let FT_showDef = true; // first time 点击默认画质 let auto_showDef = () => { let INVL_checkIconReady = setInterval(() => { let elePath = isDouyu ? 'div.tip-e3420a > ul > li' : isHuya ? 'div.player-videoline-videotype > ul > li' : isBilibiliLive ? 'div.bilibili-live-player-video-controller-btn-item.bilibili-live-player-video-controller-switch-quality-btn div.blpui-btn.text-btn.no-select.html-tip-parent div.blpui-btn.text-btn.no-select' : ''; let elePathShow = isDouyu ? 'label.textLabel-df8d16' : isHuya ? 'span.player-videotype-cur' : isBilibiliLive ? 'div.blpui-btn.text-btn.no-select.html-tip-parent span' : ''; let curShow = $H2P(elePath, false) && $H2P(elePath, false).length > 0 ? (config_tool.show0 ? $H2P(elePath, false).pop().textContent : $H2P(elePath, false).shift().textContent) : ''; if ($H2P(elePathShow) && $H2P(elePathShow).textContent === curShow) { clearInterval(INVL_checkIconReady); INVL_checkIconReady = null; console.log(`启动完毕 : ${config_tool.show0 ? '最低' : '最高'}画质`); return; } if ($H2P(elePath, false) && $H2P(elePath, false).length > 0) { if (isHuya && FT_showDef) { setTimeout(() => { if (config_tool.show0) { $H2P(elePath, false).pop().click(); } else if (config_tool.show9) { $H2P(elePath, false)[0].click(); } FT_showDef = false; }, 1000); } else { if (config_tool.show0) { $H2P(elePath, false).pop().click(); } else if (config_tool.show9) { $H2P(elePath, false)[0].click(); } } } }, 500); } let FT_wideMode = true; function wideMode () { console.log(`${config_tool.wideMode ? '启动' : '关闭'} : 宽屏模式`); let elePathIn = isDouyu ? 'div[class="wfs-2a8e83"]' : isHuya ? 'span#player-fullpage-btn[title="剧场模式"]' : isBilibiliLive ? 'button.blpui-btn.icon-btn[data-title="网页全屏"]' : ''; let elePathOut =isDouyu ? 'div[class="wfs-exit-180268"]' : isHuya ? 'span#player-fullpage-btn[title="退出剧场"]' : isBilibiliLive ? 'button.blpui-btn.icon-btn[data-title="退出网页全屏"]' : ''; if (config_tool.wideMode) { let start = new Date().getTime(); let setINVL_waitWideCoin = setInterval(() => { if ($H2P(elePathOut)) { clearInterval(setINVL_waitWideCoin); setINVL_waitWideCoin = null; console.log('启动完毕 : 宽屏模式'); return; } if ($H2P(elePathIn)) { if (isBilibiliLive && FT_wideMode) { setTimeout(() => { $H2P(elePathIn).click(); FT_wideMode = false; }, 1000); } else { $H2P(elePathIn).click(); } } else { // 等待最长 5min if ((new Date().getTime() - start) / 1000 > 300) { clearInterval(setINVL_waitWideCoin); setINVL_waitWideCoin = null; } } }, 500); } else { if ($H2P(elePathOut)) { $H2P(elePathOut).click(); } } } let FT_fullMode = true; function fullMode () { console.log(`${config_tool.fullMode ? '启动' : '关闭'} : 网页全屏`); let elePathIn = isDouyu ? 'div[class="fs-781153"]' : isHuya ? 'span#player-fullscreen-btn[title="全屏"]' : isBilibiliLive ? 'button.blpui-btn.icon-btn[data-title="全屏模式"]' : ''; let elePathOut =isDouyu ? 'div[class="fs-exit-b6e6a7"]' : isHuya ? 'span#player-fullscreen-btn[title="退出全屏"]' : isBilibiliLive ? 'button.blpui-btn.icon-btn[data-title="退出全屏"]' : ''; if (config_tool.fullMode) { let start = new Date().getTime(); let setINVL_waitFullCoin = setInterval(() => { if ($H2P(elePathOut)) { clearInterval(setINVL_waitFullCoin); setINVL_waitFullCoin = null; console.log('启动完毕 : 网页全屏'); return; } if ($H2P(elePathIn)) { if (isBilibiliLive && FT_fullMode) { setTimeout(() => { $H2P(elePathIn).click(); FT_fullMode = false; }, 1000); } else { $H2P(elePathIn).click(); } } else { // 等待最长 5min if ((new Date().getTime() - start) / 1000 > 300) { clearInterval(setINVL_waitFullCoin); setINVL_waitFullCoin = null; } } }, 500); } else { if ($H2P(elePathOut)) { $H2P(elePathOut).click(); } } } // 自动#取观看鱼丸 let INVL_autoGetFB = undefined; let auto_getFB = () => { if (INVL_autoGetFB) { return; } let isHuntTreasure = config_tool.findTreasure === new Date().$formatDate(); if (isDouyu) { return INVL_autoGetFB = setInterval(() => { if (!isHuntTreasure) { console.log('开始寻宝'); new Promise((resolve, reject) => { let eleStyle = document.createElement('style'); eleStyle.id = `h2p-style-fb`; eleStyle.innerHTML = `.FTP { visibility: hidden; }`; if (!$H2P(`style#h2p-style-fb`)) { document.body.appendChild(eleStyle); } setTimeout(resolve, 500); }) .then(() => { // 打开#取鱼丸界面 if ($H2P('div.FishpondEntrance-icon') && !$H2P('div.FTP')) { $H2P('div.FishpondEntrance-icon').click(); $H2P('div.FTP-handle-btnBottom', false).filter(ele => ele.textContent === '寻宝')[0].click(); } }) .then(() => { if ($H2P('div.FTP-userInfo > span')) { let count = Number.parseInt($H2P('div.FTP-userInfo > span').textContent.split('\/')[0]); let fishFood = Number.parseInt($H2P('div.FTP-userInfo > span:last-child').textContent.split(':')[1]); if (!isNaN(count) && !isNaN(fishFood)) { if (fishFood < 60) { isHuntTreasure = true; $notifyMgr.createNotify({ msg: `鱼粮不足: ${fishFood},本网页取消寻宝`, type: $notifyMgr.type.warn }); console.log(`鱼粮不足: ${fishFood},本网页取消寻宝`); } else { if (count === 3) { isHuntTreasure = true; config_tool.findTreasure = new Date().$formatDate(); $util.LS.set(LSConfig, config_tool); $notifyMgr.createNotify({ msg: `寻宝完毕`, type: $notifyMgr.type.success }); console.log(`寻宝完毕`); } else { console.log(`寻宝第 ${count+1} 次`); $H2P('div.FTP-turntableStartBtn').click(); } } } } }) .catch(error => { console.log(error); }) .finally(() => { if ($H2P('span.FTP-close')) { $H2P('span.FTP-close').click(); } $H2P(`style#h2p-style-fb`).remove(); }) } else { // 观看鱼丸元素存在并且有未#取的鱼丸 if ($H2P('div.FishpondEntrance-num.is-entrance') && Number($H2P('div.FishpondEntrance-num.is-entrance').textContent) > 0) { for (let i = 0; i < 3; i++) { setTimeout(() => { new Promise((resolve, reject) => { let eleStyle = document.createElement('style'); eleStyle.id = `h2p-style-fb-${i}`; eleStyle.innerHTML = `.FTP { visibility: hidden; }`; if (!$H2P(`style#h2p-style-fb-${i}`)) { document.body.appendChild(eleStyle); } setTimeout(resolve, 500); }) .then(() => { // 打开#取鱼丸界面 if ($H2P('div.FishpondEntrance-icon') && !$H2P('div.FTP')) { $H2P('div.FishpondEntrance-icon').click(); } // 每日活跃、每周活跃 $H2P('span.FTP-btn', false)[i].click(); $H2P('div.FTP-singleTask-btn.is-finished', false).forEach(ele => ele.click()); // 鱼塘 $H2P('div.FTP-bubble-progressText.is-complete', false).forEach(ele => ele.click()); }) .catch(error => { console.log(error); } ) .finally(() => { if ($H2P('span.FTP-close')) { $H2P('span.FTP-close').click(); } $H2P(`style#h2p-style-fb-${i}`).remove(); }) }, 1500 * i); } } } }, 5000); } else if (isHuya) { if (!isHuntTreasure) { INVL_autoGetFB = setInterval(() => { if ($H2P('div.chest-award-count') && Number($H2P('div.chest-award-count').textContent) > 0) { let eles = $H2P('p.player-box-stat3', false).filter(ele => ele.style.visibility == 'visible'); for (let i = 0; i < eles.length; i++) { setTimeout(() => { eles[i].click(); }, 500 * i) } } else if ($H2P('p.player-box-stat4', false).filter(ele => ele.style.visibility == 'visible').length == 6) { clearInterval(INVL_autoGetFB); isHuntTreasure = true; config_tool.findTreasure = new Date().$formatDate(); $util.LS.set(LSConfig, config_tool); } }, 5000); } } else if (isBilibiliLive) { // #取辣条 INVL_autoGetFB = setInterval(() => { if ($H2P('div.function-bar.draw')) { $H2P('div.function-bar.draw').click(); } }, 500); } }; // 自动签到 let auto_signIn = () => { if (isHuya) { return; } let start = undefined; let INVL_checkSignInIconReady = setInterval(() => { let elePath = isDouyu ? 'div.RoomLevelDetail-level.RoomLevelDetail-level--no' : isBilibiliLive ? 'div.checkin-btn.t-center.pointer' : ''; if (isDouyu) { if ($H2P('div.Title-followBtnBox') ) { if (!start) { start = new Date().getTime() / 1000; } else { if ($H2P('div.Title-followBtnBox.is-followed')) { if ($H2P(elePath)) { clearInterval(INVL_checkSignInIconReady); console.log('启动完毕 : 签到 : 已关注'); $H2P(elePath).click(); setTimeout(() => { // 关闭签到弹出的框 if ($H2P('div.SSR-D-close')) { $H2P('div.SSR-D-close').click(); } }, 200); } } else if (new Date().getTime() / 1000 - start > 100) { clearInterval(INVL_checkSignInIconReady); console.log('启动完毕 : 签到 : 未关注'); } } } } else if (isBilibiliLive) { if ($H2P(elePath)) { clearInterval(INVL_checkSignInIconReady); console.log('启动完毕 : 签到'); $H2P(elePath).click(); } } }, 500); } // 自动赠送荧光棒 let auto_anchorUp = () => { if (!isDouyu) { return; } function donateYGB(roomId){ let formData = new FormData(); formData.append("propId", "268"); formData.append("propCount", 1); formData.append("roomId", roomId); fetch('https://www.douyu.com/japi/prop/donate/mainsite/v1', { method: 'POST', body: formData }) .then(res => res.json()) .then(res => { if (res && 'error' in res && res.error === 0) { console.log('成功赠送主播 : '+ roomId + ' 一个荧光棒'); config_info.anchorFanRooms[roomId].anchorUp += 1; $util.LS.set(LSInfo, config_info); } else { console.log('赠送' + roomId + '失败 : ' + res.msg); } }); } let INVL_anchorUp = setInterval(() => { if (config_info.anchorFanUpdatedTime === new Date().$formatDate()) { let roomIds = Object.keys(config_info.anchorFanRooms); for (let i = 0; i < roomIds.length; i++) { let roomId = roomIds[i]; if (config_info.anchorFanRooms[roomId].anchorUp === 0) { setTimeout(() => { donateYGB(roomId); }, (i+1) * 2000); } } clearInterval(INVL_anchorUp); console.log('启动完毕 : 赠送荧光棒'); } else { console.log('今日已赠送荧光棒'); clearInterval(INVL_anchorUp); } }, 1000); } // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // // 脚本自动化配置界面 // // ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // const LSConfig = 'h2p-DY-config-tool'; let config_tool = $util.LS.init(LSConfig, { pausePlay : false, hideSound : false, hideBar : false, show0 : false, show9 : false, wideMode : false, fullMode : false, getFB : false, findTreasure: '', signIn : false, anchorUp : false, }); if (config_tool.pausePlay) { console.log('启动 : 暂停播放'); auto_pausePlay(); } if (config_tool.hideSound) { console.log('启动 : 自动静音'); auto_hideSound(); } if (config_tool.hideBar) { console.log('启动 : 自动禁止弹幕'); auto_hideBar(); } if (config_tool.show0) { console.log('启动 : 最低画质'); auto_showDef(); } if (config_tool.show9) { console.log('启动 : 最高画质'); auto_showDef(); } if (config_tool.wideMode) { wideMode(); } if (config_tool.fullMode) { fullMode(); } if (config_tool.getFB) { console.log('启动 : 自动#取观看鱼丸'); auto_getFB(); } if (config_tool.signIn) { console.log('启动 : 自动签到'); auto_signIn(); } if (config_tool.anchorUp) { console.log('启动 : 自动赠送荧光棒'); auto_anchorUp(); } new Promise((resolve, reject) => { // 创建元素样式 =============================================================== let eleStyle = document.createElement('style'); eleStyle.type = 'text/css'; eleStyle.innerHTML += ` #h2p-div-config button { height: 25px; } .h2p-btn { width : 100%; height : 100%; padding : 4px 0; border : none; border-radius : 5px; margin : 0; font-size : 13px; cursor : pointer; } .h2p-top-0 { top: 0!important; } .h2p-top-50 { top: 50px!important; } .h2p-w-50p { width: 50%!important; } .h2p-w-96p { width: 96%!important; } .h2p-h-100p { height: 100%!important; } `; document.head.appendChild(eleStyle); // 初始化配置界面 =============================================================== let div = document.createElement('div'); div.id = 'h2p-div-config'; div.className = 'h2p-div-inlinepanel'; div.style = 'display: none;'; div.innerHTML = ` <div class="h2p-flex-main-start h2p-item-100p"> <div class="h2p-flex-main-start h2p-item-50p"> <button class="h2p-btn h2p-w-96p h2p-bg-close" style="color: black;" disabled>关闭状态</button> </div> <div class="h2p-flex-main-end h2p-item-50p"> <button class="h2p-btn h2p-w-96p h2p-bg-open" style="color: black;" disabled>开启状态</button> </div> </div> <hr style="margin: 6px -9px 12px; border: 1px solid #DCDCDC;"> <!-- 暂停播放、静音、关闭弹幕 --> <div class="h2p-flex-main-start h2p-item-100p"> <div class="h2p-flex-main-start h2p-item-50p"> <div class="h2p-flex-main-start h2p-item-50p"> <button id="h2p-btn-config-pausePlay" class="h2p-btn h2p-w-96p h2p-bg-close">暂停播放</button> </div> <div class="h2p-flex-main-start h2p-item-50p"> <button id="h2p-btn-config-hideSound" class="h2p-btn h2p-w-96p h2p-bg-close">静音</button> </div> </div> <div class="h2p-flex-main-end h2p-item-50p"> <div class="h2p-flex-main-end h2p-item-50p"> <button id="h2p-btn-config-hideBar" class="h2p-btn h2p-w-96p h2p-bg-close">关闭弹幕</button> </div> <div class="h2p-flex-main-end h2p-item-50p"> </div> </div> </div> <div class="h2p-flex-main-start h2p-item-100p"> <!-- 画质选项 --> <div class="h2p-flex-main-start h2p-item-50p"> <div class="h2p-flex-main-start h2p-item-50p"> <button id="h2p-btn-config-show0" class="h2p-btn h2p-w-96p h2p-bg-close">最低画质</button> </div> <div class="h2p-flex-main-start h2p-item-50p"> <button id="h2p-btn-config-show9" class="h2p-btn h2p-w-96p h2p-bg-close">最高画质</button> </div> </div> <!-- 播放器大小 --> <div class="h2p-flex-main-end h2p-item-50p"> <div class="h2p-flex-main-end h2p-item-50p"> <button id="h2p-btn-config-wideMode" class="h2p-btn h2p-w-96p h2p-bg-close">宽屏模式</button> </div> <div class="h2p-flex-main-end h2p-item-50p"> <button id="h2p-btn-config-fullMode" class="h2p-btn h2p-w-96p h2p-bg-close">网页全屏</button> </div> </div> </div> <div class="h2p-flex-main-start h2p-item-100p"> <div class="h2p-flex-main-start h2p-item-50p"> <div class="h2p-flex-main-start h2p-item-50p"> <!-- 是否自动#取鱼塘 --> <button id="h2p-btn-config-getFB" class="h2p-btn h2p-w-96p h2p-bg-close" style="display: ${isDouyu ? 'none' : ''}">#取${isDouyu ? '鱼塘' : isHuya ? '宝箱' : '辣条'}</button> </div> <div class="h2p-flex-main-start h2p-item-50p" style="display: ${isHuya ? 'none' : ''}"> <!-- 是否自动签到 --> <button id="h2p-btn-config-signIn" class="h2p-btn h2p-w-96p h2p-bg-close" style="float: right">签到</button> </div> </div> <div class="h2p-flex-main-end h2p-item-50p" style="display: ${isBilibili ? 'none' : ''}"> <div class="h2p-flex-main-end h2p-item-50p" style="display: ${isDouyu ? '' : 'none'}"> <!-- 赠送荧光棒 --> <button id="h2p-btn-config-anchorUp" class="h2p-btn h2p-w-96p h2p-bg-close">赠送荧光棒</button> </div> <div class="h2p-flex-main-end h2p-item-50p"> </div> </div> </div> `; let setINVL_wait_div_DYScript = setInterval(() => { if ($H2P('div#div-DYScript')) { clearInterval(setINVL_wait_div_DYScript); $H2P('div#div-DYScript').appendChild(div); setTimeout(resolve, 250); } }, 500); }) .then(() => { let eleConfig = $H2P('div#h2p-div-config'); eleConfig.addEventListener('click', (event) => { let target = event.target; if (target.tagName.toLowerCase() !== 'button') { return; } target.classList.toggle('h2p-bg-open'); if (target.id === 'h2p-btn-config-wideMode') { config_tool.wideMode = !config_tool.wideMode; if (config_tool.fullMode) { config_tool.fullMode = false; $H2P('button#h2p-btn-config-fullMode').classList.remove('h2p-bg-open'); } wideMode(); } else if (target.id === 'h2p-btn-config-fullMode') { config_tool.fullMode = !config_tool.fullMode; if (config_tool.wideMode) { config_tool.wideMode = false; $H2P('button#h2p-btn-config-wideMode').classList.remove('h2p-bg-open'); } fullMode(); } else if (target.id === 'h2p-btn-config-show0') { config_tool.show0 = !config_tool.show0; config_tool.show9 = false; $H2P('button#h2p-btn-config-show9').classList.remove('h2p-bg-open'); auto_showDef(); } else if (target.id === 'h2p-btn-config-show9') { config_tool.show0 = false; $H2P('button#h2p-btn-config-show0').classList.remove('h2p-bg-open'); config_tool.show9 = !config_tool.show9; auto_showDef(); } else if (target.id === 'h2p-btn-config-hideBar') { config_tool.hideBar = !config_tool.hideBar; auto_hideBar(); } else if (target.id === 'h2p-btn-config-hideSound') { config_tool.hideSound = !config_tool.hideSound; auto_hideSound(); } else if (target.id === 'h2p-btn-config-getFB') { config_tool.getFB = !config_tool.getFB; auto_getFB(); } else if (target.id === 'h2p-btn-config-signIn') { config_tool.signIn = !config_tool.signIn; auto_signIn(); } else if (target.id === 'h2p-btn-config-anchorUp') { config_tool.anchorUp = !config_tool.anchorUp; auto_anchorUp(); } else if (target.id === 'h2p-btn-config-pausePlay') { config_tool.pausePlay = !config_tool.pausePlay; auto_pausePlay(); } $util.LS.set(LSConfig, config_tool); }, false); }) .then(() => { if (config_tool.wideMode) { $H2P('button#h2p-btn-config-wideMode').classList.add('h2p-bg-open'); } if (config_tool.fullMode) { $H2P('button#h2p-btn-config-fullMode').classList.add('h2p-bg-open'); } if (config_tool.delEle) { $H2P('button#h2p-btn-config-delEle').classList.add('h2p-bg-open'); } if (config_tool.show0) { $H2P('button#h2p-btn-config-show0').classList.add('h2p-bg-open'); } if (config_tool.show9) { $H2P('button#h2p-btn-config-show9').classList.add('h2p-bg-open'); } if (config_tool.hideBar) { $H2P('button#h2p-btn-config-hideBar').classList.add('h2p-bg-open'); } if (config_tool.hideSound) { $H2P('button#h2p-btn-config-hideSound').classList.add('h2p-bg-open'); } if (config_tool.getFB) { $H2P('button#h2p-btn-config-getFB').classList.add('h2p-bg-open'); } if (config_tool.signIn) { $H2P('button#h2p-btn-config-signIn').classList.add('h2p-bg-open'); } if (config_tool.anchorUp) { $H2P('button#h2p-btn-config-anchorUp').classList.add('h2p-bg-open'); } if (config_tool.pausePlay) { $H2P('button#h2p-btn-config-pausePlay').classList.add('h2p-bg-open'); } }) .catch(error => { console.log(error); }) })($util, $notifyMgr);