Last active
July 4, 2023 16:38
-
-
Save robfrawley/74ec9d1be237bc5acfff0b57d1849725 to your computer and use it in GitHub Desktop.
Tool Army Community Style Fixes
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// ==UserScript== | |
// @name Tool Army Community Style Fixes | |
// @namespace https://gist.github.com/robfrawley | |
// @version 0.2.7 | |
// @description A collection of style fixes for the community sections of Tool's website. | |
// @author Rob Frawley 2nd <[email protected]> | |
// @copyright 2023 | |
// @license https://src.mit-license.com/ | |
// @match https://www.toolband.com/forums* | |
// @match https://www.toolband.com/activities* | |
// @match https://www.toolband.com/conversations* | |
// @grant GM_addStyle | |
// @grant GM_log | |
// @icon  | |
// @supportURL https://gist.github.com/robfrawley/74ec9d1be237bc5acfff0b57d1849725#new_comment_field | |
// ==/UserScript== | |
(function() { | |
'use strict'; | |
const verboseLoggerEnable = false; | |
const addStyleSelectorMap = { | |
'.fan-wall.activity-panel .fan-wall-post.discussions': [ | |
'border: 4px solid rgb(0 0 0 / 50%)', | |
'border-left: none', | |
'border-right: none', | |
], | |
'.fan-wall.activity-panel .fan-wall-post.discussions li': [ | |
'background-color: rgb(0 0 0 / 20%)', | |
'border-left: 4px solid rgb(0 0 0 / 25%)', | |
'border-right: 4px solid rgb(0 0 0 / 25%)', | |
'margin-bottom: 2px', | |
'padding: 1em', | |
], | |
'.fan-wall.activity-panel .fan-wall-post.discussions li:first-child': [ | |
'margin-top: 2px', | |
], | |
'.fan-wall.activity-panel .fan-wall-post.discussions li:hover, .fan-wall.activity-panel .fan-wall-post.discussions li:focus': [ | |
'background-color: rgb(0 0 0 / 22.5%)', | |
], | |
'.fan-wall.activity-panel .fan-wall-post.discussions li.un-read' : [ | |
'background-color: rgb(142 104 42 / 50%)', | |
'border-left-color: rgb(142 104 42 / 95%)', | |
'border-right-color: rgb(142 104 42 / 95%)', | |
], | |
'.fan-wall.activity-panel .fan-wall-post.discussions li.un-read:hover, .fan-wall.activity-panel .fan-wall-post.discussions li.un-read:focus': [ | |
'background-color: rgb(142 104 42 / 55%)', | |
], | |
'.fan-wall.activity-panel .fan-wall-post.discussions li .profile-pic' : [ | |
'margin: 1em 1.5em 1em 0.5em', | |
'border: 2px solid rgb(255 255 255 / 80%)', | |
'box-shadow: 0 0 0 4px rgb(0 0 0 / 40%)', | |
], | |
'.fan-wall.activity-panel .fan-wall-post.discussions li.un-read .profile-pic' : [ | |
'box-shadow: 0 0 0 4px rgb(39 31 19 / 80%)', | |
], | |
'.fan-wall.activity-panel .fan-wall-post.discussions li .content': [ | |
'border-bottom: none', | |
'margin: 0', | |
'padding: 1.0em 0 1.0em 0', | |
], | |
'.fan-wall.activity-panel .fan-wall-post.discussions li p:first-child': [ | |
'font-size: 1.2em', | |
'margin-bottom: 0.25em', | |
], | |
'.fan-wall.activity-panel .fan-wall-post.discussions li.un-read p:first-child' : [ | |
'font-weight: 500', | |
], | |
'.fan-wall.activity-panel .fan-wall-post.discussions li .content .time': [ | |
'float: none', | |
'margin: 0', | |
'padding: 0', | |
], | |
'.upper-heading .comment-reply-head .vote-btn.notification-view-post': [ | |
'color: rgb(255 255 255 / 50%)', | |
], | |
'.previous-comment-btn span.previous-comment-link': [ | |
'color: rgb(255 255 255 / 30%)', | |
], | |
'.previous-comment-btn span.previous-comment-link:hover,.previous-comment-btn span.previous-comment-link:active ': [ | |
'color: rgb(255 255 255 / 50%)', | |
], | |
'.fb_layout .messages-box textarea, .fb_layout .messages-box #makemojifield': [ | |
'max-height: none', | |
], | |
'.fb_layout .newfeeds-right .add-forum .form-control, .fb_layout .newfeeds-right .add-forum #makemojifield': [ | |
'height: auto', | |
], | |
}; | |
const toHiddenSelectorSet = []; | |
const debugConsoleOut = (text) => { | |
if (verboseLoggerEnable) { | |
GM_log(text); | |
} | |
}; | |
const debounceEvent = (func) => { | |
var timer; | |
return function(event) { | |
if (timer) { | |
clearTimeout(timer); | |
} | |
timer = setTimeout(func, 100, event); | |
}; | |
}; | |
const joinStyles = (properties, selector) => { | |
return properties.map(function (value) { | |
return typeof value === 'function' ? value(selector) : value; | |
}).filter(function (value) { | |
return typeof value === 'string' && value.trim().length > 0; | |
}).map(function (value) { | |
return value.trim() + ' !important'; | |
}).join('; '); | |
}; | |
const main = () => { | |
debugConsoleOut(`(MAIN) Executing initialization function ...`); | |
debugConsoleOut(`(MAIN) Performing element styling operations ...`); | |
for (const selector in addStyleSelectorMap) { | |
let definition = `${selector} { ${joinStyles(addStyleSelectorMap[selector], selector)}; }`; | |
try { | |
GM_addStyle(definition); | |
debugConsoleOut(` -> SUCCESS: Created new selector style definitions => [ ${definition} ]`); | |
} catch { | |
debugConsoleOut(` -> FAILURE: Created new selector style definitions => [ ${definition} ]`); | |
} | |
} | |
debugConsoleOut(`(MAIN) Performing element hiding operations ...`); | |
toHiddenSelectorSet.forEach(function(querySelector) { | |
try { | |
GM_addStyle(`${querySelector} { display: none !important; }`); | |
debugConsoleOut(` -> SUCCESS: Hid els matching query selector(s) => [ "${querySelector}" ]`); | |
} catch { | |
debugConsoleOut(` -> FAILURE: Hid els matching query selector(s) => [ "${querySelector}" ]`); | |
} | |
}); | |
debugConsoleOut(`(MAIN) Completed initialization function ...`); | |
}; | |
window.addEventListener('load', function() { | |
main(); | |
}, false); | |
})(); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment