GitHub 提交資料顯示網頁視圖

該腳本將 GitHub 上的提交資訊轉化為 HTML 視圖,以更清晰地查看提交詳情。它會自動將提交資訊列表、提交頭部和最新提交資訊轉化為 HTML 格式,提供更佳的視覺效果與使用者體驗。

  1. // ==UserScript==
  2. // @name GitHub CommitMessage Html View
  3. // @description This script converts commit messages on GitHub into HTML views for clearer visibility of commit details. It automatically transforms commit message lists, commit headers, and the latest commit information into HTML format, providing enhanced visual appeal and user experience.
  4. // @name:zh-CN GitHub 提交信息显示网页视图
  5. // @description:zh-CN 该脚本将 GitHub 上的提交信息转化为 HTML 视图,以更清晰地查看提交详情。它会自动将提交信息列表、提交头部和最新提交信息转化为 HTML 格式,提供更佳的视觉效果和用户体验。
  6. // @name:ar GitHub إرسال عرض المعلومات على شبكة الإنترنت
  7. // @description:ar هذا البرنامج النصي سوف GitHub معلومات التقديم على HTML منظر,لرؤية تفاصيل التقديم بشكل أكثر وضوحًا。وسوف يقدم تلقائيا قائمة المعلومات、يتم تحويل رأس الالتزام وأحدث معلومات الالتزام إلى HTML شكل,توفير تأثيرات بصرية أفضل وتجربة المستخدم。
  8. // @name:bg GitHub Изпращане на информация за показване на уеб изглед
  9. // @description:bg Този скрипт ще GitHub Информацията за подаване на HTML изглед,за да видите по-ясно подробностите за подаването。Той автоматично ще изпрати списъка с информация、Заглавката на ангажимента и последната информация за ангажимент се преобразуват в HTML формат,Осигурете по-добри визуални ефекти и потребителско изживяване。
  10. // @name:cs GitHub Odeslat zobrazení informací na webu
  11. // @description:cs Tento skript bude GitHub Informace o podání na HTML pohled,pro jasnější zobrazení podrobností o odeslání。Automaticky odešle informační seznam、Záhlaví odevzdání a informace o nejnovějším odevzdání se převedou na HTML Formát,Poskytujte lepší vizuální efekty a uživatelský zážitek。
  12. // @name:da GitHub Indsend informationsvisning webvisning
  13. // @description:da Dette script vil GitHub Indsendelsesoplysningerne vedr HTML udsigt,for at se indsendelsesdetaljerne mere tydeligt。Det vil automatisk indsende informationslisten、Commit-headeren og seneste commit-information konverteres til HTML Format,Giv bedre visuelle effekter og brugeroplevelse。
  14. // @name:de GitHub Webansicht zur Anzeige von Informationen übermitteln
  15. // @description:de Dieses Skript wird GitHub Die Einreichungsinformationen zu HTML Sicht,um die Einreichungsdetails klarer zu sehen。Die Informationsliste wird automatisch übermittelt、Der Commit-Header und die neuesten Commit-Informationen werden konvertiert HTML Format,Bieten Sie bessere visuelle Effekte und ein besseres Benutzererlebnis。
  16. // @name:el GitHub Υποβολή προβολής πληροφοριών ιστού
  17. // @description:el Αυτό το σενάριο θα GitHub Οι πληροφορίες υποβολής για HTML θέα,για να δείτε πιο καθαρά τις λεπτομέρειες υποβολής。Θα υποβάλει αυτόματα τη λίστα πληροφοριών、Η κεφαλίδα δέσμευσης και οι πιο πρόσφατες πληροφορίες δέσμευσης μετατρέπονται σε HTML Σχήμα και διάταξις βιβλίου,Παρέχετε καλύτερα οπτικά εφέ και εμπειρία χρήστη。
  18. // @name:en GitHub Submit information display web view
  19. // @description:en This script will GitHub The submission information on HTML view,to see submission details more clearly。It will automatically submit the information list、The commit header and latest commit information are converted to HTML Format,Provide better visual effects and user experience。
  20. // @name:eo GitHub Sendu informojn montri retejon
  21. // @description:eo Ĉi tiu skripto faros GitHub La submeta informo pri HTML vido,por pli klare vidi prezentaĵojn。Ĝi aŭtomate sendos la informliston、La commit-kapo kaj plej novaj kommit-informoj estas konvertitaj al HTML Formato,Provizu pli bonajn vidajn efikojn kaj sperton de uzanto。
  22. // @name:es GitHub Enviar información mostrar vista web
  23. // @description:es Este guión GitHub La información de presentación en HTML vista,para ver los detalles del envío más claramente。Enviará automáticamente la lista de información.、El encabezado de confirmación y la información de confirmación más reciente se convierten a HTML Formato,Proporcionar mejores efectos visuales y experiencia de usuario.。
  24. // @name:fi GitHub Lähetä tietonäytön verkkonäkymä
  25. // @description:fi Tämä käsikirjoitus tulee GitHub Lähetystiedot osoitteessa HTML näkymä,nähdäksesi lähetyksen tiedot selkeämmin。Se lähettää tietoluettelon automaattisesti、Toimitusotsikko ja viimeisimmät toimitustiedot muunnetaan muotoon HTML Muoto,Tarjoa parempia visuaalisia tehosteita ja käyttökokemusta。
  26. // @name:fr GitHub Soumettre des informations, afficher la vue Web
  27. // @description:fr Ce script sera GitHub Les informations de soumission sur HTML voir,pour voir plus clairement les détails de la soumission。Il soumettra automatiquement la liste d’informations、L’en-tête de validation et les dernières informations de validation sont convertis en HTML Format,Fournir de meilleurs effets visuels et une meilleure expérience utilisateur。
  28. // @name:he GitHub שלח תצוגת מידע באינטרנט
  29. // @description:he התסריט הזה יהיה GitHub מידע ההגשה על HTML נוֹף,כדי לראות את פרטי ההגשה בצורה ברורה יותר。זה יגיש אוטומטית את רשימת המידע、כותרת ההתחייבות ופרטי ההתחייבות העדכניים ביותר מומרים ל HTML פוּרמָט,לספק אפקטים חזותיים וחווית משתמש טובים יותר。
  30. // @name:hr GitHub Pošaljite prikaz informacija na webu
  31. // @description:hr Ova skripta će GitHub Informacije o podnošenju HTML pogled,da biste jasnije vidjeli detalje prijave。Automatski će poslati popis informacija、Zaglavlje predaje i najnovije informacije o predaji se pretvaraju u HTML Format,Omogućite bolje vizualne efekte i korisničko iskustvo。
  32. // @name:hu GitHub Információk beküldése webes nézet
  33. // @description:hu Ez a script fog GitHub A benyújtási információk a HTML kilátás,hogy tisztábban lássák a benyújtás részleteit。Automatikusan elküldi az információs listát、A véglegesítési fejléc és a legutóbbi véglegesítési információ a következőre konvertálódik HTML Formátum,Jobb vizuális effektusok és felhasználói élmény biztosítása。
  34. // @name:id GitHub Kirim informasi menampilkan tampilan web
  35. // @description:id Skrip ini akan melakukannya GitHub Informasi penyerahan pada HTML melihat,untuk melihat detail penyerahan lebih jelas。Ini secara otomatis akan mengirimkan daftar informasi、Header komit dan informasi komit terbaru dikonversi menjadi HTML Format,Memberikan efek visual dan pengalaman pengguna yang lebih baik。
  36. // @name:it GitHub Invia informazioni visualizzando la visualizzazione web
  37. // @description:it Questo script lo farà GitHub Le informazioni sull’invio su HTML visualizzazione,per visualizzare più chiaramente i dettagli dell’invio。Invierà automaticamente l’elenco delle informazioni、Vengono convertite l’intestazione del commit e le informazioni sul commit più recente HTML Formato,Fornire effetti visivi ed esperienza utente migliori。
  38. // @name:ja GitHub 情報表示Webビューの送信
  39. // @description:ja このスクリプトは、 GitHub 投稿情報は、 HTML ビュー,提出物の詳細をより明確に確認するには。情報リストを自動的に送信します、コミットヘッダーと最新のコミット情報が変換されます。 HTML 形式,より優れた視覚効果とユーザーエクスペリエンスを提供する。
  40. // @name:ka GitHub ინფორმაციის ჩვენების ვებ ხედის გაგზავნა
  41. // @description:ka ეს სკრიპტი იქნება GitHub წარდგენის შესახებ ინფორმაცია HTML ხედი,წარდგენის დეტალების უფრო ნათლად სანახავად。ის ავტომატურად წარადგენს ინფორმაციის სიას、commit header და უახლესი commit ინფორმაცია გარდაიქმნება HTML ფორმატი,უზრუნველყოს უკეთესი ვიზუალური ეფექტები და მომხმარებლის გამოცდილება。
  42. // @name:ko GitHub 정보 표시 웹뷰 제출
  43. // @description:ko 이 스크립트는 GitHub 제출정보는 HTML 보다,제출 세부정보를 더 명확하게 보려면。정보 목록이 자동으로 제출됩니다.、커밋 헤더와 최신 커밋 정보는 다음과 같이 변환됩니다. HTML 체재,더 나은 시각 효과와 사용자 경험 제공。
  44. // @name:nl GitHub Informatie verzenden webweergave weergeven
  45. // @description:nl Dit script zal GitHub De indieningsinformatie op HTML weergave,om de details van de indiening duidelijker te zien。De informatielijst wordt automatisch verzonden、De commit-header en de laatste commit-informatie worden geconverteerd naar HTML Formaat,Zorg voor betere visuele effecten en gebruikerservaring。
  46. // @name:nb GitHub Send inn informasjonsvisning på nett
  47. // @description:nb Dette skriptet vil GitHub Innsendingsinformasjonen på HTML utsikt,for å se innleveringsdetaljer tydeligere。Den vil automatisk sende inn informasjonslisten、Commit-headeren og siste commit-informasjon konverteres til HTML Format,Gi bedre visuelle effekter og brukeropplevelse。
  48. // @name:pl GitHub Prześlij informacje, aby wyświetlić widok sieciowy
  49. // @description:pl Ten skrypt to zrobi GitHub Informacje o złożeniu dot HTML pogląd,aby wyraźniej zobaczyć szczegóły przesłania。Automatycznie prześle listę informacji、Nagłówek zatwierdzenia i informacje o ostatnim zatwierdzeniu są konwertowane na HTML Format,Zapewnij lepsze efekty wizualne i wygodę użytkownika。
  50. // @name:pt-BR GitHub Enviar informações exibir visualização da web
  51. // @description:pt-BR Este roteiro irá GitHub As informações de submissão em HTML visualizar,para ver os detalhes do envio com mais clareza。Ele enviará automaticamente a lista de informações、O cabeçalho do commit e as informações do commit mais recente são convertidos para HTML Formatar,Fornece melhores efeitos visuais e experiência do usuário。
  52. // @name:ro GitHub Trimiteți informații afișați vizualizarea web
  53. // @description:ro Acest script va GitHub Informațiile de depunere pe HTML vedere,pentru a vedea detaliile trimiterii mai clar。Acesta va trimite automat lista de informații、Antetul de comitere și cele mai recente informații de comitere sunt convertite în HTML Format,Oferă efecte vizuale și experiență utilizator mai bune。
  54. // @name:ru GitHub Отправить информацию, отобразить веб-просмотр
  55. // @description:ru Этот сценарий будет GitHub Информация о подаче на HTML вид,чтобы более четко видеть детали отправки。Он автоматически отправит список информации、Заголовок фиксации и последняя информация о фиксации преобразуются в HTML Формат,Обеспечьте лучшие визуальные эффекты и удобство взаимодействия с пользователем.。
  56. // @name:sk GitHub Odoslať zobrazenie informácií na webe
  57. // @description:sk Tento skript bude GitHub Informácie o predložení na HTML pohľad,aby ste jasnejšie videli podrobnosti odoslania。Automaticky odošle informačný zoznam、Hlavička odovzdania a najnovšie informácie o odovzdaní sa skonvertujú na HTML Formátovať,Poskytnite lepšie vizuálne efekty a používateľský zážitok。
  58. // @name:sr GitHub Пошаљите приказ информација веб приказ
  59. // @description:sr Ова скрипта ће GitHub Информације о подношењу на HTML поглед,да бисте јасније видели детаље о подношењу。Аутоматски ће доставити листу информација、Заглавље урезивања и најновије информације о урезивању се конвертују у HTML Формат,Обезбедите боље визуелне ефекте и корисничко искуство。
  60. // @name:sv GitHub Skicka informationsvisning webbvy
  61. // @description:sv Detta skript kommer GitHub Inlämningsinformationen på HTML se,för att se inlämningsdetaljer tydligare。Den kommer automatiskt att skicka informationslistan、Commit-huvudet och senaste commit-informationen konverteras till HTML Formatera,Ge bättre visuella effekter och användarupplevelse。
  62. // @name:th GitHub ส่งข้อมูลแสดงมุมมองเว็บ
  63. // @description:th สคริปต์นี้จะ GitHub ข้อมูลการส่งเรื่องที่ HTML ดู,เพื่อดูรายละเอียดการส่งได้ชัดเจนยิ่งขึ้น。มันจะส่งรายการข้อมูลโดยอัตโนมัติ、ส่วนหัวการคอมมิตและข้อมูลการคอมมิตล่าสุดจะถูกแปลงเป็น HTML รูปแบบ,ให้เอฟเฟกต์ภาพและประสบการณ์ผู้ใช้ที่ดีขึ้น。
  64. // @name:tr GitHub Bilgi görüntüleme web görünümünü gönder
  65. // @description:tr Bu komut dosyası GitHub Gönderim bilgileri HTML görüş,Gönderim ayrıntılarını daha net görmek için。Bilgi listesini otomatik olarak gönderecektir、Taahhüt başlığı ve en son taahhüt bilgileri şuna dönüştürülür: HTML Biçim,Daha iyi görsel efektler ve kullanıcı deneyimi sağlayın。
  66. // @name:ug GitHub ئۇچۇر كۆرسىتىش تور كۆرۈنۈشىنى يوللاڭ
  67. // @description:ug بۇ قوليازما GitHub يوللاش ئۇچۇرى HTML كۆرۈش,تاپشۇرۇش تەپسىلاتلىرىنى تېخىمۇ ئېنىق كۆرۈش。ئۇ ئۇچۇر تىزىملىكىنى ئاپتوماتىك يوللايدۇ、ۋەدىگە مۇناسىۋەتلىك ماۋزۇ ۋە ئەڭ يېڭى ۋەدىلەر ئۇچۇرلىرىغا ئايلاندۇرۇلىدۇ HTML فورماتى,تېخىمۇ ياخشى كۆرۈش ئۈنۈمى ۋە ئىشلەتكۈچى تەجرىبىسى بىلەن تەمىنلەڭ。
  68. // @name:uk GitHub Відображення інформації в Інтернеті
  69. // @description:uk Цей сценарій буде GitHub Інформація про подання HTML переглянути,щоб чіткіше бачити деталі подання。Він автоматично надішле список інформації、Заголовок фіксації та остання інформація про фіксацію перетворюються на HTML Формат,Забезпечте кращі візуальні ефекти та досвід користувача。
  70. // @name:vi GitHub Gửi thông tin hiển thị xem web
  71. // @description:vi Kịch bản này sẽ GitHub Thông tin nộp hồ sơ trên HTML xem,để xem chi tiết gửi rõ ràng hơn。Nó sẽ tự động gửi danh sách thông tin、Tiêu đề cam kết và thông tin cam kết mới nhất được chuyển đổi thành HTML Định dạng,Cung cấp hiệu ứng hình ảnh và trải nghiệm người dùng tốt hơn。
  72. // @name:zh-TW GitHub 提交資料顯示網頁視圖
  73. // @description:zh-TW 該腳本將 GitHub 上的提交資訊轉化為 HTML 視圖,以更清晰地查看提交詳情。它會自動將提交資訊列表、提交頭部和最新提交資訊轉化為 HTML 格式,提供更佳的視覺效果與使用者體驗。
  74. // @name:zh-HK GitHub 提交資料顯示網頁視圖
  75. // @description:zh-HK 該腳本將 GitHub 上的提交資訊轉化為 HTML 視圖,以更清晰地查看提交詳情。它會自動將提交資訊列表、提交頭部和最新提交資訊轉化為 HTML 格式,提供更佳的視覺效果與使用者體驗。
  76. // @name:fr-CA GitHub Soumettre des informations, afficher la vue Web
  77. // @description:fr-CA Ce script sera GitHub Les informations de soumission sur HTML voir,pour voir plus clairement les détails de la soumission。Il soumettra automatiquement la liste d’informations、L’en-tête de validation et les dernières informations de validation sont convertis en HTML Format,Fournir de meilleurs effets visuels et une meilleure expérience utilisateur。
  78. // @version 1.0.0.19
  79. // @namespace https://github.com/ChinaGodMan/UserScripts
  80. // @author 人民的勤务员 <china.qinwuyuan@gmail.com>
  81. // @match *://github.com/*/*
  82. // @grant GM_registerMenuCommand
  83. // @grant none
  84. // @icon 
  85. // @iconbak https://github.githubassets.com/pinned-octocat.svg
  86. // @license MIT
  87. // @source https://github.com/qinwuyuan-cn/UserScripts
  88. // @supportURL https://github.com/ChinaGodMan/UserScripts/issues
  89. // @homepageURL https://github.com/ChinaGodMan/UserScripts
  90. // ==/UserScript==
  91. const selectors = {
  92. commitList: {
  93. value: '.react-directory-commit-message a', // 选择提交消息列表中的链接
  94. description: '选择仓库列表中的提交信息'
  95. },
  96. commitListFound: false,
  97. commitHeader: {
  98. value: '.fgColor-muted > span[data-testid="latest-commit-html"]', // 选择最新提交的头部信息
  99. description: '选择仓库列表头部展开详细信息'
  100. },
  101. commitHeaderScreen: {
  102. value: 'span.Truncate-text[data-testid="latest-commit-html"]', // 头部小预览
  103. description: '选择头部预览小标题'
  104. },
  105. commitLastTime: {
  106. value: 'div.react-directory-commit-age', // 选择最新提交的头部信息
  107. description: '获取最新提交信息'
  108. },
  109. commitHeaderIsRun: false,
  110. commitHeaderFound: false,
  111. commitHeaderScreenIsRun: false,
  112. commitHeaderScreenFound: false
  113. }
  114. let LastCommitText = ''
  115. let LastCommitHref = ''
  116. let wocaonima = null
  117. function updateCommitMessageInDetails(selector) {//详情页,
  118. const element = document.querySelector(selector)
  119. if (!element) return
  120. const textContent = element.textContent.trim()
  121. if (!containsHTML(textContent)) return
  122. if (wocaonima) {
  123. element.innerHTML = wocaonima
  124. } else {
  125. element.innerHTML = textContent
  126. }
  127. }
  128. function updateRepoHeaderExpandCommit(selector) {//头部展开
  129. const spanElements = document.querySelectorAll(selector)
  130. spanElements.forEach(spanElement => {
  131. const parentElement = spanElement.parentElement
  132. const textContent = spanElement.textContent.trim()
  133. const linkElement = spanElement.querySelector('a')
  134. const hrefValue = linkElement.getAttribute('href')
  135. if (containsHTML(textContent)) {
  136. if (!LastCommitHref || !LastCommitText) {
  137. spanElement.innerHTML = `<a href="${hrefValue}">` + textContent + '</a>'
  138. } else {
  139. spanElement.innerHTML = `<a href="${LastCommitHref}">` + LastCommitText + '</a>'
  140. }
  141. }
  142. })
  143. }
  144. //
  145. function updateRepoHeaderScreenCommit(selector) {
  146. const spanElements = document.querySelectorAll(selector)
  147. spanElements.forEach(spanElement => {
  148. const parentElement = spanElement.parentElement
  149. const textContent = spanElement.textContent.trim()
  150. const linkElement = spanElement.querySelector('a')
  151. const hrefValue = linkElement.getAttribute('href')
  152. if (containsHTML(textContent)) {
  153. spanElement.addEventListener('click', () => {
  154. wocaonima = spanElement.innerHTML
  155. })
  156. if (!LastCommitHref || !LastCommitText) {
  157. console.log('未通过点击跳转:', textContent)
  158. spanElement.innerHTML = `<a href="${hrefValue}">` + textContent + '</a>'
  159. } else {
  160. console.log('通过点击跳转', LastCommitText)
  161. spanElement.innerHTML = `<a href="${LastCommitHref}">` + LastCommitText + '</a>'
  162. }
  163. }
  164. })
  165. }
  166. function updateRepoListCommit(selector) {
  167. const commitMessages = document.querySelectorAll(selector)
  168. commitMessages.forEach(element => {
  169. const nextElement = element.nextElementSibling
  170. if (nextElement) (
  171. nextElement.remove()
  172. )
  173. const titleContent = element.getAttribute('title')
  174. const hrefValue = element.getAttribute('href')
  175. if (titleContent) {
  176. if (containsHTML(titleContent)) {
  177. element.addEventListener('click', () => {
  178. wocaonima = element.innerHTML
  179. })
  180. element.innerHTML = `<a href="${hrefValue}">${titleContent}</a>`
  181. }
  182. }
  183. })
  184. }
  185. function getLastTimeCommit(selector) {
  186. const allElements = document.querySelectorAll(selector)
  187. let latestElement = null
  188. let latestDate = new Date(0)
  189. allElements.forEach(div => {
  190. const relativeTime = div.querySelector('relative-time')
  191. if (relativeTime) {
  192. const datetime = relativeTime.getAttribute('datetime')
  193. if (datetime) {
  194. const currentDate = new Date(datetime)
  195. if (currentDate > latestDate) {
  196. latestDate = currentDate
  197. latestElement = div
  198. }
  199. }
  200. }
  201. })
  202. if (latestElement) {
  203. const parentTd = latestElement.closest('td')
  204. if (parentTd) {
  205. const previousTd = parentTd.previousElementSibling
  206. const linkElement = previousTd.querySelector(selectors.commitList.value)
  207. LastCommitText = linkElement.getAttribute('title')
  208. LastCommitHref = linkElement.getAttribute('href')
  209. return { previousTd, linkElement }
  210. } else {
  211. return null
  212. }
  213. } else {
  214. return null
  215. }
  216. }
  217. function containsHTML(str) {
  218. const pattern = /<\/?[a-z][\s\S]*>/i
  219. return pattern.test(str)
  220. }
  221. /**
  222. * 监视 DOM 变化,直到找到符合选择器的元素,然后执行指定的回调函数。
  223. * @param {string} selector - 要匹配的选择器。
  224. * @param {function} callback - 找到匹配元素后的回调函数。
  225. */
  226. function observeForElement(selector, callback, disconnect = true, DEBUG = '操作', isElementFound) {
  227. isElementFound = false
  228. const observer = new MutationObserver((mutationsList, observer) => {
  229. mutationsList.forEach(mutation => {
  230. if (mutation.type === 'childList') {
  231. const element = document.querySelector(selector)
  232. if (element) {
  233. if (!isElementFound) {
  234. console.log(`成功执行:${DEBUG} - ${selector} `)
  235. isElementFound = true
  236. callback(element)
  237. if (disconnect) {
  238. observer.disconnect()
  239. } //else { console.log(`没有断开监听器器: ${DEBUG} - ${selector} `) }
  240. }
  241. }
  242. }
  243. })
  244. })
  245. observer.observe(document.body, {
  246. childList: true,
  247. subtree: true
  248. })
  249. if (!disconnect) {
  250. const removalObserver = new MutationObserver(mutationsList => {
  251. mutationsList.forEach(mutation => {
  252. mutation.removedNodes.forEach(node => {
  253. const element = document.querySelector(selector)
  254. if (!element) {
  255. // console.log(`继续查找: ${DEBUG} ${selector}`)
  256. isElementFound = false
  257. }
  258. })
  259. })
  260. })
  261. removalObserver.observe(document.body, {
  262. childList: true,
  263. subtree: true
  264. })
  265. }
  266. }
  267. function observeForElement_______________________________(selector, callback) {
  268. let isElementFound = false
  269. const observer = new MutationObserver((mutationsList, observer) => {
  270. mutationsList.forEach(mutation => {
  271. if (mutation.type === 'childList' && !isElementFound) {
  272. const element = document.querySelector(selector)
  273. if (element) {
  274. console.log('成功找到仓库列表中的提交信息元素')
  275. isElementFound = true
  276. callback(element)//留着以后用
  277. observer.disconnect()
  278. }
  279. }
  280. })
  281. })
  282. observer.observe(document.body, {
  283. childList: true,
  284. subtree: true
  285. })
  286. }
  287. main()
  288. watchUpdate()
  289. function main() {
  290. LastCommitText = ''
  291. LastCommitHref = ''
  292. observeForElement(selectors.commitList.value, function (element) {
  293. updateRepoListCommit(selectors.commitList.value)
  294. },
  295. true,
  296. selectors.commitList.description,
  297. selectors.commitListFound)
  298. if (!selectors.commitHeaderIsRun) {
  299. selectors.commitHeaderIsRun = true
  300. observeForElement(
  301. selectors.commitHeader.value,
  302. function (element) {
  303. getLastTimeCommit(selectors.commitLastTime.value)//从列表获取最新的提交信息,作为进入或返回目录使用
  304. updateRepoHeaderExpandCommit(selectors.commitHeader.value)
  305. },
  306. false,
  307. selectors.commitHeader.description,
  308. selectors.commitHeaderFound
  309. )
  310. }
  311. selectors.commitHeaderScreenIsRun = false
  312. if (!selectors.commitHeaderScreenIsRun) {
  313. observeForElement(
  314. selectors.commitHeaderScreen.value,
  315. function (element) {
  316. getLastTimeCommit(selectors.commitLastTime.value)//从列表获取最新的提交信息,作为进入或返回目录使用
  317. updateRepoHeaderScreenCommit(selectors.commitHeaderScreen.value)//头部预览
  318. },
  319. false,
  320. selectors.commitHeaderScreen.description,
  321. selectors.commitHeaderScreenIsRun
  322. )
  323. }
  324. //updateCommitMessageInDetails('.commit-desc')
  325. const element = document.querySelector('.commit-title.markdown-title')
  326. if (element) {
  327. element.remove()
  328. }
  329. updateCommitMessageInDetails('.commit-desc')
  330. //updateCommitMessageInDetails('.commit-title.markdown-title')
  331. wocaonima = null
  332. //
  333. }
  334. function watchUpdate() {//检查链接变化
  335. // 检测浏览器是否支持 MutationObserver
  336. const MutationObserver =
  337. window.MutationObserver ||
  338. window.WebKitMutationObserver ||
  339. window.MozMutationObserver
  340. // 获取当前页面的 URL
  341. const getCurrentURL = () => location.href
  342. getCurrentURL.previousURL = getCurrentURL()
  343. // 创建 MutationObserver 实例,监听 DOM 变化
  344. const observer = new MutationObserver((mutations, observer) => {
  345. const currentURL = getCurrentURL()
  346. // 如果页面的 URL 发生变化
  347. if (currentURL !== getCurrentURL.previousURL) {
  348. getCurrentURL.previousURL = currentURL
  349. console.log('链接变化,正在启动监听器')
  350. setTimeout(() => {
  351. main()
  352. }, 500)
  353. }
  354. })
  355. // 配置 MutationObserver
  356. const config = {
  357. characterData: true,
  358. subtree: true,
  359. childList: true,
  360. attributeFilter: ['value', 'placeholder', 'aria-label', 'data-confirm'] // 仅观察特定属性变化
  361. }
  362. // 开始观察 document.body 的变化
  363. observer.observe(document.body, config)
  364. }

QingJ © 2025

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