GreasyFork: 导航栏增强

在导航栏上添加用户列表,控制台,收藏等..

安装此脚本?
作者推荐脚本

您可能也喜欢Greasyfork 糊裱匠

安装此脚本
  1. // ==UserScript==
  2. // @name GreasyFork: User Control Panel Button
  3. // @name:zh-CN GreasyFork: 导航栏增强
  4. // @description:zh-CN 在导航栏上添加用户列表,控制台,收藏等..
  5. // @name:ar GreasyFork: تعزيز شريط التنقل
  6. // @description:ar إضافة قائمة المستخدمين على شريط التنقل,وحدة التحكم,جمع الخ..
  7. // @name:bg GreasyFork: Подобряване на лентата за навигация
  8. // @description:bg Добавяне на потребителски списък в лентата за навигация,конзола,Колекция и др...
  9. // @name:cs GreasyFork: Vylepšení navigační lišty
  10. // @description:cs Přidejte seznam uživatelů na navigační lištu,utěšit,Sbírka atd...
  11. // @name:da GreasyFork: Forbedring af navigationslinjen
  12. // @description:da Tilføj brugerliste på navigationslinjen,konsol,Indsamling mv...
  13. // @name:de GreasyFork: Verbesserung der Navigationsleiste
  14. // @description:de Benutzerliste zur Navigationsleiste hinzufügen,Konsole,Sammlung usw...
  15. // @name:el GreasyFork: Βελτίωση της γραμμής πλοήγησης
  16. // @description:el Προσθήκη λίστας χρηστών στη γραμμή πλοήγησης,κονσόλα,Συλλογή κλπ...
  17. // @name:en GreasyFork: Navigation bar enhancement
  18. // @description:en Add user list on navigation bar,console,Collection etc...
  19. // @name:eo GreasyFork: Plibonigo de navigado trinkejo
  20. // @description:eo Aldonu uzantliston sur navigadbreto,konzolo,Kolekto ktp...
  21. // @name:es GreasyFork: Mejora de la barra de navegación
  22. // @description:es Agregar lista de usuarios en la barra de navegación,consola,Colección, etc...
  23. // @name:fi GreasyFork: Navigointipalkin parannus
  24. // @description:fi Lisää käyttäjäluettelo navigointipalkkiin,konsoli,Kokoelma jne...
  25. // @name:fr GreasyFork: Amélioration de la barre de navigation
  26. // @description:fr Ajouter une liste d’utilisateurs sur la barre de navigation,console,Collecte etc..
  27. // @name:he GreasyFork: שיפור סרגל הניווט
  28. // @description:he הוסף רשימת משתמשים בסרגל הניווט,לְנַחֵם,אוסף וכו’...
  29. // @name:hr GreasyFork: Poboljšanje navigacijske trake
  30. // @description:hr Dodajte popis korisnika na navigacijsku traku,konzola,Zbirka itd...
  31. // @name:hu GreasyFork: A navigációs sáv továbbfejlesztése
  32. // @description:hu Felhasználói lista hozzáadása a navigációs sávhoz,konzol,Gyűjtemény stb...
  33. // @name:id GreasyFork: Peningkatan bilah navigasi
  34. // @description:id Tambahkan daftar pengguna di bilah navigasi,menghibur,Koleksi dll...
  35. // @name:it GreasyFork: Miglioramento della barra di navigazione
  36. // @description:it Aggiungi l’elenco degli utenti sulla barra di navigazione,consolle,Raccolta ecc...
  37. // @name:ja GreasyFork: ナビゲーションバーの強化
  38. // @description:ja ナビゲーションバーにユーザーリストを追加,コンソール,コレクションなど..
  39. // @name:ka GreasyFork: ნავიგაციის ზოლის გაუმჯობესება
  40. // @description:ka დაამატეთ მომხმარებლის სია ნავიგაციის ზოლში,კონსოლი,კოლექცია და ა.შ...
  41. // @name:ko GreasyFork: 탐색 표시줄 개선
  42. // @description:ko 탐색 표시줄에 사용자 목록 추가,콘솔,수집 등..
  43. // @name:nl GreasyFork: Verbetering van de navigatiebalk
  44. // @description:nl Voeg een gebruikerslijst toe aan de navigatiebalk,troosten,Collectie enz...
  45. // @name:nb GreasyFork: Forbedring av navigasjonslinjen
  46. // @description:nb Legg til brukerliste på navigasjonslinjen,konsoll,Samling etc...
  47. // @name:pl GreasyFork: Udoskonalenie paska nawigacji
  48. // @description:pl Dodaj listę użytkowników na pasku nawigacyjnym,konsola,Kolekcja itp...
  49. // @name:pt-BR GreasyFork: Aprimoramento da barra de navegação
  50. // @description:pt-BR Adicionar lista de usuários na barra de navegação,console,Coleção etc..
  51. // @name:ro GreasyFork: Îmbunătățirea barei de navigare
  52. // @description:ro Adăugați lista de utilizatori pe bara de navigare,consolă,Colectare etc...
  53. // @name:ru GreasyFork: Улучшение панели навигации
  54. // @description:ru Добавить список пользователей на панель навигации,консоль,Коллекция и т. д...
  55. // @name:sk GreasyFork: Vylepšenie navigačnej lišty
  56. // @description:sk Pridajte zoznam používateľov na navigačnú lištu,konzoly,Zbierka atď...
  57. // @name:sr GreasyFork: Побољшање траке за навигацију
  58. // @description:sr Додајте листу корисника на траку за навигацију,конзола,Збирка итд...
  59. // @name:sv GreasyFork: Förbättring av navigeringsfältet
  60. // @description:sv Lägg till användarlista i navigeringsfältet,trösta,Samling etc...
  61. // @name:th GreasyFork: การเพิ่มประสิทธิภาพแถบนำทาง
  62. // @description:th เพิ่มรายชื่อผู้ใช้บนแถบนำทาง,คอนโซล,คอลเลกชัน ฯลฯ..
  63. // @name:tr GreasyFork: Gezinme çubuğu geliştirmesi
  64. // @description:tr Gezinme çubuğuna kullanıcı listesi ekleyin,konsol,Koleksiyon vb...
  65. // @name:ug GreasyFork: يولباشچى بالداقنى كۈچەيتىش
  66. // @description:ug يولباشچى ستونىغا ئىشلەتكۈچى تىزىملىكىنى قوشۇڭ,console,توپلاش قاتارلىقلار...
  67. // @name:uk GreasyFork: Покращення панелі навігації
  68. // @description:uk Додати список користувачів на панель навігації,консоль,Колекція тощо..
  69. // @name:vi GreasyFork: Cải tiến thanh điều hướng
  70. // @description:vi Thêm danh sách người dùng trên thanh điều hướng,bảng điều khiển,Bộ sưu tập vv...
  71. // @name:zh-TW GreasyFork: 導覽列增強
  72. // @description:zh-TW 在導覽列上新增使用者列表,主機,收藏等..
  73. // @name:zh-HK GreasyFork: 導覽列增強
  74. // @description:zh-HK 在導覽列上新增使用者列表,主機,收藏等..
  75. // @name:fr-CA GreasyFork: Amélioration de la barre de navigation
  76. // @description:fr-CA Ajouter une liste d’utilisateurs sur la barre de navigation,console,Collecte etc..
  77. // @namespace https://github.com/ChinaGodMan/UserScripts
  78. // @match https://gf.qytechs.cn/*
  79. // @match https://sleazyfork.org/*
  80. // @grant none
  81. // @version 0.3.1.57
  82. // @license MIT
  83. // @author CY Fung & 人民的勤务员 <china.qinwuyuan@gmail.com>
  84. // @description To add User Control Panel Button into navigation bar
  85. // @icon 
  86. // @iconbak https://gf.qytechs.cn/vite/assets/blacklogo96-CxYTSM_T.png
  87. // @supportURL https://github.com/ChinaGodMan/UserScripts/issues
  88. // @homepageURL https://github.com/ChinaGodMan/UserScripts
  89. // ==/UserScript==
  90.  
  91. (async () => {
  92. let sections = [
  93. { id: '#user-script-sets-section' },
  94. { id: '#control-panel' },
  95. // { id: '#user-library-list-section', name: '库' },
  96. //{ id: '#user-unlisted-script-list-section', name: '没上架' },
  97. // { id: '#user-discussions', name: '讨论' },
  98. { id: '#user-script-list-section' }
  99. ]
  100.  
  101. function preSetup() {
  102. let pos = document.querySelectorAll('#site-nav>nav>li.with-submenu')
  103. pos = pos.length >= 1 ? pos[pos.length - 1] : null
  104.  
  105. if (!pos) return
  106.  
  107. pos.parentNode.style.minHeight = '2.8rem'
  108.  
  109. return { pos }
  110. }
  111.  
  112. function setup(m, namespace) {
  113. const { cpmRoot } = m
  114.  
  115. let h = cpmRoot.querySelector('h3') || cpmRoot.querySelector('header')
  116. if (!h) return
  117.  
  118. let nav = document.createElement('nav')
  119.  
  120. let addedText = new Set()
  121. let lastText = null
  122.  
  123. for (const anchor of cpmRoot.querySelectorAll('li a[href]')) {
  124. let textContent = anchor.textContent.trim()
  125.  
  126. if (addedText.has(textContent)) {
  127. lastText = textContent
  128. continue
  129. }
  130.  
  131. let li = nav.appendChild(document.createElement('li'))
  132. li.appendChild(anchor)
  133.  
  134. addedText.add(textContent)
  135. }
  136.  
  137. if (lastText !== null) {
  138. nav.querySelectorAll('li').forEach(li => {
  139. if (li.querySelector('a').textContent.trim() === lastText) {
  140. li.remove()
  141. }
  142. })
  143. }
  144.  
  145. let tm = document.createElement('template')
  146. tm.innerHTML = `
  147. <li class="with-submenu" style="display: block;">
  148. <a href="#" onclick="return false">${namespace ? namespace : h.textContent}</a>
  149. <nav style="min-width: initial;">
  150. ${nav.innerHTML}
  151. </nav>
  152. </li>
  153. `.trim()
  154.  
  155. return tm.content
  156. }
  157.  
  158. function bufferToHex(buffer) {
  159. const byteArray = new Uint8Array(buffer)
  160. const len = byteArray.length
  161. const hexCodes = new Array(len * 2)
  162. const chars = '0123456789abcdef'
  163. for (let i = 0, j = 0; i < len; i++) {
  164. const byte = byteArray[i]
  165. hexCodes[j++] = chars[byte >> 4]
  166. hexCodes[j++] = chars[byte & 0x0F]
  167. }
  168. return hexCodes.join('')
  169. }
  170.  
  171. async function digestMessage(message) {
  172. const encoder = new TextEncoder('utf-8')
  173. const msgUint8 = encoder.encode(message)
  174. const hashBuffer = await crypto.subtle.digest('SHA-1', msgUint8)
  175. return bufferToHex(hashBuffer)
  176. }
  177.  
  178. async function fetchHTML(href) {
  179. let response = await fetch(href, {
  180. method: 'GET',
  181. mode: 'same-origin',
  182. cache: 'force-cache',
  183. credentials: 'same-origin',
  184. redirect: 'follow',
  185. referrerPolicy: 'no-referrer'
  186. })
  187.  
  188. return response.text()
  189. }
  190.  
  191. async function addSectionsToNav() {
  192. let presetup = preSetup()
  193. if (!presetup) return
  194. const { pos } = presetup
  195.  
  196. let plink = document.querySelector('.user-profile-link')
  197. if (!plink) return
  198. let href = plink.querySelector('a[href*="/users/"]').href
  199. if (href.includes('/users/sign')) return
  200.  
  201. let dm = await digestMessage(href)
  202. const stKey = `gf_user_page_${dm}`
  203.  
  204. for (let trialN = 8; trialN--;) {
  205. let s = sessionStorage.getItem(stKey)
  206. let d = typeof s === 'string' ? parseInt(s) : 0
  207. if (d > 9 && Date.now() - d < 8000) await new Promise(r => setTimeout(r, 320))
  208. else break
  209. }
  210.  
  211. const userPageHTML = await fetchHTML(href)
  212. if (!userPageHTML || typeof userPageHTML !== 'string') return
  213.  
  214. sessionStorage.setItem(stKey, userPageHTML)
  215.  
  216. let template = document.createElement('template')
  217. template.innerHTML = userPageHTML
  218. const content = template.content
  219.  
  220.  
  221.  
  222. sections.forEach(({ id, name }) => {
  223. let section = content.querySelector(id)
  224. if (section) {
  225. const kc = setup({ cpmRoot: section, pos }, name)
  226. if (kc) {
  227. pos.parentNode.insertBefore(kc, pos.nextSibling)
  228. }
  229. }
  230. })
  231. }
  232.  
  233. if (!document.querySelector('.sign-out-link') || document.querySelector('.sign-in-link')) return
  234.  
  235. await addSectionsToNav()
  236. })()

QingJ © 2025

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