// ==UserScript==
// @name 咪咕奥运小助手——实时数据立刻了解
// @version 0.0.0022_a
// @namespace https://greasyfork.org/users/58790
// @description 添加实时热门赛事比分等详细信息;切换标签时静音上一个标签,方便多赛事切换观看;屏蔽聊天室默认热词。
// @author mission522
// @license MIT
// @match https://www.miguvideo.com/mgs/website/prd/sportLive.html?mgdbId=*
// @icon https://www.google.com/s2/favicons?domain=miguvideo.com
// @require https://cdn.bootcss.com/qs/6.7.0/qs.min.js
// @connect app.sports.qq.com
// @grant GM_setValue
// @grant GM_getValue
// @grant GM_addStyle
// @grant GM_addElement
// @grant GM_xmlhttpRequest
// ==/UserScript==
// 静音
function vedioMute() {
document.addEventListener('visibilitychange', function () {
//浏览器切换事件
const mVedioPlayer = document.querySelector('#m-player');
if (document.visibilityState == 'hidden') {
console.log('离开当前tab标签');
mVedioPlayer.muted = true; // 使音频静音
} else {
console.log('回到当前tab标签');
mVedioPlayer.muted = false; // 取消音频静音
}
});
}
//聊天室过滤,去多余信息(vip,app等)
function chatRoomFilter() {
//去多余
// console.log('here');
GM_addStyle('.user-guide-app , .list_box>.name{display:none!important}');
let FilterList = [
'slay东京',
'这才是真正的高手',
'奔跑自由是方向',
'期待破纪录',
'运动永无止境',
// 'watch out',
'见证奥林匹克精神!',
'这水花绝了',
'队?这就叫',
'这就是压水花天',
'军团,全力',
'奋力一搏',
'不留遗憾',
'就是要拼',
'运健儿取得',
'决战奥运,',
'马,卫冕东京',
'战斗从未停止,2020奥运会',
'预祝举办成功!',
'携手破浪,冲',
'憾,年轻就',
];
let FilterReg = new RegExp(`(${FilterList.join('|')})`);
document.querySelector('.__view>ul>div.list_item').addEventListener(
//插入事件。'DOMSubtreeModified',
'DOMNodeInserted',
(e) => {
// console.log('insert,e:', e);
if (FilterReg.test(e.target.textContent)) {
e.target.style.display = 'none';
}
},
false
);
}
//获取今天日期
function getNowFormatDate() {
var date = new Date();
var seperator1 = '-';
var year = date.getFullYear();
var month = date.getMonth() + 1;
var strDate = date.getDate();
if (month >= 1 && month <= 9) {
month = '0' + month;
}
if (strDate >= 0 && strDate <= 9) {
strDate = '0' + strDate;
}
var currentdate = year + seperator1 + month + seperator1 + strDate;
return currentdate;
}
// 添加赛程元素
function creatScheduleElement(resultObject) {
const tabColumn = document.querySelector('.tabColumn');
const vedioTitle = tabColumn.children[1];
vedioTitle.style.display = 'none';
const chatTitle = tabColumn.children[0];
let chatRoom = document.querySelector('#chat');
if (chatRoom === null) {
chatRoom = document.querySelector('.live-review');
}
let scheduleTitle = GM_addElement(tabColumn, 'li', { 'data-v-66839cfa': '', title: '点击立即刷新数据' });
scheduleTitle.innerHTML = '热门赛程';
scheduleTitle.addEventListener('click', (e) => {
chatRoom.style.display = 'none';
scheduleList.style.display = 'block';
scheduleTitle.style.color = '#007AFF';
chatTitle.style.color = '#999';
});
chatTitle.addEventListener('click', (e) => {
chatRoom.style.display = 'block';
scheduleList.style.display = 'none';
chatTitle.style.color = '#007AFF';
scheduleTitle.style.color = '#999';
});
let rightBox = document.querySelector('.right-box');
let scheduleList = GM_addElement(rightBox, 'ul', { class: 'scheduleList', style: 'display: none;' });
//样式
GM_addStyle(
'::-webkit-scrollbar { width: 6px}::-webkit-scrollbar-thumb { border-radius: 10px; background: #555555;}.right-box { background-color: #333;}.scheduleList { padding: 0 1rem; height: 382px; overflow-y: scroll; color: white;}.scheduleItem { min-height: 5rem; color: #fcf7f7; font-size: 12px; padding: .3rem .1rem; border-bottom: .5px solid #969ba3 ;}.scheduleItemGroup{ display: flex; flex-direction: row; align-items: center; text-align:left;}.scheduleItemMatch { padding: .5em 0; color:#969ba3 ; box-sizing:border-box;height:30px;}.scheduleItemTeams { overflow: hidden; font-size:1.2em; flex: 8; cursor: pointer;}.scheduleitemScores { flex: 1; font-size:1.2em; }'
);
function add_schedule(obj) {
// console.log('add_schedule');
obj.forEach((element) => {
let matchInfo = element.matchInfo;
function add_scheduleItem() {
let scheduleItem = GM_addElement(scheduleList, 'li', { class: 'scheduleItem' });
//match
let scheduleItemMatch = GM_addElement(scheduleItem, 'div', { class: 'scheduleItemMatch' });
// scheduleItemMatch.innerHTML = matchInfo.cnSportName + matchInfo.cnGenderName + matchInfo.cnEventName + matchInfo.cnPhaseName;
scheduleItemMatch.innerHTML = matchInfo.matchDesc;
// 添加图标
let icon = {
isChina:
'',
isGold:
'',
};
GM_addStyle('.scheduleItemIcon{display: inline; padding-left:3px; width:12px; vertical-align:middle;}')
if (matchInfo.isChina==1) {
console.log(`${matchInfo.matchDesc}:${matchInfo.isChina}`);
GM_addElement(scheduleItemMatch, 'img', { class: 'scheduleItemIcon', src: icon.isChina });
}
if (matchInfo.isGold==1) {
console.log(`${matchInfo.matchDesc}:${matchInfo.isGold}`);
GM_addElement(scheduleItemMatch, 'img', { class: 'scheduleItemIcon', src: icon.isGold });
}
let scheduleItemGroup = GM_addElement(scheduleItem, 'div', { class: 'scheduleItemGroup', title: '点击立即刷新数据' });
//time
let scheduleItemTime = GM_addElement(scheduleItemGroup, 'div', { class: 'scheduleItemTime' });
// scheduleItemTime.innerHTML = matchInfo.startTime;
//Teams
let scheduleItemTeams = GM_addElement(scheduleItemGroup, 'div', { class: 'scheduleItemTeams' });
let scheduleItemTeam1 = GM_addElement(scheduleItemTeams, 'div', { class: 'scheduleItemTeam' });
scheduleItemTeam1.innerHTML = matchInfo.leftName;
let scheduleItemTeam2 = GM_addElement(scheduleItemTeams, 'div', { class: 'scheduleItemTeam' });
scheduleItemTeam2.innerHTML = matchInfo.rightName;
//Score
let scheduleItemScores = GM_addElement(scheduleItemGroup, 'div', { class: 'scheduleitemScores' });
let scheduleItemScore1 = GM_addElement(scheduleItemScores, 'div', { class: 'scheduleitemScore' });
scheduleItemScore1.innerHTML = matchInfo.leftGoal;
let scheduleItemScore2 = GM_addElement(scheduleItemScores, 'div', { class: 'scheduleitemScore' });
scheduleItemScore2.innerHTML = matchInfo.rightGoal;
//详细数据获取按钮
// console.dir(scheduleItemTeams);
scheduleItemTeams.addEventListener('click', () => {
detailUrl = `https://app.sports.qq.com/TokyoOly/statDetail?mid=${matchInfo.mid}`;
getStatsDetail(detailUrl, scheduleItem);
});
}
if (element.liveId === '' && element.matchInfo.quarter !== '') {
// if (element.liveId === '') {
add_scheduleItem();
}
});
}
function update_schedule() {
let newResultObject = {};
scheduleList.innerHTML = null;
getSchedule(getXhrUrl(), (responseText) => {
let today = getNowFormatDate();
newResultObject = JSON.parse(responseText).data.matches[`${today}`].list;
add_schedule(newResultObject);
});
}
//第一次获取数据
add_schedule(resultObject);
// 每3分钟更新数据
setInterval(() => {
update_schedule();
}, 1000 * 60 * 3);
scheduleTitle.addEventListener('click', update_schedule);
}
function getXhrUrl() {
let urlData = {
// 130003热门
columnId: 130003,
dateNum: 1,
flag: 2,
// sportID:null,
// venueID:null,
// nocID:null,
// parentChildType:1,
date: getNowFormatDate(),
};
return 'https://app.sports.qq.com/match/list?' + Qs.stringify(urlData);
}
//xhr获取赛程信息
function getSchedule(url, success, fail) {
// 执行xhr
GM_xmlhttpRequest({
method: 'GET',
url: url,
onload: (result) => {
if (result.readyState === 4 && result.status === 200) {
success && success(result.responseText);
} else {
fail && fail(new Error('接口请求失败'));
}
},
});
}
function getStatsDetail(url, parentElement) {
function addDetailElement(responseText) {
let response = JSON.parse(responseText);
let stats = '';
if (parentElement.lastChild.classList[0] === 'statsTable') {
parentElement.lastChild.remove();
}
let statsTable = GM_addElement(parentElement, 'table', { class: 'statsTable' });
if (response.code === 4) {
return (statsTable.innerHTML = '暂无数据');
} else {
stats = response.data.stats['0'];
console.dir(stats);
}
// statsTable.innerHTML = stats['0'];
let statsTbody = GM_addElement(statsTable, 'tbody', { class: 'statsTbody' });
for (let i = 0; i < stats.rowCount; i++) {
let statsTr = GM_addElement(statsTable, 'tr', { class: 'statsTr' });
for (let j = 0; j < stats.rows[i].length; j++) {
let statsTd = GM_addElement(statsTr, 'td', { class: 'statsTd' });
// console.log(`i:${i},j:${j}`);
statsTd.innerHTML = stats.rows[i][j].html;
// statsTd.innerHTML = stats.rows[0][0].html;
}
}
GM_addStyle(
'.statsTable { text-align: left; margin: 2px 0; min-width: 3.75rem; border-collapse: separate; font-size: 12px;}.scheduleItemGroup { padding-bottom: 10px;}.statsTr { border-bottom: 1px solid #f5f5f5;}.statsTd { min-width: 5em; white-space: normal; text-align: left; padding-right: .5em; padding-bottom:.5em; overflow: hidden;}'
);
}
getSchedule(url, addDetailElement);
}
window.onload = function myPromise() {
new Promise((resolve, reject) => {
vedioMute();
setTimeout(() => {
chatRoomFilter();
}, 100);
resolve();
})
.then((res) => {
getSchedule(getXhrUrl(), (responseText) => {
let today = getNowFormatDate();
let responseDataList = JSON.parse(responseText).data.matches[`${today}`].list;
creatScheduleElement(responseDataList);
});
return new Promise((resolve, reject) => {
resolve('end');
});
})
.then((res) => {
// console.log(res);
});
};