nodebb-plugin-ezoic-infinite 1.4.90 → 1.4.92
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/public/library.js +21 -5
- package/public/plugin.json +4 -0
- package/public/public/admin.js +2 -3
- package/public/public/client.js +697 -646
- package/public/public/style.css +3 -13
package/package.json
CHANGED
package/public/library.js
CHANGED
|
@@ -27,13 +27,21 @@ async function getAllGroups() {
|
|
|
27
27
|
}
|
|
28
28
|
const filtered = names.filter(name => !groups.isPrivilegeGroup(name));
|
|
29
29
|
const data = await groups.getGroupsData(filtered);
|
|
30
|
-
//
|
|
31
|
-
|
|
32
|
-
|
|
30
|
+
// Filter out nulls (groups deleted between the sorted-set read and getGroupsData)
|
|
31
|
+
const valid = data.filter(g => g && g.name);
|
|
32
|
+
valid.sort((a, b) => String(a.name).localeCompare(String(b.name), undefined, { sensitivity: 'base' }));
|
|
33
|
+
return valid;
|
|
33
34
|
}
|
|
35
|
+
let _settingsCache = null;
|
|
36
|
+
let _settingsCacheAt = 0;
|
|
37
|
+
const SETTINGS_TTL = 30000; // 30s
|
|
38
|
+
|
|
34
39
|
async function getSettings() {
|
|
40
|
+
const now = Date.now();
|
|
41
|
+
if (_settingsCache && (now - _settingsCacheAt) < SETTINGS_TTL) return _settingsCache;
|
|
35
42
|
const s = await meta.settings.get(SETTINGS_KEY);
|
|
36
|
-
|
|
43
|
+
_settingsCacheAt = Date.now();
|
|
44
|
+
_settingsCache = {
|
|
37
45
|
// Between-post ads (simple blocks) in category topic list
|
|
38
46
|
enableBetweenAds: parseBool(s.enableBetweenAds, true),
|
|
39
47
|
showFirstTopicAd: parseBool(s.showFirstTopicAd, false),
|
|
@@ -54,6 +62,7 @@ async function getSettings() {
|
|
|
54
62
|
|
|
55
63
|
excludedGroups: normalizeExcludedGroups(s.excludedGroups),
|
|
56
64
|
};
|
|
65
|
+
return _settingsCache;
|
|
57
66
|
}
|
|
58
67
|
|
|
59
68
|
async function isUserExcluded(uid, excludedGroups) {
|
|
@@ -62,6 +71,13 @@ async function isUserExcluded(uid, excludedGroups) {
|
|
|
62
71
|
return (userGroups[0] || []).some(g => excludedGroups.includes(g.name));
|
|
63
72
|
}
|
|
64
73
|
|
|
74
|
+
plugin.onSettingsSet = function (data) {
|
|
75
|
+
// Invalider le cache dès que les settings de ce plugin sont sauvegardés via l'ACP
|
|
76
|
+
if (data && data.hash === SETTINGS_KEY) {
|
|
77
|
+
_settingsCache = null;
|
|
78
|
+
}
|
|
79
|
+
};
|
|
80
|
+
|
|
65
81
|
plugin.addAdminNavigation = async (header) => {
|
|
66
82
|
header.plugins = header.plugins || [];
|
|
67
83
|
header.plugins.push({
|
|
@@ -89,7 +105,7 @@ plugin.init = async ({ router, middleware }) => {
|
|
|
89
105
|
router.get('/admin/plugins/ezoic-infinite', middleware.admin.buildHeader, render);
|
|
90
106
|
router.get('/api/admin/plugins/ezoic-infinite', render);
|
|
91
107
|
|
|
92
|
-
router.get('/api/plugins/ezoic-infinite/config',
|
|
108
|
+
router.get('/api/plugins/ezoic-infinite/config', async (req, res) => {
|
|
93
109
|
const settings = await getSettings();
|
|
94
110
|
const excluded = await isUserExcluded(req.uid, settings.excludedGroups);
|
|
95
111
|
|
package/public/plugin.json
CHANGED
package/public/public/admin.js
CHANGED
|
@@ -13,11 +13,10 @@
|
|
|
13
13
|
e.preventDefault();
|
|
14
14
|
|
|
15
15
|
Settings.save('ezoic-infinite', $form, function () {
|
|
16
|
-
// Toast vert (NodeBB core)
|
|
17
16
|
if (alerts && typeof alerts.success === 'function') {
|
|
18
|
-
alerts.success('
|
|
17
|
+
alerts.success('[[admin/settings:saved]]');
|
|
19
18
|
} else if (window.app && typeof window.app.alertSuccess === 'function') {
|
|
20
|
-
window.app.alertSuccess('
|
|
19
|
+
window.app.alertSuccess('[[admin/settings:saved]]');
|
|
21
20
|
}
|
|
22
21
|
});
|
|
23
22
|
});
|