-
-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathgreasyfork-discussion-watcher.user.js
417 lines (415 loc) · 34.7 KB
/
greasyfork-discussion-watcher.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
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
// ==UserScript==
// @name GreasyFork Discussion Watcher
// @name:zh-CN GreasyFork 通知助手
// @description:zh-CN 当你的脚本或你参与的讨论有新回复时,脚本会在网页上以模态窗口显示最新的讨论内容。
// @name:ar GreasyFork مساعد الإخطار
// @description:ar عندما يكون هناك رد جديد على البرنامج النصي الخاص بك أو على مناقشة تشارك فيها,سيعرض البرنامج النصي أحدث محتوى للمناقشة في نافذة مشروطة على صفحة الويب。
// @name:bg GreasyFork Асистент за уведомяване
// @description:bg Когато има нов отговор на вашия скрипт или на дискусия, в която участвате,Скриптът ще покаже най-новото съдържание на дискусия в модален прозорец на уеб страницата。
// @name:cs GreasyFork Asistent upozornění
// @description:cs Když přijde nová odpověď na váš scénář nebo na diskuzi, které se účastníte,Skript zobrazí nejnovější obsah diskuse v modálním okně na webové stránce。
// @name:da GreasyFork Underretningsassistent
// @description:da Når der er et nyt svar på dit manuskript eller til en diskussion, du deltager i,Scriptet vil vise det seneste diskussionsindhold i et modalt vindue på websiden。
// @name:de GreasyFork Benachrichtigungsassistent
// @description:de Wenn es eine neue Antwort auf Ihr Skript oder auf eine Diskussion gibt, an der Sie teilnehmen,Das Skript zeigt den neuesten Diskussionsinhalt in einem modalen Fenster auf der Webseite an。
// @name:el GreasyFork Βοηθός ειδοποιήσεων
// @description:el Όταν υπάρχει μια νέα απάντηση στο σενάριό σας ή σε μια συζήτηση στην οποία συμμετέχετε,Το σενάριο θα εμφανίσει το πιο πρόσφατο περιεχόμενο συζήτησης σε ένα παράθυρο τρόπου στην ιστοσελίδα。
// @name:en GreasyFork Notification Assistant
// @description:en When there’s a new reply to your script or to a discussion you’re participating in,The script will display the latest discussion content in a modal window on the web page。
// @name:eo GreasyFork Asistanto pri sciigo
// @description:eo Kiam estas nova respondo al via skripto aŭ al diskuto, kiun vi partoprenas,La skripto montros la lastan diskutenhavon en modala fenestro sur la retpaĝo。
// @name:es GreasyFork Asistente de notificaciones
// @description:es Cuando hay una nueva respuesta a tu guión o a una discusión en la que estás participando,El script mostrará el contenido de la discusión más reciente en una ventana modal en la página web.。
// @name:fi GreasyFork Ilmoitusassistentti
// @description:fi Kun käsikirjoitukseen tai keskusteluun, johon osallistut, tulee uusi vastaus,Käsikirjoitus näyttää uusimman keskustelusisällön web-sivun modaaliikkunassa。
// @name:fr GreasyFork Assistant de notifications
// @description:fr Lorsqu’il y a une nouvelle réponse à votre script ou à une discussion à laquelle vous participez,Le script affichera le dernier contenu de la discussion dans une fenêtre modale sur la page Web。
// @name:he GreasyFork עוזר הודעות
// @description:he כאשר יש תשובה חדשה לתסריט שלך או לדיון שאתה משתתף בו,הסקריפט יציג את תוכן הדיון העדכני ביותר בחלון מודאלי בדף האינטרנט。
// @name:hr GreasyFork Pomoćnik za obavijesti
// @description:hr Kada postoji novi odgovor na vašu skriptu ili na raspravu u kojoj sudjelujete,Skripta će prikazati najnoviji sadržaj rasprave u modalnom prozoru na web stranici。
// @name:hu GreasyFork Értesítési asszisztens
// @description:hu Amikor új válasz érkezik a forgatókönyvére vagy egy beszélgetésre, amelyben részt vesz,A szkript megjeleníti a legfrissebb vitatartalmat egy modális ablakban a weboldalon。
// @name:id GreasyFork Asisten Pemberitahuan
// @description:id Ketika ada balasan baru pada naskah Anda atau pada diskusi yang Anda ikuti,Script akan menampilkan konten diskusi terbaru di jendela modal di halaman web。
// @name:it GreasyFork Assistente alle notifiche
// @description:it Quando c’è una nuova risposta al tuo script o a una discussione a cui stai partecipando,Lo script visualizzerà il contenuto della discussione più recente in una finestra modale sulla pagina web。
// @name:ja GreasyFork 通知アシスタント
// @description:ja スクリプトまたは参加しているディスカッションに対して新しい返信があったとき,スクリプトは、Web ページ上のモーダル ウィンドウに最新のディスカッション コンテンツを表示します。。
// @name:ka GreasyFork შეტყობინებების ასისტენტი
// @description:ka როდესაც არის ახალი პასუხი თქვენს სკრიპტზე ან დისკუსიაზე, რომელშიც თქვენ მონაწილეობთ,სკრიპტი აჩვენებს უახლესი დისკუსიის შინაარსს მოდალურ ფანჯარაში ვებ გვერდზე。
// @name:ko GreasyFork 알림 도우미
// @description:ko 귀하의 스크립트나 귀하가 참여하고 있는 토론에 대한 새로운 답변이 있는 경우,스크립트는 웹 페이지의 모달 창에 최신 토론 내용을 표시합니다.。
// @name:nl GreasyFork Meldingsassistent
// @description:nl Wanneer er een nieuw antwoord is op uw script of op een discussie waaraan u deelneemt,Het script geeft de nieuwste discussie-inhoud weer in een modaal venster op de webpagina。
// @name:nb GreasyFork Varslingsassistent
// @description:nb Når det kommer et nytt svar på manuset ditt eller på en diskusjon du deltar i,Skriptet vil vise det siste diskusjonsinnholdet i et modalt vindu på nettsiden。
// @name:pl GreasyFork Asystent powiadomień
// @description:pl Kiedy pojawi się nowa odpowiedź na Twój skrypt lub dyskusję, w której bierzesz udział,Skrypt wyświetli najnowszą treść dyskusji w oknie modalnym na stronie internetowej。
// @name:pt-BR GreasyFork Assistente de Notificação
// @description:pt-BR Quando há uma nova resposta ao seu script ou a uma discussão da qual você está participando,O script exibirá o conteúdo da discussão mais recente em uma janela modal na página da web。
// @name:ro GreasyFork Asistent de notificare
// @description:ro Când există un nou răspuns la scenariul dvs. sau la o discuție la care participați,Scriptul va afișa cel mai recent conținut de discuție într-o fereastră modală pe pagina web。
// @name:ru GreasyFork Помощник по уведомлениям
// @description:ru Когда появляется новый ответ на ваш сценарий или на обсуждение, в котором вы участвуете.,Скрипт будет отображать последнее содержимое обсуждения в модальном окне на веб-странице.。
// @name:sk GreasyFork Asistent upozornení
// @description:sk Keď príde nová odpoveď na váš scenár alebo na diskusiu, ktorej sa zúčastňujete,Skript zobrazí najnovší obsah diskusie v modálnom okne na webovej stránke。
// @name:sr GreasyFork Помоћник за обавештења
// @description:sr Када постоји нови одговор на ваш сценарио или на дискусију у којој учествујете,Скрипта ће приказати најновији садржај дискусије у модалном прозору на веб страници。
// @name:sv GreasyFork Aviseringsassistent
// @description:sv När det kommer ett nytt svar på ditt manus eller på en diskussion du deltar i,Skriptet kommer att visa det senaste diskussionsinnehållet i ett modalt fönster på webbsidan。
// @name:th GreasyFork ผู้ช่วยการแจ้งเตือน
// @description:th เมื่อมีการตอบกลับสคริปต์ของคุณหรือการสนทนาที่คุณเข้าร่วมใหม่,สคริปต์จะแสดงเนื้อหาการสนทนาล่าสุดในหน้าต่างโมดอลบนหน้าเว็บ。
// @name:tr GreasyFork Bildirim Asistanı
// @description:tr Senaryonuza veya katıldığınız bir tartışmaya yeni bir yanıt geldiğinde,Komut dosyası, en son tartışma içeriğini web sayfasındaki kalıcı bir pencerede görüntüleyecektir.。
// @name:ug GreasyFork ئۇقتۇرۇش ياردەمچىسى
// @description:ug قوليازمىڭىزغا ياكى سىز قاتناشقان مۇنازىرىگە يېڭى جاۋاب كەلگەندە,بۇ قوليازما ئەڭ يېڭى مۇنازىرە مەزمۇنىنى تور بەتتىكى مودېل كۆزنەكتە كۆرسىتىدۇ。
// @name:uk GreasyFork Помічник сповіщень
// @description:uk Коли є нова відповідь на ваш сценарій або на обговорення, в якому ви берете участь,Сценарій відображатиме останній вміст обговорення в модальному вікні на веб-сторінці。
// @name:vi GreasyFork Trợ lý thông báo
// @description:vi Khi có câu trả lời mới cho tập lệnh của bạn hoặc cho cuộc thảo luận mà bạn đang tham gia,Tập lệnh sẽ hiển thị nội dung thảo luận mới nhất trong một cửa sổ phương thức trên trang web。
// @name:zh-TW GreasyFork 通知助手
// @description:zh-TW 當你的腳本或你參與的討論有新回應時,腳本會在網頁上以模態視窗顯示最新的討論內容。
// @name:zh-HK GreasyFork 通知助手
// @description:zh-HK 當你的腳本或你參與的討論有新回應時,腳本會在網頁上以模態視窗顯示最新的討論內容。
// @name:fr-CA GreasyFork Assistant de notifications
// @description:fr-CA Lorsqu’il y a une nouvelle réponse à votre script ou à une discussion à laquelle vous participez,Le script affichera le dernier contenu de la discussion dans une fenêtre modale sur la page Web。
// @description On GreasyFork, when there are new replies to your scripts or discussions you're involved in, the latest discussion content will be displayed on the webpage.
// @namespace https://github.com/ChinaGodMan/UserScripts
// @version 1.5.0.4
// @icon 
// @iconbak https://greasyfork.org/vite/assets/blacklogo96-CxYTSM_T.png
// @author 人民的勤务员 <[email protected]>
// @license MIT
// @match https://greasyfork.org/*
// @grant GM_setValue
// @grant GM_getValue
// @grant GM_registerMenuCommand
// @require https://unpkg.com/[email protected]/dist/sweetalert2.min.js
// @supportURL https://github.com/ChinaGodMan/UserScripts/issues
// @homepageURL https://github.com/ChinaGodMan/UserScripts
// @modified 2024-09-11 07:52:25
// ==/UserScript==
(function () {
'use strict'
var DEBUG = false
const config = {
reversal: GM_getValue('reversal', true),
isInstalled: GM_getValue('Installed', false),//第一次不加载.
lastUpdated: GM_getValue('lastUpdated', 0),//上次更新时间
delay: GM_getValue('delay', '30m'), // 格式如下: 1h1m1s, 1h1s, 1m, 1s, 1m1s
userId: null,//当前登录id
userName: null,
maxItem: GM_getValue('maxItem', 50),//访问时显示最大的信息数量
saveDiscussions: GM_getValue('saveDiscussions', true)//可以不保存到本地,如保存到本地,未读每次都会弹出提示,反之保存在本地,未读只会弹出一次,除非有新回复,
}
const translate = (function () {
const userLang = location.pathname.split('/')[1]
const strings = {
'en': {
reversal: 'Reverse Notifications:',
loadingquantity: 'Discussions loading quantity:',
popup: 'Pop-up time:',
Save: 'Save Discussions:',
Setoptions: 'Set Options',
ScriptsDiscussions: 'ScriptsDiscussions',
Discussions: 'Discussions',
title: 'GreasyFork Discussion Watcher Settings',
saveBtn: 'Save',
cancelBtn: 'Cancel'
}, 'zh-CN': {
reversal: '反转通知信息:',
loadingquantity: '讨论加载数量:',
popup: '弹出时间:',
Save: '保存讨论:',
Setoptions: '设置选项',
ScriptsDiscussions: '脚本讨论',
Discussions: '讨论',
title: 'GreasyFork 通知助手设置',
saveBtn: '保存',
cancelBtn: '取消'
}, 'zh-TW': {
reversal: '反轉通知信息:',
loadingquantity: '討論加載數量:',
popup: '彈出時間:',
Save: '保存討論:',
Setoptions: '設置選項',
ScriptsDiscussions: '腳本討論',
Discussions: '討論',
title: 'GreasyFork 通知助手設置',
saveBtn: '保存',
cancelBtn: '取消'
}, 'vi': {
reversal: 'Lật ngược thông báo:',
loadingquantity: 'Số lượng thảo luận đang tải:',
popup: 'Thời gian pop-up:',
Save: 'Lưu thảo luận:',
Setoptions: 'Cài đặt tùy chọn',
ScriptsDiscussions: 'Thảo luận kịch bản',
Discussions: 'Thảo luận',
title: 'Cài đặt Trình giám sát Thảo luận GreasyFork',
saveBtn: 'Lưu',
cancelBtn: 'Hủy'
}, 'ko': {
reversal: '알림 정보를 반전:',
loadingquantity: '토론 로딩 수량:',
popup: '팝업 시간:',
Save: '토론 저장:',
Setoptions: '옵션 설정',
ScriptsDiscussions: '스크립트 토론',
Discussions: '토론',
title: 'GreasyFork 토론 감시기 설정',
saveBtn: '저장',
cancelBtn: '취소'
}, 'ja': {
reversal: '通知情報を反転:',
loadingquantity: 'ディスカッションの読み込み数量:',
popup: 'ポップアップ時間:',
Save: 'ディスカッションを保存:',
Setoptions: 'オプションを設定',
ScriptsDiscussions: 'スクリプトディスカッション',
Discussions: 'ディスカッション',
title: 'GreasyForkディスカッションウォッチャーの設定',
saveBtn: '保存',
cancelBtn: 'キャンセル'
}
}
return (id, lang = '') => {
const selectedLang = lang || userLang
return (strings[selectedLang] || strings.en)[id] || strings.en[id]
}
// return id => (strings[userLang] || strings.en)[id] || strings.en[id];
}())
function setSettings() {
const currentDelay = config.delay
const currentSaveDiscussions = GM_getValue('saveDiscussions', true)
const currentMax = config.maxItem
const content = `
<div style="text-align: left;">
<label>${translate('popup')}</label>
<input id="delay-input" type="text" value="${currentDelay}" placeholder="1h30m1s, 1s0m30s, 1h, 1m, 1s" style="width: 100%; margin-bottom: 10px;">
<br>
<label>${translate('loadingquantity')}</label>
<input id="max-input" type="number" value="${currentMax}" placeholder="Enter max count" style="width: 100%; margin-bottom: 10px;">
<br>
<label>${translate('Save')}</label>
<input id="save-discussions" type="checkbox" ${currentSaveDiscussions ? 'checked' : ''}><br>
<label>${translate('reversal')}</label>
<input id="reversal-notifications" type="checkbox" ${config.reversal ? 'checked' : ''}> <a href="https://greasyfork.org/users/${config.userId}/notifications" target="_blank">${config.userName}</a>
</div>
`
Swal.fire({
imageUrl: 'https://greasyfork.org/vite/assets/blacklogo96-CxYTSM_T.png',
imageWidth: 96,
imageHeight: 96,
footer: '<div style="text-align: center;font-size: 1em;">Powered by <a href="https://www.github.com/ChinaGodMan">人民的勤务员</a></div>',
title: translate('title'),
html: content,
focusConfirm: false,
showCancelButton: true,
confirmButtonText: translate('saveBtn'),
cancelButtonText: translate('cancelBtn')
}).then((result) => {
if (result.isConfirmed) {
const newDelay = document.getElementById('delay-input').value
const newSaveDiscussions = document.getElementById('save-discussions').checked
const reversalNotifications = document.getElementById('reversal-notifications').checked
const newMaxItem = document.getElementById('max-input').value
if (/^\d+([hms])?(\d+([hms])?)*$/.test(newDelay)) {
GM_setValue('delay', newDelay)
config.delay = newDelay
} else {
Swal.fire('Error', 'The refresh time format is incorrect!', 'error')
return
}
GM_setValue('saveDiscussions', newSaveDiscussions)
config.saveDiscussions = newSaveDiscussions
GM_setValue('reversal', reversalNotifications)
config.reversal = reversalNotifications
if (newMaxItem && !isNaN(newMaxItem)) {
GM_setValue('maxItem', newMaxItem)
config.maxItem = newMaxItem
} else {
Swal.fire('Error', 'Please enter a valid number for max item count!', 'error')
return
}
}
})
}
GM_registerMenuCommand(translate('Setoptions'), setSettings)
function timeToSeconds(timeStr) {
let hours = 0, minutes = 0, seconds = 0
const hoursMatch = timeStr.match(/(\d+)h/)
const minutesMatch = timeStr.match(/(\d+)m/)
const secondsMatch = timeStr.match(/(\d+)s/)
if (hoursMatch) {
hours = parseInt(hoursMatch[1], 10)
}
if (minutesMatch) {
minutes = parseInt(minutesMatch[1], 10)
}
if (secondsMatch) {
seconds = parseInt(secondsMatch[1], 10)
}
let totalSeconds = (hours * 3600) + (minutes * 60) + seconds
return totalSeconds
}
function isUpdate() {
const now = Math.floor(new Date().getTime() / 1000)
const lastUpdated = config.lastUpdated
const secondsDifference = now - lastUpdated
if (secondsDifference > timeToSeconds(config.delay)) {
GM_setValue('lastUpdated', now)
console.log(`时间超过${config.delay} 进行更新`)
return true
}
return DEBUG
}
function isMobileDevice() {
return /Mobi|Android|iPhone|iPad|iPod|Windows Phone/i.test(navigator.userAgent)
}
function fetchAndDisplayDiscussions(urls) {
if (DEBUG) GM_setValue('discussions', [])
if (!isUpdate()) return
let discussions = GM_getValue('discussions', [])
let fetchPromises = []
let itemCount = 0
var modalHTML = `
<div id="discussion-modal" style="position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.5); display: flex; visibility: hidden; align-items: center; justify-content: center; z-index: 1000;">
<button id="close-button" style="align-self: flex-end; background-color: #ff5e5e; border: none; color: #fff; padding: 25px 25px; cursor: pointer; border-radius: 5px; font-family: Arial, sans-serif; font-size: 30px;">×</button>
<div id="modal-content" style="background: #fff; border-radius: 10px; box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); max-height: 80vh; overflow-y: auto; width: 100%; max-width: 100%; padding: 20px; font-family: Arial, sans-serif; display: flex; flex-direction: column;">
<div class="discussion-list" style="margin-top: 10px;">
<ul id="discussion-list-a" style="list-style-type: none; padding: 0; margin: 0;"></ul>
</div>
</div>
</div>
`
document.body.insertAdjacentHTML('beforeend', modalHTML)
const discussionList = document.getElementById('discussion-list-a')
const modalContent = document.getElementById('modal-content')
const closeButton = document.getElementById('close-button')
if (isMobileDevice()) {
modalContent.appendChild(closeButton)
closeButton.style.alignSelf = 'flex-end'
closeButton.style.padding = '5px 5px'
}
var isFirst = false
urls.forEach(([url, description]) => {
fetchPromises.push(
fetch(url)
.then(response => response.text())
.then(data => {
var parser = new DOMParser()
var doc = parser.parseFromString(data, 'text/html')
var elements = doc.querySelectorAll('.discussion-list > div > div')
var discussionsHTML = ''
var currentCount = 0
elements.forEach(function (element) {
var discussionTitle = element.querySelector('.discussion-title')
var relativeTimes = element.querySelectorAll('relative-time')
if (!discussionTitle || relativeTimes.length === 0) return
var discussionTitleHref = discussionTitle.getAttribute('href')
var latestRelativeTime = relativeTimes[relativeTimes.length - 1].getAttribute('datetime')
var existingDiscussion = discussions.find(function (disc) {
return disc.discussionTitleHref === discussionTitleHref
})
const userLinks = element.querySelectorAll('a.user-link')
if (existingDiscussion && existingDiscussion.relativeTime === latestRelativeTime) return
var discussionInfo = {
discussionTitleHref: discussionTitleHref,
relativeTime: latestRelativeTime,
lasteduserName: userLinks.length > 0 ? userLinks[userLinks.length - 1].textContent.trim() : null,//最后的发言人
lastedID: userLinks.length > 0 ? userLinks[userLinks.length - 1].href.match(/\/users\/(\d+)-/)[1] : null//ANCHOR - 获取最后的发言人ID
}
if (existingDiscussion) {
existingDiscussion.relativeTime = latestRelativeTime
existingDiscussion.lasteduserName = discussionInfo.lasteduserName
} else {
discussions.push(discussionInfo)
}
if (discussionInfo.lastedID === config.userId || discussionInfo.lasteduserName === config.userName) {
// 最新发言ID是自己,或用户名是自己,跳过
console.log('skip ')
return
}
var listItemHTML = '<div class="discussion-list-item">' + element.innerHTML + '</div>'
currentCount++
discussionsHTML += listItemHTML
itemCount++
})
if (currentCount > 0) {
discussionsHTML = `<center><h5>${isFirst ? `<div class="discussion-list-item"><a href="${url}" target="_blank">${description} (${currentCount})</a></div>` : `<a href="${url}" target="_blank">${description} (${currentCount})`}</a></h5></center>` + discussionsHTML
isFirst = true // 后续描述都以嵌套结构添加
}
discussionList.innerHTML += discussionsHTML
})
)
})
Promise.all(fetchPromises).then(() => {
if (itemCount === 0) return
// 将讨论信息保存到 GM_setValue
if (config.saveDiscussions) GM_setValue('discussions', discussions)
if (!config.isInstalled) {
console.log('首次安装时,不弹出:')
GM_setValue('Installed', true)
return
}
// 计算关闭按钮的位置,并动态设置
closeButton.style.position = 'absolute'
var closeButtonRect = closeButton.getBoundingClientRect()
var modalContentRect = modalContent.getBoundingClientRect()
if (isMobileDevice()) {
closeButton.style.top = `${discussionList.offsetTop - closeButtonRect.height}px`
closeButton.style.left = `${discussionList.right}px`
} else {
closeButton.style.top = `${modalContentRect.top - closeButtonRect.height}px`
closeButton.style.left = `${modalContentRect.width / 2}px`
}
document.getElementById('discussion-modal').style.visibility = 'visible'
// 设置所有链接在新窗口中打开
var links = discussionList.querySelectorAll('a')
links.forEach(function (link) {
link.setAttribute('target', '_blank')
})
closeButton.addEventListener('click', function () {
document.body.removeChild(document.getElementById('discussion-modal'))
})
}).catch(error => {
console.error('无法获取讨论列表:', error)
})
}
function getUserId() {
const profileLinkElement = document.querySelector('#nav-user-info > span.user-profile-link > a')
if (profileLinkElement) {
const href = profileLinkElement.getAttribute('href')
const match = href.match(/\/users\/(\d+)-/)
if (match) {
const userId = match[1]
config.userId = userId
const nameMatch = href.match(/\/users\/\d+-([^/]+)$/)
config.userName = nameMatch ? decodeURIComponent(nameMatch[1]) : ''
return true
} else {
console.log('放弃操作,无法找到id')
return false
}
} else {
return false
}
}
if (getUserId()) {
fetchAndDisplayDiscussions([
[`https://greasyfork.org/discussions?user=${config.userId}&read=unread&per_page=${config.maxItem}`, translate('Discussions')],
[`https://greasyfork.org/discussions?me=script&read=unread&per_page=${config.maxItem}`, translate('ScriptsDiscussions')]//添加read=unread参数,只提取未读信息,此版本为最后版本,Greasyfork已经逐步支持站内通知.
])
} else {
console.log('没有登录,放弃操作')
}
const notificationList = document.querySelector('.notification-list')
if (notificationList && config.reversal) {
const items = Array.from(notificationList.children)
items.reverse()
notificationList.innerHTML = ''
items.forEach(item => notificationList.appendChild(item))
}
})()