-
-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathgithub-file-list-beautifier-plus.user.js
272 lines (270 loc) · 38.8 KB
/
github-file-list-beautifier-plus.user.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
// ==UserScript==
// @name GitHub file list beautifier
// @description Adds colors to files by type, displays small images in place of file-type icons in a repository source tree
// @name:zh-CN GitHub 文件列表美化器
// @description:zh-CN GitHub 文件列表美化器是一个用户脚本,用于增强 GitHub 仓库中的文件显示效果。它可以为文件和文件夹添加颜色,并将文件类型图标替换为小图像,使得代码库更加易于浏览和管理。按类型为文件添加颜色和图标,在存储库源树中显示小图像以代替文件类型图标
// @name:ar GitHub تجميل قائمة الملفات
// @description:ar GitHub File List Beautifier هو برنامج نصي للمستخدم,تستخدم لتعزيز GitHub عرض تأثير الملفات في المستودع。يمكنه إضافة الألوان إلى الملفات والمجلدات,واستبدل أيقونات نوع الملف بصور صغيرة,يجعل قاعدة التعليمات البرمجية أسهل في التصفح والإدارة。إضافة الألوان والأيقونات إلى الملفات حسب النوع,عرض صور صغيرة بدلاً من أيقونات نوع الملف في شجرة مصدر المستودع
// @name:bg GitHub Разкрасител на списък с файлове
// @description:bg GitHub File List Beautifier е потребителски скрипт,използвани за подобряване GitHub Показване на ефекта на файловете в склада。Може да добавя цветове към файлове и папки,и заменете иконите за типове файлове с малки изображения,Прави кодовата база по-лесна за разглеждане и управление。Добавете цветове и икони към файлове по тип,Показване на малки изображения на мястото на иконите за типове файлове в дървото на източника на хранилището
// @name:cs GitHub Zkrášlovač seznamu souborů
// @description:cs GitHub File List Beautifier je uživatelský skript,slouží k vylepšení GitHub Zobrazení efektu souborů ve skladu。Může přidat barvy do souborů a složek,a nahraďte ikony typů souborů malými obrázky,Usnadňuje procházení a správu kódové základny。Přidejte barvy a ikony do souborů podle typu,Zobrazte malé obrázky místo ikon typů souborů ve zdrojovém stromu úložiště
// @name:da GitHub Filliste forskønner
// @description:da GitHub File List Beautifier er et brugerscript,bruges til at forbedre GitHub Vis effekt af filer på lager。Det kan tilføje farver til filer og mapper,og udskift filtypeikonerne med små billeder,Gør kodebasen nemmere at gennemse og administrere。Tilføj farver og ikoner til filer efter type,Vis små billeder i stedet for filtypeikoner i lagerkildetræet
// @name:de GitHub Dateilisten-Verschönerer
// @description:de GitHub File List Beautifier ist ein Benutzerskript,zur Verstärkung verwendet GitHub Anzeigeeffekt von Dateien im Lager。Es kann Dateien und Ordnern Farben hinzufügen,und ersetzen Sie die Dateitypsymbole durch kleine Bilder,Erleichtert das Durchsuchen und Verwalten der Codebasis。Fügen Sie Dateien nach Typ Farben und Symbole hinzu,Zeigen Sie kleine Bilder anstelle von Dateitypsymbolen im Repository-Quellbaum an
// @name:el GitHub Διακοσμητικό λίστας αρχείων
// @description:el GitHub Το File List Beautifier είναι ένα σενάριο χρήστη,χρησιμοποιείται για ενίσχυση GitHub Εμφάνιση εφέ αρχείων στην αποθήκη。Μπορεί να προσθέσει χρώματα σε αρχεία και φακέλους,και αντικαταστήστε τα εικονίδια τύπου αρχείου με μικρές εικόνες,Κάνει πιο εύκολη την περιήγηση και τη διαχείριση της βάσης κώδικα。Προσθέστε χρώματα και εικονίδια σε αρχεία ανά τύπο,Εμφάνιση μικρών εικόνων στη θέση των εικονιδίων τύπου αρχείου στο δέντρο προέλευσης του αποθετηρίου
// @name:en GitHub File list beautifier
// @description:en GitHub File List Beautifier is a user script,used to enhance GitHub Display effect of files in warehouse。It can add colors to files and folders,and replace the file type icons with small images,Makes the code base easier to browse and manage。Add colors and icons to files by type,Display small images in place of file type icons in repository source tree
// @name:eo GitHub Plibeligilo de dosierlisto
// @description:eo GitHub Dosiera Listo Beautifier estas uzanta skripto,uzata por plibonigi GitHub Montri efikon de dosieroj en magazeno。Ĝi povas aldoni kolorojn al dosieroj kaj dosierujoj,kaj anstataŭigu la dosiertipaj ikonojn per malgrandaj bildoj,Plifaciligas foliumi kaj administri la kodan bazon。Aldonu kolorojn kaj ikonojn al dosieroj laŭ tipo,Montru malgrandajn bildojn anstataŭ dosiertipaj ikonoj en deponeja fontarbo
// @name:es GitHub Embellecedor de lista de archivos
// @description:es GitHub File List Beautifier es un script de usuario,utilizado para mejorar GitHub Efecto de visualización de archivos en el almacén.。Puede agregar colores a archivos y carpetas.,y reemplace los íconos de tipo de archivo con imágenes pequeñas,Hace que la base del código sea más fácil de navegar y administrar.。Agregue colores e íconos a archivos por tipo,Mostrar imágenes pequeñas en lugar de íconos de tipo de archivo en el árbol de fuentes del repositorio
// @name:fi GitHub Tiedostolistan kaunistaja
// @description:fi GitHub File List Beautifier on käyttäjän komentosarja,käytetään parantamaan GitHub Näytä tehosteet tiedostot varastossa。Se voi lisätä värejä tiedostoihin ja kansioihin,ja korvaa tiedostotyyppikuvakkeet pienillä kuvilla,Helpottaa koodikannan selailua ja hallintaa。Lisää värejä ja kuvakkeita tiedostoihin tyypin mukaan,Näytä pienet kuvat tiedostotyyppikuvakkeiden tilalla arkiston lähdepuussa
// @name:fr GitHub Embellisseur de liste de fichiers
// @description:fr GitHub File List Beautifier est un script utilisateur,utilisé pour améliorer GitHub Effet d’affichage des fichiers dans l’entrepôt。Il peut ajouter des couleurs aux fichiers et dossiers,et remplacez les icônes de type de fichier par de petites images,Rend la base de code plus facile à parcourir et à gérer。Ajouter des couleurs et des icônes aux fichiers par type,Afficher de petites images à la place des icônes de type de fichier dans l’arborescence des sources du référentiel
// @name:he GitHub מייפה רשימת קבצים
// @description:he GitHub File List Beautifier הוא סקריפט משתמש,משמש לשיפור GitHub הצגת אפקט של קבצים במחסן。זה יכול להוסיף צבעים לקבצים ולתיקיות,והחלף את סמלי סוג הקובץ בתמונות קטנות,הופך את בסיס הקוד לקל יותר לעיון ולניהול。הוסף צבעים וסמלים לקבצים לפי סוג,הצג תמונות קטנות במקום סמלי סוג קובץ בעץ המקור של המאגר
// @name:hr GitHub Uljepšavač popisa datoteka
// @description:hr GitHub File List Beautifier je korisnička skripta,koristi se za poboljšanje GitHub Učinak prikaza datoteka u skladištu。Može dodati boje datotekama i mapama,i zamijenite ikone vrste datoteka malim slikama,Čini bazu koda lakšom za pregledavanje i upravljanje。Dodajte boje i ikone datotekama prema vrsti,Prikaži male slike umjesto ikona tipa datoteke u izvornom stablu spremišta
// @name:hu GitHub Fájllista szépítő
// @description:hu GitHub A File List Beautifier egy felhasználói szkript,fokozására használják GitHub A raktárban lévő fájlok megjelenítési hatása。Színeket adhat a fájlokhoz és mappákhoz,és cserélje ki a fájltípus ikonokat kis képekkel,Könnyebbé teszi a kódbázis böngészését és kezelését。Színek és ikonok hozzáadása a fájlokhoz típus szerint,Kis képek megjelenítése a fájltípus ikonok helyett a lerakat forrásfájában
// @name:id GitHub Percantik daftar file
// @description:id GitHub File List Beautifier adalah skrip pengguna,digunakan untuk meningkatkan GitHub Menampilkan efek file di gudang。Itu dapat menambahkan warna pada file dan folder,dan ganti ikon jenis file dengan gambar kecil,Membuat basis kode lebih mudah dijelajahi dan dikelola。Tambahkan warna dan ikon ke file berdasarkan jenisnya,Tampilkan gambar kecil sebagai pengganti ikon jenis file di pohon sumber repositori
// @name:it GitHub Abbellitore dell’elenco dei file
// @description:it GitHub File List Beautifier è uno script utente,utilizzato per migliorare GitHub Visualizza l’effetto dei file nel magazzino。Può aggiungere colori a file e cartelle,e sostituisci le icone del tipo di file con piccole immagini,Rende la base di codice più semplice da sfogliare e gestire。Aggiungi colori e icone ai file per tipo,Visualizza piccole immagini al posto delle icone del tipo di file nell’albero di origine del repository
// @name:ja GitHub ファイルリスト整形ツール
// @description:ja GitHub File List Beautifier はユーザースクリプトです,強化するために使用される GitHub 倉庫内のファイルの表示効果。ファイルやフォルダーに色を追加できます,ファイルタイプのアイコンを小さな画像に置き換えます,コードベースの参照と管理が容易になります。。種類ごとにファイルに色とアイコンを追加する,リポジトリソースツリーのファイルタイプアイコンの代わりに小さな画像を表示します
// @name:ka GitHub ფაილების სიის გამალამაზებელი
// @description:ka GitHub File List Beautifier არის მომხმარებლის სკრიპტი,გამოიყენება გასაძლიერებლად GitHub ფაილების ეფექტის ჩვენება საწყობში。მას შეუძლია ფერების დამატება ფაილებსა და საქაღალდეებში,და შეცვალეთ ფაილის ტიპის ხატები პატარა სურათებით,ამარტივებს კოდის ბაზის დათვალიერებას და მართვას。დაამატეთ ფერები და ხატები ფაილებს ტიპის მიხედვით,აჩვენეთ პატარა სურათები ფაილის ტიპის ხატულების ნაცვლად საცავის წყაროს ხეში
// @name:ko GitHub 파일 목록 미화자
// @description:ko GitHub File List Beautifier는 사용자 스크립트입니다.,향상시키는 데 사용됨 GitHub 창고 내 파일 표시 효과。파일과 폴더에 색상을 추가할 수 있습니다.,파일 형식 아이콘을 작은 이미지로 바꿉니다.,코드 베이스를 더 쉽게 찾아보고 관리할 수 있습니다.。유형별로 파일에 색상 및 아이콘 추가,저장소 소스 트리의 파일 유형 아이콘 대신 작은 이미지 표시
// @name:nl GitHub Bestandslijstverfraaier
// @description:nl GitHub File List Beautifier is een gebruikersscript,gebruikt om te verbeteren GitHub Weergave-effect van bestanden in magazijn。Het kan kleuren toevoegen aan bestanden en mappen,en vervang de bestandstypepictogrammen door kleine afbeeldingen,Maakt het gemakkelijker om door de codebasis te bladeren en deze te beheren。Voeg kleuren en pictogrammen toe aan bestanden op type,Geef kleine afbeeldingen weer in plaats van bestandstypepictogrammen in de bronstructuur van de repository
// @name:nb GitHub Filliste forskjønner
// @description:nb GitHub File List Beautifier er et brukerskript,brukes til å forbedre GitHub Vis effekt av filer på lager。Den kan legge til farger i filer og mapper,og erstatte filtypeikonene med små bilder,Gjør kodebasen enklere å bla gjennom og administrere。Legg til farger og ikoner til filer etter type,Vis små bilder i stedet for filtypeikoner i depotkildetreet
// @name:pl GitHub Upiększanie listy plików
// @description:pl GitHub File List Beautifier to skrypt użytkownika,używany do ulepszania GitHub Efekt wyświetlania plików w magazynie。Może dodawać kolory do plików i folderów,i zamień ikony typów plików na małe obrazy,Ułatwia przeglądanie i zarządzanie bazą kodu。Dodaj kolory i ikony do plików według typu,Wyświetlaj małe obrazy zamiast ikon typów plików w drzewie źródeł repozytorium
// @name:pt-BR GitHub Embelezador de lista de arquivos
// @description:pt-BR GitHub File List Beautifier é um script de usuário,usado para melhorar GitHub Efeito de exibição de arquivos no warehouse。Pode adicionar cores a arquivos e pastas,e substitua os ícones de tipo de arquivo por imagens pequenas,Torna a base de código mais fácil de navegar e gerenciar。Adicione cores e ícones aos arquivos por tipo,Exibir pequenas imagens no lugar dos ícones de tipo de arquivo na árvore de origem do repositório
// @name:ro GitHub Înfrumusețator de listă de fișiere
// @description:ro GitHub File List Beautifier este un script de utilizator,folosit pentru a spori GitHub Efectul de afișare al fișierelor în depozit。Poate adăuga culori fișierelor și folderelor,și înlocuiți pictogramele tip fișier cu imagini mici,Face baza de cod mai ușor de răsfoit și gestionat。Adăugați culori și pictograme fișierelor după tip,Afișați imagini mici în locul pictogramelor de tip fișier în arborele sursă a depozitului
// @name:ru GitHub Средство украшения списка файлов
// @description:ru GitHub File List Beautifier — пользовательский скрипт.,используется для улучшения GitHub Эффект отображения файлов на складе。Он может добавлять цвета к файлам и папкам.,и замените значки типов файлов небольшими изображениями,Упрощает просмотр и управление базой кода.。Добавляйте цвета и значки к файлам по типу,Отображение небольших изображений вместо значков типов файлов в дереве исходного кода репозитория.
// @name:sk GitHub Skrášľovač zoznamu súborov
// @description:sk GitHub File List Beautifier je užívateľský skript,používa sa na vylepšenie GitHub Zobrazenie efektu súborov v sklade。Môže pridávať farby do súborov a priečinkov,a nahraďte ikony typov súborov malými obrázkami,Uľahčuje prehľadávanie a správu kódovej základne。Pridajte farby a ikony do súborov podľa typu,Zobrazte malé obrázky namiesto ikon typu súboru v strome zdroja úložiska
// @name:sr GitHub Улепшавање листе датотека
// @description:sr GitHub Филе Лист Беаутифиер је корисничка скрипта,користи за побољшање GitHub Приказ ефеката датотека у магацину。Може да додаје боје датотекама и фасциклама,и замените иконе типа датотеке малим сликама,Олакшава претраживање и управљање основом кода。Додајте боје и иконе датотекама по типу,Прикажите мале слике уместо икона типа датотеке у изворном стаблу спремишта
// @name:sv GitHub Fillista förskönare
// @description:sv GitHub File List Beautifier är ett användarskript,används för att förbättra GitHub Visningseffekt av filer i lagret。Det kan lägga till färger till filer och mappar,och ersätt filtypsikonerna med små bilder,Gör kodbasen lättare att bläddra i och hantera。Lägg till färger och ikoner till filer efter typ,Visa små bilder istället för filtypsikoner i arkivets källträd
// @name:th GitHub โปรแกรมตกแต่งรายการไฟล์
// @description:th GitHub File List Beautifier เป็นสคริปต์ผู้ใช้,ใช้เพื่อเพิ่มประสิทธิภาพ GitHub แสดงเอฟเฟกต์ของไฟล์ในคลังสินค้า。สามารถเพิ่มสีสันให้กับไฟล์และโฟลเดอร์ได้,และแทนที่ไอคอนประเภทไฟล์ด้วยรูปภาพขนาดเล็ก,ทำให้ฐานโค้ดง่ายต่อการเรียกดูและจัดการ。เพิ่มสีและไอคอนให้กับไฟล์ตามประเภท,แสดงรูปภาพขนาดเล็กแทนที่ไอคอนประเภทไฟล์ในแผนผังแหล่งเก็บข้อมูล
// @name:tr GitHub Dosya listesi güzelleştirici
// @description:tr GitHub Dosya Listesi Güzelleştirici bir kullanıcı komut dosyasıdır,geliştirmek için kullanılır GitHub Depodaki dosyaların efektini görüntüleme。Dosya ve klasörlere renk ekleyebilir,ve dosya türü simgelerini küçük resimlerle değiştirin,Kod tabanına göz atmayı ve yönetmeyi kolaylaştırır。Türe göre dosyalara renkler ve simgeler ekleyin,Depo kaynak ağacında dosya türü simgelerinin yerine küçük resimleri görüntüle
// @name:ug GitHub ھۆججەت تىزىملىكى گۈزەللەشتۈرگۈچى
// @description:ug GitHub ھۆججەت تىزىملىكى گۈزەللەشتۈرگۈچى ئىشلەتكۈچى قوليازمىسى,كۈچەيتىشكە ئىشلىتىلىدۇ GitHub ئامباردىكى ھۆججەتلەرنىڭ ئۈنۈمىنى كۆرسىتىش。ئۇ ھۆججەت ۋە ھۆججەت قىسقۇچلارغا رەڭ قوشالايدۇ,ھەمدە ھۆججەت تىپىدىكى سىنبەلگىلەرنى كىچىك رەسىملەر بىلەن ئالماشتۇرۇڭ,كود ئاساسىنى كۆرۈش ۋە باشقۇرۇشنى ئاسانلاشتۇرىدۇ。ھۆججەتلەرگە رەڭ ۋە سىنبەلگە قوشۇڭ,ئامبار مەنبە دەرىخىدە ھۆججەت تىپىدىكى سىنبەلگىلەرنىڭ ئورنىدا كىچىك رەسىملەرنى كۆرسىتىڭ
// @name:uk GitHub Прикрашувач списку файлів
// @description:uk GitHub File List Beautifier — це сценарій користувача,використовується для посилення GitHub Ефект відображення файлів у складі。Він може додавати кольори до файлів і папок,і замініть піктограми типів файлів маленькими зображеннями,Полегшує перегляд та керування кодовою базою。Додайте кольори та значки до файлів за типом,Відображати невеликі зображення замість значків типів файлів у дереві вихідних кодів сховища
// @name:vi GitHub Trình làm đẹp danh sách tập tin
// @description:vi GitHub File List Beautifier là một tập lệnh người dùng,được sử dụng để tăng cường GitHub Hiển thị tác dụng của file trong kho。Nó có thể thêm màu sắc vào tập tin và thư mục,và thay thế các biểu tượng loại tệp bằng hình ảnh nhỏ,Làm cho cơ sở mã dễ dàng duyệt và quản lý hơn。Thêm màu sắc và biểu tượng vào tệp theo loại,Hiển thị hình ảnh nhỏ thay cho biểu tượng loại tệp trong cây nguồn kho lưu trữ
// @name:zh-TW GitHub 文件列表美化器
// @description:zh-TW GitHub 文件清單美化器是一個使用者腳本,用於增強 GitHub 倉庫中的文件顯示效果。它可以為文件和資料夾添加顏色,並將文件類型圖示替換為小圖像,使得程式碼庫更加易於瀏覽和管理。按類型為文件添加顏色和圖標,在儲存庫來源樹中顯示小圖像以取代文件類型圖標
// @name:zh-HK GitHub 文件列表美化器
// @description:zh-HK GitHub 文件清單美化器是一個使用者腳本,用於增強 GitHub 倉庫中的文件顯示效果。它可以為文件和資料夾添加顏色,並將文件類型圖示替換為小圖像,使得程式碼庫更加易於瀏覽和管理。按類型為文件添加顏色和圖標,在儲存庫來源樹中顯示小圖像以取代文件類型圖標
// @name:fr-CA GitHub Embellisseur de liste de fichiers
// @description:fr-CA GitHub File List Beautifier est un script utilisateur,utilisé pour améliorer GitHub Effet d’affichage des fichiers dans l’entrepôt。Il peut ajouter des couleurs aux fichiers et dossiers,et remplacez les icônes de type de fichier par de petites images,Rend la base de code plus facile à parcourir et à gérer。Ajouter des couleurs et des icônes aux fichiers par type,Afficher de petites images à la place des icônes de type de fichier dans l’arborescence des sources du référentiel
// @license MIT
// @version 4.1.0.4
// @match https://github.com/*
// @grant none
// @run-at document-start
// @grant GM_xmlhttpRequest
// @grant GM_getValue
// @grant GM_setValue
// @compatible chrome
// @compatible firefox
// @compatible edge
// @compatible opera
// @compatible safari
// @author wOxxOm,人民的勤务员 <[email protected]>
// @namespace https://github.com/ChinaGodMan/UserScripts
// @icon 
// @license MIT
// @supportURL https://github.com/ChinaGodMan/UserScripts/issues
// @homepageURL https://github.com/ChinaGodMan/UserScripts
// ==/UserScript==
'use strict'
let customColors = GM_getValue('fileTypesColors', {})
var DEBUG = false
var addIcon = true
if (DEBUG) {
GM_setValue('fileTypesColors', {})
}
GM_setValue('fileTypesColors', {})
if (Object.keys(customColors).length === 0) {
GM_xmlhttpRequest({
method: 'GET',
url: 'https://raw.githubusercontent.com/ChinaGodMan/UserScripts/main/github-file-list-beautifier-plus/colors.json',
//url: 'http://127.0.0.1:5500/UserScripts/Script%20details/github-file-list-beautifier-plus/colors.json',
onload: function (response) {
try {
customColors = JSON.parse(response.responseText)
GM_setValue('fileTypesColors', customColors) // 保存到本地存储
requestAnimationFrame(start)
} catch (e) {
console.error('解析颜色配置失败:', e)
}
},
onerror: function () {
console.error('加载颜色配置失败')
}
})
} else {
requestAnimationFrame(start)
}
let savedConfig = {}
try {
savedConfig = JSON.parse(localStorage.FileListBeautifier) || {}
} catch (e) { }
const config = Object.assign({},
...Object.entries({
iconSize: 24,
colorSeed1: 13,
colorSeed2: 1299721,
colorSeed3: 179426453
}).map(([k, v]) => ({ [k]: +savedConfig[k] || v })))
const IMG_CLS = 'wOxxOm-image-icon'
const rxImages = /^(png|jpe?g|bmp|gif|cur|ico|svg)$/i
const styleQueue = []
const { sheet } = document.documentElement.appendChild($create('style', {
textContent: /*language=CSS*/ `
.${IMG_CLS} {
width: ${config.iconSize}px;
height: ${config.iconSize}px;
object-fit: scale-down;
margin: 0 -4px;
}
.qinwuyuan-file-icon {
width: 16px;
height: 16px;
object-fit: scale-down;
margin: 0 -4px;
}
a[file-type=":folder"] {
font-weight: bold;
}
`.replace(/;/g, '!important;')
}))
const filetypes = {}
const ME = Symbol(GM_info.script.name)
const ob = new MutationObserver(start)
let lumaBias, lumaFix, lumaAmp
function start() {
beautify()
ob.observe(document, { subtree: true, childList: true })
}
function beautify() {
for (const el of document.querySelectorAll('.react-directory-truncate, .js-navigation-open')) {
if (ME in el)
continue
el[ME] = true
const isOld = el.tagName === 'A'
const a = isOld ? el : el.getElementsByTagName('a')[0]
const url = a && a.href
if (!url)
continue
const icon = el.closest(isOld ? '.js-navigation-item' : 'td').querySelector('svg')
if (icon.classList.contains(isOld ? 'octicon-file-directory-fill' : 'icon-directory')) {
a.setAttribute('file-type', ':folder')
continue
}
let filename = url.split('/').pop().toLowerCase()
let ext = (url.match(/\.(\w+)$|$/)[1] || filename).toLowerCase()
if (customColors[filename]) {
ext = filename
}
a.setAttribute('file-type', ext)
const customIcon = customColors[filename] && customColors[filename].icon
? customColors[filename].icon
: (customColors[ext] && customColors[ext].icon) || null
if (!filetypes[ext])
addFileTypeStyle(ext)
if (customIcon && addIcon) {
let iconUrl = customIcon
if (iconUrl && !iconUrl.startsWith('https://') && !iconUrl.startsWith('data:image')) {
iconUrl = `https://raw.githubusercontent.com/PKief/vscode-material-icon-theme/main/icons/${iconUrl}.svg`
console.log(iconUrl)
}
const img = $create('img', {
className: 'qinwuyuan-file-icon',
src: iconUrl,
alt: ext
})
icon.replaceWith(img)
} else if (rxImages.test(ext)) {
const m = url.match(/github\.com\/(.+?\/)blob\/(.*)$/)
const next = icon.nextElementSibling
if (!m || next && next[ME])
continue
icon.replaceWith($create('img', {
[ME]: true,
className: IMG_CLS,
src: `https://raw.githubusercontent.com/${m[1]}${m[2]}`
}))
}
}
}
function addFileTypeStyle(type) {
filetypes[type] = true
if (!styleQueue.length)
requestAnimationFrame(commitStyleQueue)
styleQueue.push(type)
}
function commitStyleQueue() {
if (!lumaAmp) initLumaScale()
const seed2 = config.colorSeed2
const seed3 = config.colorSeed3
for (const type of styleQueue) {
const colorConfig = customColors[type]
if (colorConfig) {
const color = colorConfig.color
if (color) {
sheet.insertRule(/*language=CSS*/ `
a[file-type="${type}"]:not(#foo) {
color: ${color} !important;
}
`)
}
} else {
const hash = calcSimpleHash(type)
const H = hash % 360
const Hq = H / 60
const S = hash * seed2 % 50 + 50 | 0
const redFix = (Hq < 1 ? 1 - Hq : Hq > 4 ? (Hq - 4) / 2 : 0)
const blueFix = (Hq < 3 || Hq > 5 ? 0 : Hq < 4 ? Hq - 3 : 5 - Hq) * 3
const L = hash * seed3 % lumaAmp + lumaBias + (redFix + blueFix) * lumaFix * S / 100 | 0
sheet.insertRule(/*language=CSS*/ `
a[file-type="${type}"]:not(#foo) {
color: hsl(${H},${S}%,${L}%) !important;
}
`)
}
}
styleQueue.length = 0
}
function calcSimpleHash(text) {
let hash = 0
for (let i = 0, len = text.length; i < len; i++)
hash = ((hash << 5) - hash) + text.charCodeAt(i)
return Math.abs(hash * config.colorSeed1 | 0)
}
function initLumaScale() {
const [, r, g, b] = getComputedStyle(document.body).backgroundColor.split(/[^\d.]+/).map(parseFloat)
const isDark = (r * .2126 + g * .7152 + b * .0722) < 128;
[lumaBias, lumaAmp, lumaFix] = isDark ? [30, 50, 12] : [25, 15, 0]
}
function $create(tag, props) {
return Object.assign(document.createElement(tag), props)
}