Skip to content

Instantly share code, notes, and snippets.

@spiralx
Last active September 27, 2017 10:42
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save spiralx/2bbd7b50363450484cfce6b0735295ca to your computer and use it in GitHub Desktop.
Save spiralx/2bbd7b50363450484cfce6b0735295ca to your computer and use it in GitHub Desktop.
Reddit - Remember RES user tag UserScript
// ==UserScript==
// @name Reddit - Remember RES tag action
// @description Saves previously set tag and colour to use again.
// @author James Skinner <spiralx@gmail.com> (http://github.com/spiralx)
// @namespace http://spiralx.org/
// @version 0.5.0
// @icon 
// @icon64 
// @match *://*.reddit.com/r/*/comments/*
// @match *://*.reddit.com/user/*
// @grant GM_getValue
// @grant GM_setValue
// @run-at document-end
// @require https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.js
// @require https://greasyfork.org/scripts/10443-datacache-simple-storage-wrapper/code/DataCache%20-%20Simple%20storage%20wrapper.js?version=56961
// ==/UserScript==
/* jshint asi: true, esnext: true */
/* global jQuery, MutationSummary */
/**
### 0.5.0 (26.08.2017)
* Change to simple use of GM_getValue and GM_setValue for storage
### 0.4.0 (21.08.2017)
* Update all other tags correctly when changing a user's tag
* Handle removing all other tags when clearing a user's tag
### 0.3.0 (13.07.2017)
* Checks tag link to see if tag set, always overwrites if not
* Updates other tags for same user on current page
### 0.2.1 (27.06.2017)
* Changed timeout of field set function to 250ms
### 0.2.0 (31.05.2017)
* Updated jQuery to v3.2.1
* Added timeout before overriding tag/colour fields
* Update preview when setting tag/colour
*/
; ($ => {
'use strict'
const NORMAL = 'font-weight: normal; text-decoration: none; color: black'
const ERROR = 'font-weight: bold; color: #f4f'
const LINK = 'color: #05f; text-decoration: underline'
const BOLD = 'font-weight: bold'
const BLUE = [ 'color: #05f', 'color: #000' ]
const GREEN = [ 'color: #c1007f', 'color: #000' ]
const qval = (v, n) => `${n}=%c"${v}"%c`
// --------------------------------------------------------------------
const bgToTextColorMap = {
none: 'inherit',
aqua: 'black',
black: 'white',
blue: 'white',
cornflowerblue: 'white',
fuchsia: 'white',
gray: 'white',
green: 'white',
lime: 'black',
maroon: 'white',
navy: 'white',
olive: 'white',
orange: 'white',
orangered: 'white',
pink: 'black',
purple: 'white',
red: 'white',
silver: 'black',
teal: 'white',
white: 'black',
yellow: 'black'
}
// --------------------------------------------------------------------------
class Tag {
constructor(text = '', colour = 'none') {
this.text = text
this.colour = colour
}
get css() {
return {
backgroundColor: this.colour === 'none' ? 'transparent' : this.colour,
color: bgToTextColorMap[this.colour]
}
}
equals(other) {
return this.text === other.text && this.colour === other.colour
}
json() {
return JSON.stringify(this)
}
dump() {
console.log(`Tag(${qval(this.text, 'text')}, ${qval(this.colour, 'colour')})`, ...BLUE, ...BLUE)
}
}
Tag.parse = str => {
const { text, colour } = JSON.parse(str)
return new Tag(text, colour)
}
const previousTag = {
text: GM_getValue('tag', $('.pagename a').text()),
colour: GM_getValue('colour', 'olive')
}
// --------------------------------------------------------------------------
const tags = JSON.parse(localStorage.getItem('resrem') || '[]').map(v => new Tag(v.text, v.colour))
console.info(`onScriptInit: ${qval(previousTag.text, 'text')}, ${qval(previousTag.colour, 'colour')}`, ...BLUE, ...BLUE)
console.group(`tags(${qval(tags.length, 'length')})`, ...GREEN)
tags.forEach(t => t.dump())
console.groupEnd()
function getLastTag() {
return tags.length ? tags[0] : new Tag($('.pagename a').text(), 'olive')
}
function saveTag(tag) {
const idx = tags.findIndex(t => t.equals(tag))
if (idx !== -1) {
tags.splice(idx, 1)
}
tags.unshift(tag)
localStorage.setItem('resrem', JSON.stringify(tags))
return idx === -1
}
// console.info('Loaded "%s" and "%s"', previousTag.text, previousTag.colour)
// --------------------------------------------------------------------------
function onTagModalOpened() {
const $tagField = $('#userTaggerTag')
const $colourField = $('#userTaggerColor')
const $previewField = $('#userTaggerPreview')
const pt = getLastTag()
console.info(`onTagModalOpened: ${qval($tagField.val(), 'tag')}, ${qval($colourField.val(), 'colour')} (${qval(previousTag.text, 'oldTag')}, ${qval(previousTag.colour, 'oldCol')})`,
...GREEN, ...GREEN, ...BLUE, ...BLUE)
pt.dump()
console.dir(pt.css)
// console.info(`onTagModalOpened: tag="${$tagField.val()}", colour="${$colourField.val()}" (oldTag="${previousTag.text}", oldCol="${previousTag.colour}")`)
$tagField.val(previousTag.text)
$colourField.val(previousTag.colour)
$previewField
.css({
backgroundColor: previousTag.colour === 'none' ? 'transparent' : previousTag.colour,
color: bgToTextColorMap[previousTag.colour]
})
.text(previousTag.text)
}
// --------------------------------------------------------------------------
function onSaveTag() {
const text = $('#userTaggerTag').val()
const colour = $('#userTaggerColor').val()
const user = $('#userTaggerName').val()
if (text) {
previousTag.text = text
previousTag.colour = colour
const newTag = new Tag(text, colour)
saveTag(newTag)
console.info(`onSaveTag: ${qval(text, 'newText')}, ${qval(colour, 'newColour')}`, ...GREEN, ...GREEN)
newTag.dump()
console.info(tags)
// $(`a.userTagLink:not(.hasTag)[username=${user}]`)
$(`a.userTagLink[username=${user}]`)
.text(previousTag.text)
.css({
backgroundColor: previousTag.colour === 'none' ? 'transparent' : previousTag.colour,
color: bgToTextColorMap[previousTag.colour]
})
.addClass('hasTag')
.removeClass('RESUserTagImage')
} else {
previousTag.text = ''
previousTag.colour = 'none'
$(`a.userTagLink[username=${user}]`)
.text('')
.removeAttr('style')
.removeClass('hasTag')
.addClass('RESUserTagImage')
}
GM_setValue('tag', previousTag.text)
GM_setValue('colour', previousTag.colour)
}
// --------------------------------------------------------------------------
$('body')
.on('click.resrem', 'a.userTagLink:not(.hasTag)', () => {
setTimeout(onTagModalOpened, 250)
})
.on('click.resrem', '#userTaggerSave', onSaveTag)
})(jQuery)
jQuery.noConflict(true)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment