Github记录star时间
当前为
// ==UserScript==
// @name Github记录标星时间
// @version 1.0.0
// @author windwhim
// @description Github记录star时间
// @namespace githubstartime
// @match *github.com/*
// @icon 
// @grant GM_getValue
// @grant GM_setValue
// @grant GM_deleteValue
// @grant window.onurlchange
// @sandbox JavaScript
// @license GPL-3.0 License
// @run-at document-end
// ==/UserScript==
/* TODO:
在页面切换和数据变化时自动加载
*/
;(function () {
"use strict"
setTimeout(() => {
main()
}, 100)
//url变化时重新加载
//页面变化时重新显示
let buttonGroup = document.querySelector(
"#user-starred-repos > div > div.col-lg-9 > div.paginate-container > div"
)
if (buttonGroup) {
buttonGroup.addEventListener("click", () => {
setTimeout(() => {
main
}, 100)
})
}
function main() {
console.log("start")
let starList = document.querySelector(
"#user-starred-repos > div > div.col-lg-9, #user-list-repositories"
)
if (starList) {
let num_buttons = starList.children.length
let buttons = getStarButtons(starList, createRange(1, num_buttons))
buttons.forEach((button) => {
try {
addListener(button)
addTime(button)
} catch (e) {
if (!(e instanceof TypeError)) throw e
}
})
}
let singleButton = document.querySelector(
".js-toggler-container.js-social-container.starring-container.on.d-flex, .js-toggler-container.js-social-container.starring-container.d-flex"
)
console.log(singleButton)
if (singleButton) {
try {
addListener2(singleButton)
addTime2(singleButton)
} catch (e) {
if (!(e instanceof TypeError)) throw e
}
}
}
function addTime(element) {
let repoName = getRepoName(element)
let time = GM_getValue(repoName)
if (!time) return
let parent = element.parentNode
let pparent = parent.parentNode
let node = pparent.querySelector(".define-time")
if (node) return
let children = pparent.children
let tgtEle = children[children.length - 1]
let date = time.split(", ")[0]
tgtEle.insertAdjacentHTML(
"beforeend",
`<span class='define-time' title='${time}'>   Satrred at ${date}<span>`
)
}
//单个按钮时间
function addTime2(element) {
let repoName_all = document.querySelector(
"#repo-title-component > strong > a"
).href
let repoName = repoName_all.slice(18)
let time = GM_getValue(repoName)
if (!time) return
let parent = element.parentNode
let pparent = parent.parentNode
let ppparent = pparent.parentNode
let pppparent = ppparent.parentNode
let node = pppparent.querySelector(".define-time")
if (node) return
let date = time.split(", ")[0]
ppparent.insertAdjacentHTML(
"beforebegin",
`<span class='define-time' title='${time}' style='margin-top:3px'>   Satrred at ${date}<span>`
)
}
function removeTime(element) {
let parent = element.parentNode
let pparent = parent.parentNode
let node = pparent.querySelector(".define-time")
if (!node) return
node.remove()
}
function removeTime2(element) {
let parent = element.parentNode
let pparent = parent.parentNode
let ppparent = pparent.parentNode
let pppparent = ppparent.parentNode
let node = pppparent.querySelector(".define-time")
if (!node) return
node.remove()
}
function addListener(element) {
let buttons = element.querySelectorAll("form > button")
buttons.forEach((button) => {
button.addEventListener("click", () => {
let isStar = getStarStatus(element)
let repoName = getRepoName(element)
if (isStar) {
unStar(repoName)
removeTime(element)
} else {
doStar(repoName)
addTime(element)
}
})
})
}
//单个按钮监听
function addListener2(element) {
let buttons = element.querySelectorAll("form > button")
buttons.forEach((button) => {
button.addEventListener("click", () => {
let isStar = getStarStatus(element)
let repoName_all = document.querySelector(
"#repo-title-component > strong > a"
).href
let repoName = repoName_all.slice(18)
if (isStar) {
unStar(repoName)
removeTime2(element)
} else {
doStar(repoName)
addTime2(element)
}
})
})
}
function getStarButtons(element, indices) {
const baseSelector = "div:nth-child(index) > div.float-right.d-flex > div"
// const indices = [3, 4]; // 需要获取的索引列表
return indices.map((index) => {
const selector = baseSelector.replace("index", index)
return element.querySelector(selector)
})
}
function createRange(n, m) {
return Array.from({ length: m - n + 1 }, (_, index) => n + index)
}
function getStarStatus(element) {
let classes = element.classList
return classes.contains("on") ? true : false
}
function getRepoName(element) {
let parent = element.parentNode
//parent前一个节点
let repo = parent.previousElementSibling
let a = repo.querySelector("a")
let repoName = a.getAttribute("href")
return repoName
}
function doStar(key) {
//获取当前时间
let date = new Date().toLocaleDateString()
let now = new Date().toLocaleTimeString()
GM_setValue(key, date + ", " + now)
}
function unStar(key) {
if (!GM_getValue(key)) return
GM_deleteValue(key)
}
})()