diff --git a/checkbans.js b/checkbans.js index f098a4f..17b2e31 100644 --- a/checkbans.js +++ b/checkbans.js @@ -34,25 +34,33 @@ checkBans = () => { playerEls.forEach(playerEl => { let verdict = ''; let verdictEl = document.createElement('div'); - if (player.NumberOfVACBans > 0) { - verdict += 'VAC'; + let icon = ''; + verdictEl.className = 'banchecker-verdict'; + if (player.NumberOfVACBans > 0 || player.NumberOfGameBans > 0) { + verdictEl.classList.add('banned'); + icon = 'banned.svg'; + verdict = `${player.NumberOfVACBans > 0 ? `${player.NumberOfVACBans} VAC`: ''}` + + `${player.NumberOfVACBans > 0 && player.NumberOfGameBans > 0 ? ' & ' : ''}` + + `${player.NumberOfGameBans > 0 ? `${player.NumberOfGameBans} Game`: ''}` + + ` ban${player.NumberOfVACBans + player.NumberOfGameBans > 1 ? 's' : ''} on record\n` + + `Last ban occured ${player.DaysSinceLastBan} day${player.DaysSinceLastBan > 1 ? 's' : ''} ago`; } - if (player.NumberOfGameBans > 0) { - if (verdict) verdict += ' & '; - verdict += 'Game Ban'; - } if (!verdict) { + verdictEl.classList.add('clean'); if (greentext) { + icon = 'clean.svg'; verdict = 'No bans for this player'; - verdictEl.style.color = 'green'; - } - } else { - verdict += ` ${player.DaysSinceLastBan} day${player.DaysSinceLastBan > 1 ? 's' : ''} ago.`; - verdictEl.style.color = 'red'; - } + } + } if (verdict) { - playerEl.querySelector('.friend_block_content br').remove(); - verdictEl.textContent = verdict; + const verdictElIcon = document.createElement('div'); + const verdictElIconImg = document.createElement('img'); + verdictElIconImg.src = chrome.extension.getURL(`icons/${icon}`); + verdictElIcon.appendChild(verdictElIconImg); + const verdictElText = document.createElement('span'); + verdictElText.textContent = verdict; + verdictEl.appendChild(verdictElIcon); + verdictEl.appendChild(verdictElText); playerEl.querySelector('.friend_block_content').appendChild(verdictEl); } }); diff --git a/display.css b/display.css index 1da4348..a5a1845 100644 --- a/display.css +++ b/display.css @@ -106,4 +106,51 @@ background-color: #66c0f4; border-color: #66c0f4; color: #fff; + } + + .banchecker-verdict { + position: absolute; + color: #ebebeb; + top: 0; + right: 0; + width: auto; + max-width: 28px; + height: 100%; + transition: all .3s; + z-index: 10; + cursor: default; + display: flex; + align-items: center; + } + + .banchecker-verdict:hover { + max-width: 235px; + } + + .banchecker-verdict div { + flex: 0 0 28px; + text-align: center; + overflow: hidden; + } + + .banchecker-verdict:hover div { + flex: 0 0 0; + } + + .banchecker-verdict span { + padding: 10px; + white-space: pre; + } + + .banchecker-verdict.banned { + background-color: rgba(255, 0, 0, .4); + } + .banchecker-verdict.banned:hover { + background-color: rgba(255, 0, 0, .9); + } + .banchecker-verdict.clean { + background-color: rgba(0, 255, 0, .2); + } + .banchecker-verdict.clean:hover { + background-color: rgba(0, 150, 0, .9); } \ No newline at end of file diff --git a/display.js b/display.js index a319fd0..0374d7f 100644 --- a/display.js +++ b/display.js @@ -4,7 +4,7 @@ var gamesShowingIndex = 0; // Index of a last game shown // Add links to Ban Checker page var banCheckerButton = document.createElement('a'); banCheckerButton.setAttribute('href', '//steamcommunity.com/my/friends/banchecker'); -banCheckerButton.className = 'icon_item icon_recent_friends banchecker'; +banCheckerButton.className = 'icon_item icon_all_groups banchecker'; banCheckerButton.dataset.navid = 'banchecker'; var banCheckerButtonText = document.createElement('span'); banCheckerButtonText.appendChild(document.createTextNode('Ban Checker')); @@ -318,6 +318,7 @@ function renderBanCheker() { extensionInfo.style.paddingBottom = "1.5em"; var InfoMessage = `
This page will show only those bans which occured after you played together.
Extension records games periodically every few hours, they don't appear here immediately.
+For complete CS:GO Match history click here.
With your own Steam API key extension will periodically scan every recorded game for recent bans.
Without the key it will only scan last 100 players once a day. You can set your API key in settings.