Github记录标星时间

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}'>&nbsp&nbsp&nbspSatrred 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'>&nbsp&nbsp&nbspSatrred 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)
  }
})()

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址