Greasy Fork镜像 支持简体中文。

GitHub Gist 代碼片段複製與下載器

向 Gist 文件添加複制按鈕,以便輕鬆複製代碼。 | 向 Gist 文件添加下載按鈕,以便輕鬆下載代碼。

  1. // ==UserScript==
  2. // @name GitHub Gist Copier & Downloader
  3. // @name:ar Github Gist Code Snippet Copy and Downloader
  4. // @name:bg Github Gist код Shippet Copy and Downloader
  5. // @name:cs Github Gist Code Snippet Copy and Downloader
  6. // @name:da GitHub Gist Code Strappet Copy and Downloader
  7. // @name:de Github Gist Code Snippet Copy und Downloader
  8. // @name:el GitHub Gist Κωδικός απόσπασμα και λήψη
  9. // @name:en GitHub Gist code snippet copy and downloader
  10. // @name:eo Github Gist Code Snippet Copy and Downloader
  11. // @name:es Copia y descargador de fragmentos de código Github Gist
  12. // @name:fi Github GIST -koodin katkelma kopio ja lataaja
  13. // @name:fr GitHub Gist Code Snippet Copy and Downloader
  14. // @name:fr-CA GitHub Gist Code Snippet Copy and Downloader
  15. // @name:he Github GiSt Code Snippet Copy and Downloader
  16. // @name:hr GitHub Gist Code Snippet Kopiranje i preuzimanje
  17. // @name:hu GitHub GIST kódrészlet másolat és letöltő
  18. // @name:id Salinan dan download cuplikan kode GIST GITHUB
  19. // @name:it Copia di snippet di codice GIST GIST e downloader
  20. // @name:ja GitHub Gistコードスニペットコピーとダウンローダー
  21. // @name:ka Github gist კოდის snippet ასლი და ჩამოტვირთვა
  22. // @name:ko github gist 코드 스 니펫 복사 및 다운로더
  23. // @name:nb GitHub Gist Code Snippet Copy and Downloader
  24. // @name:nl GitHub Gist Code Snippet Copy and Downloader
  25. // @name:pl Github gist kod kodu fragmentu i downloader
  26. // @name:pt-BR Cópia do snippet e downloader de código de código do Github
  27. // @name:ro Github Gist Code Snipt Copy and Downloader
  28. // @name:ru Github Gist Code Specy Copy and Downloader
  29. // @name:sk Kópia a sťahovanie kódu github gist
  30. // @name:sr ГитХуб Гист Цоде Сниппет Копирање и преузимање
  31. // @name:sv Github gist code kodavsnitt kopia och nedladdare
  32. // @name:th GitHub Gist Code Snippet Copy and Downloader
  33. // @name:tr Github Gist Kodu Snippet Copy ve Downloader
  34. // @name:ug GitHub GIST CLIPTE CLIPPET ۋە چۈشۈرگۈچى
  35. // @name:uk Копія та завантажувач Github Github Gist Code
  36. // @name:vi Github Gist Code Snippet Sao chép và tải xuống
  37. // @name:zh GitHub Gist 代码片段复制与下载器
  38. // @name:zh-CN GitHub Gist 代码片段复制与下载器
  39. // @name:zh-HK GitHub Gist 代碼片段複製與下載器
  40. // @name:zh-SG GitHub Gist 代码片段复制与下载器
  41. // @name:zh-TW GitHub Gist 代碼片段複製與下載器
  42. // @description Adds copy button to Gist files for easy code copying.| Adds download button to Gist files for easy code downloading.
  43. // @description:ar أضف زر نسخ إلى ملف GIST لجعل الكود يتم نسخه بسهولة. |
  44. // @description:bg Добавете бутон за копиране към файла на GIST, за да направите лесно копирания код. |.
  45. // @description:cs Přidejte tlačítko Kopírovat do souboru GIST, aby se kód snadno zkopíroval. |.
  46. // @description:da Tilføj en kopi -knap til GIST -filen for at gøre koden let kopieret. |.
  47. // @description:de Fügen Sie der GIST -Datei eine Kopierschaltfläche hinzu, um den Code leicht zu kopieren. |.
  48. // @description:el Προσθέστε ένα κουμπί αντιγραφής στο αρχείο GIST για να αντιγράψετε εύκολα τον κώδικα. | Προσθέστε ένα κουμπί λήψης στο αρχείο GIST για εύκολη λήψη του κώδικα.
  49. // @description:en Add a copy button to the Gist file to make the code easily copied. | Add a download button to the Gist file to easily download the code.
  50. // @description:eo Aldonu kopian butonon al la GIST -dosiero por fari la kodon facile kopiita. | Aldoni elŝutan butonon al la GIST -dosiero por facile elŝuti la kodon.
  51. // @description:es Agregue un botón de copia al archivo GIST para que el código se copie fácilmente. | Agregar un botón de descarga al archivo GIST para descargar fácilmente el código.
  52. // @description:fi Lisää kopio -painike GIST -tiedostoon, jotta koodi kopioidaan helposti. | Lisää latauspainike GIST -tiedostoon koodin helposti.
  53. // @description:fr Ajoutez un bouton de copie au fichier GIST pour que le code soit facilement copié. | Ajouter un bouton de téléchargement au fichier GIST pour télécharger facilement le code.
  54. // @description:fr-CA Ajoutez un bouton de copie au fichier GIST pour que le code soit facilement copié. | Ajouter un bouton de téléchargement au fichier GIST pour télécharger facilement le code.
  55. // @description:he הוסף כפתור העתק לקובץ ה- GIST כדי להפוך את הקוד להעתיק בקלות. |.
  56. // @description:hr Dodajte gumb za kopiranje u datoteku Gist da biste se kôd lako kopirali. | Dodajte gumb za preuzimanje u datoteku Gist da biste lako preuzeli kôd.
  57. // @description:hu Adjon hozzá egy másolat gombot a GIST fájlhoz, hogy a kód könnyen másoljon. | Adjon hozzá egy letöltési gombot a GIST fájlhoz, hogy könnyen letöltse a kódot.
  58. // @description:id Tambahkan tombol Salin ke file GIST untuk membuat kode dengan mudah disalin. Tambahkan tombol unduh ke file GIST untuk dengan mudah mengunduh kode.
  59. // @description:it Aggiungi un pulsante Copia al file GIST per rendere il codice facilmente copiato. | Aggiungi un pulsante di download al file GIST per scaricare facilmente il codice.
  60. // @description:ja GISTファイルにコピーボタンを追加して、コードを簡単にコピーすることができます。 |ダウンロードボタンをGISTファイルに追加して、コードを簡単にダウンロードします。
  61. // @description:ka დაამატეთ კოპირების ღილაკი GIST ფაილში, რომ კოდი ადვილად გადაწეროთ. |
  62. // @description:ko 코드를 쉽게 복사하기 위해 GIST 파일에 복사 버튼을 추가하십시오. |. 코드를 쉽게 다운로드하려면 GIST 파일에 다운로드 버튼을 추가하십시오.
  63. // @description:nb Legg til en kopiknapp i GIST -filen for å gjøre koden enkelt kopiert. |.
  64. // @description:nl Voeg een kopie -knop toe aan het GIST -bestand om de code gemakkelijk te laten kopiëren. | Voeg een downloadknop toe aan het GIST -bestand om de code eenvoudig te downloaden.
  65. // @description:pl Dodaj przycisk kopii do pliku GIST, aby kod był łatwy do kopiowania. |
  66. // @description:pt-BR Adicione um botão de cópia ao arquivo GIST para tornar o código facilmente copiado. |.
  67. // @description:ro Adăugați un buton de copiere în fișierul GIST pentru a face codul ușor copiat. |
  68. // @description:ru Добавьте кнопку копирования в файл GIST, чтобы сделать код легко скопированный. |.
  69. // @description:sk Pridajte tlačidlo kopírovania do súboru GIST, aby sa kód ľahko skopíroval. | Dodajte tlačidlo sťahovania do súboru GIST, aby ste si ľahko stiahnuť kód.
  70. // @description:sr Додајте дугме за копирање у датотеку Гист да бисте кодекс лако копирали. | Додајте дугме за преузимање у датотеку ГИСТ да бисте лако преузели код.
  71. // @description:sv Lägg till en kopieringsknapp i GIST -filen så att koden enkelt kopieras. | Lägg till en nedladdningsknapp i GIST -filen för att enkelt ladda ner koden.
  72. // @description:th เพิ่มปุ่มคัดลอกไปยังไฟล์ GIST เพื่อให้รหัสคัดลอกได้อย่างง่ายดาย | เพิ่มปุ่มดาวน์โหลดไปยังไฟล์ GIST เพื่อดาวน์โหลดรหัสได้อย่างง่ายดาย
  73. // @description:tr Kodu kolayca kopyalamak için GIST dosyasına bir kopya düğmesi ekleyin. Kodu kolayca indirmek için bir indir düğmesi ekleyin.
  74. // @description:ug كود ھۆججىتىگە بىر نۇسخا قوشۇش كۇنۇپكىسىنى قوشۇڭ. | بىز GIST ھۆججىتىگە چۈشۈرۈش كۇنۇپكىسىنى قوشۇڭ, كودنى ئاسانلا چۈشۈرۈش.
  75. // @description:uk Додайте кнопку копіювання до файлу GIST, щоб зробити код легко скопіювати. | Додайте кнопку завантаження до файлу GIST, щоб легко завантажити код.
  76. // @description:vi Thêm một nút sao chép vào tệp GIST để dễ dàng sao chép mã. |
  77. // @description:zh 向 Gist 文件添加复制按钮,以便轻松复制代码。| 向 Gist 文件添加下载按钮,以便轻松下载代码。
  78. // @description:zh-CN 向 Gist 文件添加复制按钮,以便轻松复制代码。| 向 Gist 文件添加下载按钮,以便轻松下载代码。
  79. // @description:zh-HK 向 Gist 文件添加複制按鈕,以便輕鬆複製代碼。 | 向 Gist 文件添加下載按鈕,以便輕鬆下載代碼。
  80. // @description:zh-SG 向 Gist 文件添加复制按钮,以便轻松复制代码。| 向 Gist 文件添加下载按钮,以便轻松下载代码。
  81. // @description:zh-TW 向 Gist 文件添加複制按鈕,以便輕鬆複製代碼。 | 向 Gist 文件添加下載按鈕,以便輕鬆下載代碼。
  82. // @author afkarxyz,人民的勤务员 <china.qinwuyuan@gmail.com>
  83. // @namespace https://github.com/ChinaGodMan/UserScripts
  84. // @supportURL https://github.com/ChinaGodMan/UserScripts/issues
  85. // @homepageURL https://github.com/ChinaGodMan/UserScripts
  86. // @license MIT
  87. // @icon 
  88. // @run-at document-end
  89. // @match https://gist.github.com/*
  90. // @grant GM_xmlhttpRequest
  91. // @grant GM_addStyle
  92. // @connect githubusercontent.com
  93. // @compatible chrome
  94. // @compatible firefox
  95. // @compatible edge
  96. // @compatible opera
  97. // @compatible safari
  98. // @compatible kiwi
  99. // @compatible qq
  100. // @compatible via
  101. // @compatible brave
  102. // @version 2025.03.18.0659
  103. // @created 2025-03-12 00:22:40
  104. // @modified 2025-03-12 00:22:40
  105. // ==/UserScript==
  106. /**
  107. * File: github-gist-copier.user.js
  108. * Project: UserScripts
  109. * File Created: 2025/03/12,Wednesday 00:22:50
  110. * Author: 人民的勤务员@ChinaGodMan (china.qinwuyuan@gmail.com)
  111. * -----
  112. * Last Modified: 2025/03/18,Tuesday 06:59:14
  113. * Modified By: 人民的勤务员@ChinaGodMan (china.qinwuyuan@gmail.com)
  114. * -----
  115. * License: MIT License
  116. * Copyright © 2024 - 2025 ChinaGodMan,Inc
  117. */
  118. (function () {
  119. 'use strict'
  120. const compactGist = true
  121. function noop() { }
  122. function debounce(f, delay) {
  123. let timeoutId = null
  124. return function (...args) {
  125. if (timeoutId) {
  126. clearTimeout(timeoutId)
  127. }
  128. timeoutId = setTimeout(() => {
  129. f.apply(this, args)
  130. }, delay)
  131. }
  132. }
  133.  
  134. function createCopyButton(fileElement) {
  135. const fileActionElement = fileElement.querySelector('.file-actions')
  136. if (!fileActionElement) {
  137. return noop
  138. }
  139.  
  140. const rawButton = fileActionElement.querySelector('a[href*="/raw/"]')
  141. if (!rawButton) {
  142. return noop
  143. }
  144.  
  145. const buttonToDown = document.createElement('button')
  146. buttonToDown.className = 'btn-octicon gist-down-button'
  147. buttonToDown.style.marginRight = '5px'
  148. const button = document.createElement('button')
  149. button.className = 'btn-octicon gist-copy-button'
  150. button.style.marginRight = '5px'
  151. buttonToDown.innerHTML = `
  152. <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-down">
  153. <path d="M2.75 14A1.75 1.75 0 0 1 1 12.25v-2.5a.75.75 0 0 1 1.5 0v2.5c0 .138.112.25.25.25h10.5a.25.25 0 0 0 .25-.25v-2.5a.75.75 0 0 1 1.5 0v2.5A1.75 1.75 0 0 1 13.25 14Z"></path>
  154. <path d="M7.25 7.689V2a.75.75 0 0 1 1.5 0v5.689l1.97-1.969a.749.749 0 1 1 1.06 1.06l-3.25 3.25a.749.749 0 0 1-1.06 0L4.22 6.78a.749.749 0 1 1 1.06-1.06l1.97 1.969Z"></path>
  155. </svg>
  156.  
  157. <svg style="display: none;" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-check color-fg-success">
  158. <path d="M13.78 4.22a.75.75 0 0 1 0 1.06l-7.25 7.25a.75.75 0 0 1-1.06 0L2.22 9.28a.751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018L6 10.94l6.72-6.72a.75.75 0 0 1 1.06 0Z"></path>
  159. </svg>
  160. `
  161.  
  162. button.innerHTML = `
  163. <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-copy">
  164. <path d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 0 1 0 1.5h-1.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-1.5a.75.75 0 0 1 1.5 0v1.5A1.75 1.75 0 0 1 9.25 16h-7.5A1.75 1.75 0 0 1 0 14.25Z"></path><path d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0 1 14.25 11h-7.5A1.75 1.75 0 0 1 5 9.25Zm1.75-.25a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-7.5a.25.25 0 0 0-.25-.25Z"></path>
  165. </svg>
  166.  
  167. <svg style="display: none;" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-check color-fg-success">
  168. <path d="M13.78 4.22a.75.75 0 0 1 0 1.06l-7.25 7.25a.75.75 0 0 1-1.06 0L2.22 9.28a.751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018L6 10.94l6.72-6.72a.75.75 0 0 1 1.06 0Z"></path>
  169. </svg>
  170. `
  171.  
  172. const copyIcon = button.querySelector('.octicon-copy')
  173. const checkIcon = button.querySelector('.octicon-check')
  174. const downIcon = buttonToDown.querySelector('.octicon-down')
  175. const downcheckIcon = buttonToDown.querySelector('.octicon-check')
  176. let timeoutId = null
  177. const copyHandler = (e) => {
  178. if (timeoutId) {
  179. return
  180. }
  181. e.preventDefault()
  182. const rawUrl = rawButton.href
  183. GM_xmlhttpRequest({
  184. method: 'GET',
  185. url: rawUrl,
  186. onload: function (response) {
  187. if (response.status === 200) {
  188. navigator.clipboard.writeText(response.responseText).then(() => {
  189. copyIcon.style.display = 'none'
  190. checkIcon.style.display = 'inline-block'
  191. timeoutId = setTimeout(() => {
  192. copyIcon.style.display = 'inline-block'
  193. checkIcon.style.display = 'none'
  194. timeoutId = null
  195. }, 500)
  196. }).catch(err => {
  197. console.error('Failed to copy text: ', err)
  198. })
  199. }
  200. },
  201. onerror: function (error) {
  202. timeoutId = null
  203. }
  204. })
  205. }
  206. const downHandler = (e, element) => {
  207. if (timeoutId) {
  208. return
  209. }
  210. e.preventDefault()
  211. const gistName = element.parentElement.querySelector('.gist-blob-name').innerText
  212. const rawUrl = rawButton.href
  213. if (gistName.slice(-8) === '.user.js') {
  214. const a = document.createElement('a')
  215. a.href = rawUrl
  216. a.click()
  217. return
  218. }
  219. GM_xmlhttpRequest({
  220. method: 'GET',
  221. url: rawUrl,
  222. onload: function (response) {
  223. if (response.status === 200) {
  224. const blob = new Blob([response.responseText], {
  225. type: 'text/plain'
  226. })
  227. const url = URL.createObjectURL(blob)
  228. const a = document.createElement('a')
  229. a.href = url
  230. a.download = gistName
  231. a.click()
  232. downIcon.style.display = 'none'
  233. downcheckIcon.style.display = 'inline-block'
  234. timeoutId = setTimeout(() => {
  235. downIcon.style.display = 'inline-block'
  236. downcheckIcon.style.display = 'none'
  237. timeoutId = null
  238. }, 500)
  239. } else {
  240. console.error('Download Failed')
  241. }
  242. },
  243. onerror: function (error) {
  244. timeoutId = null
  245. }
  246. })
  247. }
  248.  
  249. buttonToDown.addEventListener('click', (e) => downHandler(e, fileActionElement))
  250. button.addEventListener('click', copyHandler)
  251. fileActionElement.insertBefore(button, fileActionElement.firstChild)
  252. fileActionElement.insertBefore(buttonToDown, fileActionElement.firstChild)
  253. return () => {
  254. button.removeEventListener('click', copyHandler)
  255. if (timeoutId) {
  256. clearTimeout(timeoutId)
  257. }
  258. button.remove()
  259. }
  260. }
  261.  
  262. function runGist() {
  263. let removeAllListeners = noop
  264.  
  265. function tryCreateCopyButtons() {
  266. removeAllListeners()
  267. const fileElements = [...document.querySelectorAll('.file')]
  268. const removeListeners = fileElements.map(createCopyButton)
  269. removeAllListeners = () => {
  270. removeListeners.map((f) => f());
  271. [...document.querySelectorAll('.gist-down-button')].forEach((el) => {
  272. el.remove()
  273. });
  274. [...document.querySelectorAll('.gist-copy-button')].forEach((el) => {
  275. el.remove()
  276. })
  277. }
  278. }
  279.  
  280. setTimeout(tryCreateCopyButtons, 300)
  281.  
  282. const observer = new MutationObserver(debounce(() => {
  283. if (document.querySelectorAll('.file').length > 0 &&
  284. document.querySelectorAll('.gist-copy-button').length === 0) {
  285. tryCreateCopyButtons()
  286. }
  287. }, 100))
  288.  
  289. observer.observe(document.body, {
  290. childList: true,
  291. subtree: true
  292. })
  293.  
  294. if (window.onurlchange === null) {
  295. window.addEventListener('urlchange', debounce(tryCreateCopyButtons, 16))
  296. }
  297. }
  298. function compactView() {
  299. //! https://gf.qytechs.cn/es/scripts/529737
  300. GM_addStyle(`
  301. /* main container */
  302. .gist-snippet {margin-bottom: 2px !important;}
  303. /* icon */
  304. .gist-snippet-meta .d-lg-inline-block.d-none.v-align-top.mt-1 > a {display: none !important;}
  305. /* code */
  306. .gist-snippet .js-gist-file-update-container {display: none;}
  307. /* links */
  308. .gist-snippet-meta .px-lg-2.px-0 > span:nth-child(1) {display: none;}
  309. /* date */
  310. .gist-snippet-meta .px-lg-2.px-0 > div {display: none;}
  311. /* font size */
  312. .gist-snippet-meta .color-fg-muted {font-size: 14px !important;}
  313. `)
  314. }
  315. if (compactGist) {
  316. compactView()
  317. }
  318. runGist()
  319.  
  320. })()

QingJ © 2025

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