Greasy Fork is available in English.

Salinan dan download cuplikan kode GIST GITHUB

Tambahkan tombol Salin ke file GIST untuk membuat kode dengan mudah disalin. Tambahkan tombol unduh ke file GIST untuk dengan mudah mengunduh kode.

  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://greatest.deepsurf.us/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. })()