Compare commits

..

1 Commits

Author SHA1 Message Date
428c967255 Rewrite 2025-05-18 03:38:55 -04:00
2 changed files with 77 additions and 46 deletions

View File

@ -2,30 +2,35 @@
// @name ycombinator-keys // @name ycombinator-keys
// @namespace https://gitea.amine-bouabdallaoui.fr/AmineB/ycombinator-keys // @namespace https://gitea.amine-bouabdallaoui.fr/AmineB/ycombinator-keys
// @license gpl-3.0-only // @license gpl-3.0-only
// @match http*://news.ycombinator.com/* // @match *://news.ycombinator.com/*
// @icon https://gitea.amine-bouabdallaoui.fr/AmineB/ycombinator-keys/raw/branch/main/icons/48.png // @icon https://gitea.amine-bouabdallaoui.fr/AmineB/ycombinator-keys/raw/branch/main/icons/48.png
// @grant none // @grant none
// @version 4 // @version 4
// @author AmineB // @author AmineB
// @description Ycombinator keyboard nav. // @description Ycombinator keyboard nav.
// @downloadURL https://gitea.amine-bouabdallaoui.fr/brian6932/ycombinator-keys/raw/branch/main/keyboard-watcher.js // @downloadURL https://gitea.amine-bouabdallaoui.fr/AmineB/ycombinator-keys/raw/branch/main/keyboard-watcher.user.js
// @updateURL https://gitea.amine-bouabdallaoui.fr/brian6932/ycombinator-keys/raw/branch/main/keyboard-watcher.js // @updateURL https://gitea.amine-bouabdallaoui.fr/AmineB/ycombinator-keys/raw/branch/main/keyboard-watcher.user.js
// ==/UserScript== // ==/UserScript==
// jshint esversion: 11 // jshint esversion: 11
let selected = -1 globalThis.document.styleSheets[0].insertRule('tbody tr.athing>td.title>span.titleline>a:focus,tbody tr.athing.comtr a.togg.clicky:focus{outline: none}')
globalThis.document.styleSheets[0].insertRule('tbody tr.athing>td.title>span.titleline>a:focus,.athing.comtr a.togg.clicky:focus{outline: none}')
const requery = () => globalThis.document.querySelectorAll('tbody tr.athing') const requery = () => globalThis.document.querySelectorAll('tbody tr.athing')
let query = requery() let
query = requery(),
selected = -1,
lastCollapsed
const const
input = new Set()
.add('INPUT')
.add('TEXTAREA'),
// This is a Firefox only option. For some reason older versions of Firefox can't set outline: none. // This is a Firefox only option. For some reason older versions of Firefox can't set outline: none.
focusInvisible = { __proto__: null, focusVisible: false }, focusInvisible = { __proto__: null, focusVisible: false },
isComment = () => query[selected].classList.contains('comtr'),
highlightSelected = () => { highlightSelected = () => {
query[selected].style.boxShadow = '0px 0px 10px 4px rgba(0,0,0,0.73)' query[selected].style.boxShadow = '0px 0px 10px 4px rgba(0,0,0,0.73)'
globalThis.location.pathname === '/item' ? isComment() ?
// Drawing the boxShadow on this selector isn't visible enough. // Drawing the boxShadow on this selector isn't visible enough.
query[selected].querySelector('a.togg.clicky')?.focus(focusInvisible) query[selected].querySelector('a.togg.clicky')?.focus(focusInvisible)
: :
@ -33,48 +38,74 @@ const
query[selected].lastChild.firstChild.firstChild.focus(focusInvisible) query[selected].lastChild.firstChild.firstChild.focus(focusInvisible)
}, },
keydown = event => { keydown = event => {
switch (event.key) { if (!input.has(event.target.tagName))
case 'j': switch (event.key) {
if (selected + 1 === query.length) case 'j':
return const lastIndex = query.length - 1
if (selected === lastIndex)
return
if (selected !== -1) if (selected !== -1)
query[selected].style.boxShadow = '' query[selected].style.boxShadow = ''
while (selected < query.length && query[++selected].classList.contains('noshow')); let hiddenChain = 0
highlightSelected() while (selected < lastIndex) {
return const hidden = query[++selected].classList.contains('noshow')
case 'k': hiddenChain = hiddenChain * hidden + hidden
if (selected <= 0)
return
query[selected].style.boxShadow = '' if (!hidden) {
while (selected >= 0 && query[--selected].classList.contains('noshow')); lastCollapsed = query[selected].classList.contains('coll') ? selected : undefined
highlightSelected()
return
case 'h':
if (globalThis.location.pathname === '/hidden')
for (const selector of query[selected].nextSibling.querySelectorAll('a'))
if (selector.innerText === 'un-hide') {
selector.click()
break break
} }
else }
query[selected].nextSibling.querySelector('a.clicky.hider')?.click()
highlightSelected() selected -= hiddenChain * (selected - hiddenChain === lastCollapsed)
return highlightSelected()
case 'c': return
globalThis.open('https://news.ycombinator.com/item?id=' + query[selected].id, '_self') case 'k':
return if (selected <= 0)
case 'C': return
globalThis.open('https://news.ycombinator.com/item?id=' + query[selected].id)
return query[selected].style.boxShadow = ''
case 'u':
globalThis.open(globalThis.location.pathname === '/item' ? query[selected].querySelector('a.hnuser').href : query[selected].nextSibling.querySelector('a.hnuser').href, '_self') while (selected >= 0 && query[--selected].classList.contains('noshow'));
return highlightSelected()
case 'U': return
globalThis.open(globalThis.location.pathname === '/item' ? query[selected].querySelector('a.hnuser').href : query[selected].nextSibling.querySelector('a.hnuser').href) case 'h':
} if (globalThis.location.pathname === '/hidden')
for (const selector of query[selected].nextSibling.querySelectorAll('a'))
if (selector.innerText === 'un-hide') {
selector.click()
break
}
else
query[selected].nextSibling.querySelector('a.clicky.hider')?.click()
if (selected + 1 <= query.length)
highlightSelected()
return
case 'c':
globalThis.open('https://news.ycombinator.com/item?id=' + query[selected].id, '_self')
return
case 'C':
globalThis.open('https://news.ycombinator.com/item?id=' + query[selected].id)
return
case 'r':
if (!isComment())
return
globalThis.open(query[selected].querySelector('div.reply a').href, '_self')
return
case 'R':
if (!isComment())
return
globalThis.open(query[selected].querySelector('div.reply a').href)
return
case 'u':
globalThis.open((isComment() ? query[selected] : query[selected].nextSibling).querySelector('a.hnuser').href, '_self')
return
case 'U':
globalThis.open((isComment() ? query[selected] : query[selected].nextSibling).querySelector('a.hnuser').href)
}
}, },
listen = () => globalThis.document.addEventListener('keydown', keydown) listen = () => globalThis.document.addEventListener('keydown', keydown)

View File

@ -12,7 +12,7 @@
"*://news.ycombinator.com/*" "*://news.ycombinator.com/*"
], ],
"js": [ "js": [
"keyboard-watcher.js" "keyboard-watcher.user.js"
] ]
} }
], ],