From f066ddb8f63dfddfbaa6e73f9c3820b182bca887 Mon Sep 17 00:00:00 2001
From: "Misty (Bot)"
Date: Wed, 22 Sep 2021 17:01:45 +0000
Subject: [PATCH 01/62] chore: update changelog for v1.18.3
---
CHANGELOG.md | 75 ++++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 75 insertions(+)
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 2331add3ab..593cf81266 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,3 +1,78 @@
+#### v1.18.3 (2021-09-22)
+
+##### Chores
+
+* **deps:** update docker/build-push-action action to v2.7.0 (ee027719)
+* incrementing version number - v1.18.2 (0a56158b)
+* update changelog for v1.18.2 (27e9282a)
+
+##### New Features
+
+* move filter:topic.post hook to top of method (f194809f)
+* add client-side static hook to fire immediately before any topic action (hint: delete `action` to stop default behaviour) (66eaae44)
+* allow removing multiple items from list (397835a0)
+* add uid to filter:user.saveSettings (7f48edc0)
+* headers for global privs #9717 (#9762) (84ff1152)
+* add ACP option to require email address on new registration (006fc700)
+
+##### Bug Fixes
+
+* **deps:**
+ * update dependency nodebb-plugin-composer-default to v7.0.7 (98554294)
+ * update dependency postcss to v8.3.7 (6ebe707c)
+ * update dependency autoprefixer to v10.3.5 (25687441)
+ * update dependency nodebb-plugin-composer-default to v7.0.6 (#9815) (c18678ce)
+ * update dependency nodebb-theme-persona to v11.2.8 (#9816) (39d73d0c)
+ * update dependency connect-mongo to v4.6.0 (8e886c85)
+ * update dependency nodebb-plugin-composer-default to v7.0.4 (8af54255)
+ * update dependency mongodb to v3.7.1 (9049dcd7)
+ * update dependency nodebb-theme-persona to v11.2.6 (506035b5)
+ * update dependency nodebb-theme-slick to v1.4.13 (787306a6)
+ * update dependency nodebb-plugin-composer-default to v7.0.3 (732b59c2)
+* fixed element shifting in ACP menu that's been bothering me for 5-ish years (31975a62)
+* #9822, use correct username/pwd (30f38771)
+* remove unused translator (2add84a5)
+* ban info test (07859f7e)
+* #9819, show same time info for ban (9f0e55ad)
+* show local time for ban (7a2f0ae1)
+* crash (c437b336)
+* remove caller from payload after hooks is done (15f9aaa6)
+* bad uid reference (ce8ea6ea)
+* update Topics.post and Topics.reply so that plugins can modify uid (or redirect a reply to a different topic) (7777812e)
+* #9818, fix totalTime calculation (c4fc7bf9)
+* missing microdata in category data (1ed62aa8)
+* #9812, add topics:schedule (c0a52924)
+* for subfolders (31a6d4b3)
+* req.path doesn't have full url (0236ea86)
+* escape moderation note before adding to dom (75ebe786)
+* #9811, send bodyClass on 403 (40c9fca9)
+* also launch docker workflow on release branches (944a7985)
+* xss on flags page via ban reason (ba3582b8)
+* up timeout for psql tests (896ff215)
+* redis batch (0c4b875e)
+* redis processing batch+1 items every iteration (3261edcc)
+* #9560, don't save post diffs if content didn't change (8b576a37)
+* #9790, get baseIndex on update for infinitescroll (6a55c027)
+* #9790, fix sorting of more than one page of pinned topics (2657804c)
+* privileges added by plugins (#9802) (3ecbb624)
+* #9800, don't send all welcome test emails to test@example.org @julianlam (71ed50b9)
+* docker - remove sha tag (b06e8dba)
+* Return QEMU back, remove platforms definition (52eace4b)
+* Docker workflow tweaks (#9792) (e7f4cde4)
+* browsers autocompleting smtp fields when they should not (34afb747)
+
+##### Refactors
+
+* no regex (18252fb9)
+* remove async.waterfall (58ac55c1)
+* remove async.waterfall (222dccaf)
+* remove async.waterfall (f35a0f43)
+* allow plugins to replace og:image, or specify additional og:image (819917da)
+
+##### Code Style Changes
+
+* give me an A! :100: (0b4d7d1f)
+
#### v1.18.2 (2021-09-08)
##### Chores
From 57358743fadfe8abe4c7076af44f49bae8f92724 Mon Sep 17 00:00:00 2001
From: "Misty (Bot)"
Date: Wed, 22 Sep 2021 17:01:44 +0000
Subject: [PATCH 02/62] chore: incrementing version number - v1.18.3
(cherry picked from commit 9e52236973276dc4be837eb39e42193c547ba9f1)
Signed-off-by: Misty (Bot)
---
install/package.json | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/install/package.json b/install/package.json
index b960000564..dd52eab1c9 100644
--- a/install/package.json
+++ b/install/package.json
@@ -2,7 +2,7 @@
"name": "nodebb",
"license": "GPL-3.0",
"description": "NodeBB Forum",
- "version": "1.18.2",
+ "version": "1.18.3",
"homepage": "http://www.nodebb.org",
"repository": {
"type": "git",
From 1a61ffc595420cc093c514bdb3227184df6d0b38 Mon Sep 17 00:00:00 2001
From: Julian Lam
Date: Wed, 22 Sep 2021 16:33:19 -0400
Subject: [PATCH 03/62] feat: a useless hover effect because raisins
---
public/less/admin/header.less | 4 ++++
1 file changed, 4 insertions(+)
diff --git a/public/less/admin/header.less b/public/less/admin/header.less
index 709dbc378f..585ac2fe37 100644
--- a/public/less/admin/header.less
+++ b/public/less/admin/header.less
@@ -102,6 +102,10 @@
border-bottom: 4px solid transparent;
transition: border-color 150ms linear;
+ &:hover {
+ border-color: darken(@brand-primary, 20%);
+ }
+
&.active {
border-color: @brand-primary;
}
From 89af00d1d5da2e7353de4f88e2242baf3dfd2935 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Bar=C4=B1=C5=9F=20Soner=20U=C5=9Fakl=C4=B1?=
Date: Wed, 22 Sep 2021 23:56:34 -0400
Subject: [PATCH 04/62] fix: #9827, fix reward duplication
---
public/src/admin/extend/rewards.js | 8 +++++++-
src/rewards/admin.js | 1 +
src/socket.io/admin/rewards.js | 2 +-
3 files changed, 9 insertions(+), 2 deletions(-)
diff --git a/public/src/admin/extend/rewards.js b/public/src/admin/extend/rewards.js
index 7df62a7e15..93f6227ccd 100644
--- a/public/src/admin/extend/rewards.js
+++ b/public/src/admin/extend/rewards.js
@@ -167,11 +167,17 @@ define('admin/extend/rewards', [], function () {
activeRewards.push(data);
});
- socket.emit('admin.rewards.save', activeRewards, function (err) {
+ socket.emit('admin.rewards.save', activeRewards, function (err, result) {
if (err) {
app.alertError(err.message);
} else {
app.alertSuccess('[[admin/extend/rewards:alert.save-success]]');
+ // newly added rewards are missing data-id, update to prevent rewards getting duplicated
+ $('#active li').each(function (index) {
+ if (!$(this).attr('data-id')) {
+ $(this).attr('data-id', result[index].id);
+ }
+ });
}
});
}
diff --git a/src/rewards/admin.js b/src/rewards/admin.js
index 15a0c9fcc8..edd3202e26 100644
--- a/src/rewards/admin.js
+++ b/src/rewards/admin.js
@@ -24,6 +24,7 @@ rewards.save = async function (data) {
await Promise.all(data.map(data => save(data)));
await saveConditions(data);
+ return data;
};
rewards.delete = async function (data) {
diff --git a/src/socket.io/admin/rewards.js b/src/socket.io/admin/rewards.js
index e68527547c..278d5e6e0f 100644
--- a/src/socket.io/admin/rewards.js
+++ b/src/socket.io/admin/rewards.js
@@ -5,7 +5,7 @@ const rewardsAdmin = require('../../rewards/admin');
const SocketRewards = module.exports;
SocketRewards.save = async function (socket, data) {
- await rewardsAdmin.save(data);
+ return await rewardsAdmin.save(data);
};
SocketRewards.delete = async function (socket, data) {
From c78309b573d039db95c6dc7b1389f35cb04715d3 Mon Sep 17 00:00:00 2001
From: Renovate Bot
Date: Thu, 23 Sep 2021 04:17:31 +0000
Subject: [PATCH 05/62] fix(deps): update dependency yargs to v17.2.0
---
install/package.json | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/install/package.json b/install/package.json
index dd52eab1c9..8a7e760c10 100644
--- a/install/package.json
+++ b/install/package.json
@@ -137,7 +137,7 @@
"winston": "3.3.3",
"xml": "^1.0.1",
"xregexp": "^5.0.1",
- "yargs": "17.1.1",
+ "yargs": "17.2.0",
"zxcvbn": "^4.4.2"
},
"devDependencies": {
From fc1a31ed872823d696d792a583dcff4570f3f61d Mon Sep 17 00:00:00 2001
From: "Misty (Bot)"
Date: Thu, 23 Sep 2021 09:07:44 +0000
Subject: [PATCH 06/62] Latest translations and fallbacks
---
public/language/sl/admin/advanced/errors.json | 2 +-
public/language/sl/admin/dashboard.json | 12 +--
.../language/sl/admin/development/logger.json | 16 ++--
public/language/sl/admin/extend/plugins.json | 28 +++---
.../language/sl/admin/manage/admins-mods.json | 16 ++--
.../language/sl/admin/manage/categories.json | 86 +++++++++----------
public/language/sl/ip-blacklist.json | 24 +++---
7 files changed, 92 insertions(+), 92 deletions(-)
diff --git a/public/language/sl/admin/advanced/errors.json b/public/language/sl/admin/advanced/errors.json
index 2cbbbce7ce..4e5a5ae888 100644
--- a/public/language/sl/admin/advanced/errors.json
+++ b/public/language/sl/admin/advanced/errors.json
@@ -1,5 +1,5 @@
{
- "figure-x": "Figure %1",
+ "figure-x": "Slika %1",
"error-events-per-day": "%1 dogodkov na dan",
"error.404": "4040 ni najdeno",
"error.503": "503 storitev ni na voljo",
diff --git a/public/language/sl/admin/dashboard.json b/public/language/sl/admin/dashboard.json
index c334df9b0f..366af71742 100644
--- a/public/language/sl/admin/dashboard.json
+++ b/public/language/sl/admin/dashboard.json
@@ -62,17 +62,17 @@
"user-presence": "Prisotnost uporabnikov",
"on-categories": "On categories list",
- "reading-posts": "Reading posts",
- "browsing-topics": "Browsing topics",
+ "reading-posts": "Branje objav",
+ "browsing-topics": "Brskanje po temah",
"recent": "Nedavno",
"unread": "Neprebrano",
- "high-presence-topics": "High Presence Topics",
+ "high-presence-topics": "Teme z visoko prisotnostjo",
"graphs.page-views": "Ogledov strani",
- "graphs.page-views-registered": "Page Views Registered",
- "graphs.page-views-guest": "Page Views Guest",
- "graphs.page-views-bot": "Page Views Bot",
+ "graphs.page-views-registered": "Ogledov strani-registrirani",
+ "graphs.page-views-guest": "Ogledov strani-gosti",
+ "graphs.page-views-bot": "Ogledov strani-robot",
"graphs.unique-visitors": "Edinstveni obiskovalci",
"graphs.registered-users": "Registrirani uporabniki",
"graphs.anonymous-users": "Anonimni uporabniki",
diff --git a/public/language/sl/admin/development/logger.json b/public/language/sl/admin/development/logger.json
index 6ab9558149..ce73544633 100644
--- a/public/language/sl/admin/development/logger.json
+++ b/public/language/sl/admin/development/logger.json
@@ -1,12 +1,12 @@
{
- "logger-settings": "Logger Settings",
- "description": "By enabling the check boxes, you will receive logs to your terminal. If you specify a path, logs will then be saved to a file instead. HTTP logging is useful for collecting statistics about who, when, and what people access on your forum. In addition to logging HTTP requests, we can also log socket.io events. Socket.io logging, in combination with redis-cli monitor, can be very helpful for learning NodeBB's internals.",
- "explanation": "Simply check/uncheck the logging settings to enable or disable logging on the fly. No restart needed.",
- "enable-http": "Enable HTTP logging",
- "enable-socket": "Enable socket.io event logging",
- "file-path": "Path to log file",
+ "logger-settings": "Nastavitve beleženja",
+ "description": "Če omogočite potrditvena polja, boste prejemali dnevnike na svoj terminal. Če določite pot, se bodo dnevniki namesto tega shranili v datoteko. Zapisovanje HTTP je uporabno za zbiranje statističnih podatkov o tem, kdo, kdaj in do česa ljudje dostopajo na vašem forumu. Poleg beleženja zahtev HTTP lahko beležimo tudi dogodke socket.io. Zapisovanje Socket.io v kombinaciji z monitorjem redis-cli je lahko v veliko pomoč pri učenju notranjosti NodeBB.",
+ "explanation": "Preprosto preverite/počistite nastavitve beleženja, če želite omogočiti ali onemogočiti sprotno beleženje. Ponovni zagon ni potreben.",
+ "enable-http": "Omogoči HTTP prijave",
+ "enable-socket": "Omogoči beleženje dogodkov socket.io",
+ "file-path": "Pot do datoteke dnevnika",
"file-path-placeholder": "/path/to/log/file.log ::: leave blank to log to your terminal",
- "control-panel": "Logger Control Panel",
- "update-settings": "Update Logger Settings"
+ "control-panel": "Nadzorna plošča beleženja",
+ "update-settings": "Posodobi nastavitve beleženja"
}
\ No newline at end of file
diff --git a/public/language/sl/admin/extend/plugins.json b/public/language/sl/admin/extend/plugins.json
index a6e276dff7..648edefde3 100644
--- a/public/language/sl/admin/extend/plugins.json
+++ b/public/language/sl/admin/extend/plugins.json
@@ -13,11 +13,11 @@
"submit-anonymous-usage": "Submit anonymous plugin usage data.",
"reorder-plugins": "Re-order Plugins",
"order-active": "Order Active Plugins",
- "dev-interested": "Interested in writing plugins for NodeBB?",
- "docs-info": "Full documentation regarding plugin authoring can be found in the NodeBB Docs Portal.",
+ "dev-interested": "Vas zanima pisanje vtičnikov za NodeBB?",
+ "docs-info": "Celotno dokumentacijo o ustvarjanju vtičnikov najdete v NodeBB dokumentnem portalu.",
- "order.description": "Certain plugins work ideally when they are initialised before/after other plugins.",
- "order.explanation": "Plugins load in the order specified here, from top to bottom",
+ "order.description": "Nekateri vtičniki delujejo idealno, če so inicializirani pred/po drugih vtičnikih.",
+ "order.explanation": "Vtičniki se nalagajo po vrstnem redu, ki je tukaj naveden, od zgoraj navzdol",
"plugin-item.themes": "Teme",
"plugin-item.deactivate": "Deaktiviraj",
@@ -30,9 +30,9 @@
"plugin-item.upgrade": "Posodobi",
"plugin-item.more-info": "Za več informacij:",
"plugin-item.unknown": "Neznano",
- "plugin-item.unknown-explanation": "The state of this plugin could not be determined, possibly due to a misconfiguration error.",
+ "plugin-item.unknown-explanation": "Stanja tega vtičnika ni bilo mogoče določiti, morda zaradi napačne konfiguracije.",
"plugin-item.compatible": "Ta vtičnik deluje na NodeBB %1",
- "plugin-item.not-compatible": "This plugin has no compatibility data, make sure it works before installing on your production environment.",
+ "plugin-item.not-compatible": "Ta vtičnik nima podatkov o združljivosti, preden ga namestite v svoje produkcijsko okolje, se prepričajte, da deluje.",
"alert.enabled": "Vtičnik omogočen",
"alert.disabled": "Vtičnik onemogočen",
@@ -44,14 +44,14 @@
"alert.upgrade-success": "Za popolno nadgradnjo tega vtičnika obnovite in ponovno zaženete vaš NodeB.",
"alert.install-success": "Vtičnik je uspešno nameščen, aktivirajte ga.",
"alert.uninstall-success": "Vtičnik je bil uspešno deaktiviran in odstranjen.",
- "alert.suggest-error": "
NodeBB could not reach the package manager, proceed with installation of latest version?
Server returned (%1): %2
",
- "alert.package-manager-unreachable": "
NodeBB could not reach the package manager, an upgrade is not suggested at this time.
",
- "alert.incompatible": "
Your version of NodeBB (v%1) is only cleared to upgrade to v%2 of this plugin. Please update your NodeBB if you wish to install a newer version of this plugin.
",
- "alert.possibly-incompatible": "
No Compatibility Information Found
This plugin did not specify a specific version for installation given your NodeBB version. Full compatibility cannot be guaranteed, and may cause your NodeBB to no longer start properly.
In the event that NodeBB cannot boot properly:
$ ./nodebb reset plugin=\"%1\"
Continue installation of latest version of this plugin?
",
- "alert.reorder": "Plugins Re-ordered",
- "alert.reorder-success": "Please rebuild and restart your NodeBB to fully complete the process.",
+ "alert.suggest-error": "
NodeBB ni mogel doseči upravitelja paketov, naj nadaljuje z namestitvijo najnovejše različice?
Strežnik je našel (%1): %2
",
+ "alert.package-manager-unreachable": "
NodeBB ni mogel doseči upravitelja paketov, posodobitev v tem trenutku ni priporočena.
",
+ "alert.incompatible": "Vaša različica NodeBB (v%1) dovoljuje nadgradnjo tega vtičnika samo na različico v%2. Če želite namestiti novejšo različico tega vtičnika, posodobite svoj NodeBB.
",
+ "alert.possibly-incompatible": "
Podatke o združljivosti ni mogoče najti
Ta vtičnik ni določil posebne različice za namestitev glede na vašo različico NodeBB. Popolne združljivosti ni mogoče zagotoviti, zato se lahko vaš NodeBB ne zažene več pravilno.
V primeru, da se NodeBB ne zažene pravilno:
$ ./nodebb reset plugin=\"%1\"
Ali želite nadaljevati z namestitvijo najnovejše različice tega vtičnika?
",
+ "alert.reorder": "Vtičniki preurejeni",
+ "alert.reorder-success": "Prosimo, da za dokončanje postopka v celoti obnovite in znova zaženete NodeBB.",
- "license.title": "Plugin License Information",
- "license.intro": "The plugin %1 is licensed under the %2. Please read and understand the license terms prior to activating this plugin.",
+ "license.title": "Informacija o licenci vtičnika",
+ "license.intro": "Vtičnik %1 je licenciran pod %2. Preden aktivirate ta vtičnik, preberite in razumite licenčne pogoje.",
"license.cta": "Ali želite nadaljevati z aktiviranjem tega vtičnika?"
}
diff --git a/public/language/sl/admin/manage/admins-mods.json b/public/language/sl/admin/manage/admins-mods.json
index e0f39ed5d4..7009fad3a0 100644
--- a/public/language/sl/admin/manage/admins-mods.json
+++ b/public/language/sl/admin/manage/admins-mods.json
@@ -1,10 +1,10 @@
{
- "administrators": "Administrators",
- "global-moderators": "Global Moderators",
- "no-global-moderators": "No Global Moderators",
- "moderators-of-category": "%1 Moderators",
- "no-moderators": "No Moderators",
- "add-administrator": "Add Administrator",
- "add-global-moderator": "Add Global Moderator",
- "add-moderator": "Add Moderator"
+ "administrators": "Skrbnik",
+ "global-moderators": "Globalni moderatorji",
+ "no-global-moderators": "Ni globalnih moderatorjev",
+ "moderators-of-category": "%1 moderator(jev)",
+ "no-moderators": "Ni moderatorjev",
+ "add-administrator": "Dodaj skrbnika",
+ "add-global-moderator": "Dodaj globalnega moderatorja",
+ "add-moderator": "Dodaj moderatorja"
}
\ No newline at end of file
diff --git a/public/language/sl/admin/manage/categories.json b/public/language/sl/admin/manage/categories.json
index 36eb291256..d2bba96e4b 100644
--- a/public/language/sl/admin/manage/categories.json
+++ b/public/language/sl/admin/manage/categories.json
@@ -1,92 +1,92 @@
{
"settings": "Nastavitve kategorije",
- "privileges": "Privileges",
+ "privileges": "Privilegiji",
"name": "Ime kategorije",
"description": "Opis kategorije",
"bg-color": "Barva ozadja",
"text-color": "Barva besedila",
- "bg-image-size": "Background Image Size",
- "custom-class": "Custom Class",
- "num-recent-replies": "# of Recent Replies",
+ "bg-image-size": "Velikost slike ozadja",
+ "custom-class": "Razred po meri",
+ "num-recent-replies": "# nedavnih odgovorov",
"ext-link": "Zunanja povezava",
"subcategories-per-page": "Podkategorij na stran",
- "is-section": "Treat this category as a section",
+ "is-section": "Obravnavaj to kategorijo kot sekcijo",
"post-queue": "Čakalna vrsta objav",
- "tag-whitelist": "Tag Whitelist",
+ "tag-whitelist": "Bela lista oznak",
"upload-image": "Naloži sliko",
"delete-image": "Odstrani",
"category-image": "Slika kategorije",
- "parent-category": "Parent Category",
- "optional-parent-category": "(Optional) Parent Category",
- "top-level": "Top Level",
- "parent-category-none": "(None)",
+ "parent-category": "Nadrejena kategorija",
+ "optional-parent-category": "(Izbirno) Nadrejena kategorija",
+ "top-level": "Vrhnja raven",
+ "parent-category-none": "(Brez)",
"copy-parent": "Copy Parent",
- "copy-settings": "Copy Settings From",
- "optional-clone-settings": "(Optional) Clone Settings From Category",
+ "copy-settings": "Kopiraj nastavitve iz",
+ "optional-clone-settings": "(Izbirno) Kloniraj nastavitve iz kategorije",
"clone-children": "Clone Children Categories And Settings",
- "purge": "Purge Category",
+ "purge": "Počisti kategorijo",
"enable": "Omogoči",
"disable": "Onemogoči",
- "edit": "Edit",
- "analytics": "Analytics",
+ "edit": "Uredi",
+ "analytics": "Analitika",
"view-category": "Poglej kategorijo",
"set-order": "Nastavi vrstni red",
"set-order-help": "Če nastavite vrstni red kategorije, se bo ta kategorija premaknila in po potrebi posodobila vrstni red drugih kategorij. Najmanjša št. vrstnega reda je 1, kar kategorijo postavlja na vrh.",
"select-category": "Izberi kategorijo",
- "set-parent-category": "Set Parent Category",
+ "set-parent-category": "Nastavi nadrejeno kategorijo",
- "privileges.description": "You can configure the access control privileges for portions of the site in this section. Privileges can be granted on a per-user or a per-group basis. Select the domain of effect from the dropdown below.",
- "privileges.category-selector": "Configuring privileges for ",
- "privileges.warning": "Note: Privilege settings take effect immediately. It is not necessary to save the category after adjusting these settings.",
- "privileges.section-viewing": "Viewing Privileges",
- "privileges.section-posting": "Posting Privileges",
- "privileges.section-moderation": "Moderation Privileges",
- "privileges.section-other": "Other",
+ "privileges.description": "V tem razdelku lahko konfigurirate pravice za nadzor dostopa za dele spletnega mesta. Privilegiji se lahko podelijo uporabniku ali skupini. V spodnjem spustnem meniju izberite področje učinka.",
+ "privileges.category-selector": "Konfiguriranje privilegijev za",
+ "privileges.warning": "Opomba: Nastavitve privilegijev pričnejo učinkovati takoj. Po prilagoditvi teh nastavitev kategorije ni potrebno shraniti.",
+ "privileges.section-viewing": "Pravice ogleda",
+ "privileges.section-posting": "Pravice za objavo",
+ "privileges.section-moderation": "Pravice spreminjanja",
+ "privileges.section-other": "Drugo",
"privileges.section-user": "Uporabnik",
"privileges.search-user": "Dodaj uporabnika",
- "privileges.no-users": "No user-specific privileges in this category.",
+ "privileges.no-users": "V tej kategoriji ni uporabniških pravic.",
"privileges.section-group": "Skupina",
"privileges.group-private": "Ta skupina je zasebna",
- "privileges.inheritance-exception": "This group does not inherit privileges from registered-users group",
- "privileges.banned-user-inheritance": "Banned users inherit privileges from banned-users group",
+ "privileges.inheritance-exception": "Ta skupina ne deduje pravic od skupine registriranih uporabnikov",
+ "privileges.banned-user-inheritance": "Prepovedani uporabniki dedujejo pravice od skupine prepovedanih uporabnikov",
"privileges.search-group": "Dodaj skupino",
"privileges.copy-to-children": "Copy to Children",
"privileges.copy-from-category": "Kopiraj iz kategorije",
"privileges.copy-privileges-to-all-categories": "Kopiraj v vse kategorije",
"privileges.copy-group-privileges-to-children": "Copy this group's privileges to the children of this category.",
- "privileges.copy-group-privileges-to-all-categories": "Copy this group's privileges to all categories.",
- "privileges.copy-group-privileges-from": "Copy this group's privileges from another category.",
- "privileges.inherit": "If the registered-users group is granted a specific privilege, all other groups receive an implicit privilege, even if they are not explicitly defined/checked. This implicit privilege is shown to you because all users are part of the registered-users user group, and so, privileges for additional groups need not be explicitly granted.",
- "privileges.copy-success": "Privileges copied!",
+ "privileges.copy-group-privileges-to-all-categories": "Kopiraj pravice te skupine v vse kategorije.",
+ "privileges.copy-group-privileges-from": "Kopiraj pravice te skupine iz druge kategorije.",
+ "privileges.inherit": "Če je skupini registeriranih uporabnikov dodeljena posebna pravica, prejmejo vse druge skupine implicitno pravico, čeprav niso eksplicitno navedene/označene. Ta implicitna pravica se vam prikaže, ker so vsi uporabniki del skupine registriranih uporabnikov, zato pravic za dodatne skupine ni treba izrecno podeliti.",
+ "privileges.copy-success": "Pravice so kopirane!",
"analytics.back": "Nazaj na seznam kategorij",
- "analytics.title": "Analytics for \"%1\" category",
- "analytics.pageviews-hourly": "Figure 1 – Hourly page views for this category",
- "analytics.pageviews-daily": "Figure 2 – Daily page views for this category",
- "analytics.topics-daily": "Figure 3 – Daily topics created in this category",
- "analytics.posts-daily": "Figure 4 – Daily posts made in this category",
+ "analytics.title": "Analitika za kategorijo \"%1\"",
+ "analytics.pageviews-hourly": "Slika 1 – Urni ogledi strani za to kategorijo",
+ "analytics.pageviews-daily": "Slika 2 – Dnevni ogledi strani za to kategorijo",
+ "analytics.topics-daily": "Slika 3 – Dnevno ustvarjene teme v tej kategoriji",
+ "analytics.posts-daily": "Slika 4 – Dnevne objave v tej kategoriji",
"alert.created": "Ustvarjeno",
"alert.create-success": "Kategorija je uspešno ustvarjena!",
"alert.none-active": "Nimate aktivnih kategorij.",
"alert.create": "Ustvari kategorijo",
"alert.confirm-purge": "
Do you really want to purge this category \"%1\"?
Warning! All topics and posts in this category will be purged!
Purging a category will remove all topics and posts, and delete the category from the database. If you want to remove a category temporarily, you'll want to \"disable\" the category instead.
diff --git a/test/posts.js b/test/posts.js
index 200810ad89..20a7661da1 100644
--- a/test/posts.js
+++ b/test/posts.js
@@ -1426,4 +1426,111 @@ describe('Post\'s', () => {
});
});
});
+
+ describe('Topic Backlinks', () => {
+ let tid1;
+ before(async () => {
+ tid1 = await topics.post({
+ uid: 1,
+ cid,
+ title: 'Topic backlink testing - topic 1',
+ content: 'Some text here for the OP',
+ });
+ tid1 = tid1.topicData.tid;
+ });
+
+ describe('.syncBacklinks()', () => {
+ it('should error on invalid data', async () => {
+ try {
+ await topics.syncBacklinks();
+ } catch (e) {
+ assert(e);
+ assert.strictEqual(e.message, '[[error:invalid-data]]');
+ }
+ });
+
+ it('should do nothing if the post does not contain a link to a topic', async () => {
+ const backlinks = await topics.syncBacklinks({
+ content: 'This is a post\'s content',
+ });
+
+ assert.strictEqual(backlinks, 0);
+ });
+
+ it('should create a backlink if it detects a topic link in a post', async () => {
+ const count = await topics.syncBacklinks({
+ pid: 2,
+ content: `This is a link to [topic 1](${nconf.get('url')}/topic/1/abcdef)`,
+ });
+ const events = await topics.events.get(1, 1);
+ const backlinks = await db.getSortedSetMembers('pid:2:backlinks');
+
+ assert.strictEqual(count, 1);
+ assert(events);
+ assert.strictEqual(events.length, 1);
+ assert(backlinks);
+ assert(backlinks.includes('1'));
+ });
+
+ it('should remove the backlink (but keep the event) if the post no longer contains a link to a topic', async () => {
+ const count = await topics.syncBacklinks({
+ pid: 2,
+ content: 'This is a link to [nothing](http://example.org)',
+ });
+ const events = await topics.events.get(1, 1);
+ const backlinks = await db.getSortedSetMembers('pid:2:backlinks');
+
+ assert.strictEqual(count, 0);
+ assert(events);
+ assert.strictEqual(events.length, 1);
+ assert(backlinks);
+ assert.strictEqual(backlinks.length, 0);
+ });
+ });
+
+ describe('integration tests', () => {
+ it('should create a topic event in the referenced topic', async () => {
+ const topic = await topics.post({
+ uid: 1,
+ cid,
+ title: 'Topic backlink testing - topic 2',
+ content: `Some text here for the OP – ${nconf.get('url')}/topic/${tid1}`,
+ });
+
+ const events = await topics.events.get(tid1, 1);
+ assert(events);
+ assert.strictEqual(events.length, 1);
+ assert.strictEqual(events[0].type, 'backlink');
+ assert.strictEqual(parseInt(events[0].uid, 10), 1);
+ assert.strictEqual(events[0].href, `/post/${topic.postData.pid}`);
+ });
+
+ it('should not create a topic event if referenced topic is the same as current topic', async () => {
+ await topics.reply({
+ uid: 1,
+ tid: tid1,
+ content: `Referencing itself – ${nconf.get('url')}/topic/${tid1}`,
+ });
+
+ const events = await topics.events.get(tid1, 1);
+ assert(events);
+ assert.strictEqual(events.length, 1); // should still equal 1
+ });
+
+ it('should not show backlink events if the feature is disabled', async () => {
+ meta.config.topicBacklinks = 0;
+
+ await topics.post({
+ uid: 1,
+ cid,
+ title: 'Topic backlink testing - topic 3',
+ content: `Some text here for the OP – ${nconf.get('url')}/topic/${tid1}`,
+ });
+
+ const events = await topics.events.get(tid1, 1);
+ assert(events);
+ assert.strictEqual(events.length, 0);
+ });
+ });
+ });
});
From 409151050a13863ac7ab999e6c2ecc206c8a61b8 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Bar=C4=B1=C5=9F=20Soner=20U=C5=9Fakl=C4=B1?=
Date: Wed, 29 Sep 2021 20:22:21 -0400
Subject: [PATCH 38/62] fix: #9828, max-width
---
public/less/admin/extend/rewards.less | 3 +++
1 file changed, 3 insertions(+)
diff --git a/public/less/admin/extend/rewards.less b/public/less/admin/extend/rewards.less
index 3972b16de3..e90eb3e717 100644
--- a/public/less/admin/extend/rewards.less
+++ b/public/less/admin/extend/rewards.less
@@ -31,12 +31,15 @@
&.if-block {
border-color: @brand-primary;
+ max-width: 33%;
}
&.this-block {
border-color: @brand-warning;
+ max-width: 33%;
}
&.then-block {
border-color: @brand-success;
+ max-width: 33%;
}
&.reward-block {
border-color: @brand-success;
From a658757382dfcda96bd2899df1dd3556aa46ca21 Mon Sep 17 00:00:00 2001
From: "Misty (Bot)"
Date: Thu, 30 Sep 2021 09:07:35 +0000
Subject: [PATCH 39/62] Latest translations and fallbacks
---
public/language/ar/admin/settings/post.json | 3 +
public/language/ar/topic.json | 1 +
public/language/bg/admin/settings/post.json | 3 +
public/language/bg/topic.json | 1 +
public/language/bn/admin/settings/post.json | 3 +
public/language/bn/topic.json | 1 +
public/language/cs/admin/settings/post.json | 3 +
public/language/cs/topic.json | 1 +
public/language/da/admin/settings/post.json | 3 +
public/language/da/topic.json | 1 +
public/language/de/admin/settings/post.json | 3 +
public/language/de/topic.json | 1 +
public/language/el/admin/settings/post.json | 3 +
public/language/el/topic.json | 1 +
.../language/en-US/admin/settings/post.json | 3 +
public/language/en-US/topic.json | 1 +
.../en-x-pirate/admin/settings/post.json | 3 +
public/language/en-x-pirate/topic.json | 1 +
public/language/es/admin/settings/post.json | 3 +
public/language/es/topic.json | 1 +
public/language/et/admin/settings/post.json | 3 +
public/language/et/topic.json | 1 +
.../language/fa-IR/admin/settings/post.json | 3 +
public/language/fa-IR/topic.json | 1 +
public/language/fi/admin/settings/post.json | 3 +
public/language/fi/topic.json | 1 +
public/language/fr/admin/settings/post.json | 3 +
public/language/fr/topic.json | 1 +
public/language/gl/admin/settings/post.json | 3 +
public/language/gl/topic.json | 1 +
public/language/he/admin/settings/post.json | 3 +
public/language/he/topic.json | 1 +
public/language/hr/admin/settings/post.json | 3 +
public/language/hr/topic.json | 1 +
public/language/hu/admin/settings/post.json | 3 +
public/language/hu/topic.json | 1 +
public/language/id/admin/settings/post.json | 3 +
public/language/id/topic.json | 1 +
public/language/it/admin/settings/post.json | 3 +
public/language/it/topic.json | 1 +
public/language/ja/admin/settings/post.json | 3 +
public/language/ja/topic.json | 1 +
public/language/ko/admin/settings/post.json | 3 +
public/language/ko/topic.json | 1 +
public/language/lt/admin/settings/post.json | 3 +
public/language/lt/topic.json | 1 +
public/language/lv/admin/settings/post.json | 3 +
public/language/lv/topic.json | 1 +
public/language/ms/admin/settings/post.json | 3 +
public/language/ms/topic.json | 1 +
public/language/nb/admin/settings/post.json | 3 +
public/language/nb/topic.json | 1 +
public/language/nl/admin/settings/post.json | 3 +
public/language/nl/topic.json | 1 +
public/language/pl/admin/settings/post.json | 3 +
public/language/pl/topic.json | 1 +
.../language/pt-BR/admin/settings/post.json | 3 +
public/language/pt-BR/topic.json | 1 +
.../language/pt-PT/admin/settings/post.json | 3 +
public/language/pt-PT/topic.json | 1 +
public/language/ro/admin/settings/post.json | 3 +
public/language/ro/topic.json | 1 +
public/language/ru/admin/settings/post.json | 3 +
public/language/ru/topic.json | 1 +
public/language/rw/admin/settings/post.json | 3 +
public/language/rw/topic.json | 1 +
public/language/sc/admin/settings/post.json | 3 +
public/language/sc/topic.json | 1 +
public/language/sk/admin/settings/post.json | 3 +
public/language/sk/topic.json | 1 +
public/language/sl/admin/settings/post.json | 3 +
public/language/sl/flags.json | 58 ++++-----
public/language/sl/topic.json | 111 +++++++++---------
public/language/sr/admin/settings/post.json | 3 +
public/language/sr/topic.json | 1 +
public/language/sv/admin/settings/post.json | 3 +
public/language/sv/topic.json | 1 +
public/language/th/admin/settings/post.json | 3 +
public/language/th/topic.json | 1 +
public/language/tr/admin/settings/post.json | 3 +
public/language/tr/topic.json | 1 +
public/language/uk/admin/settings/post.json | 3 +
public/language/uk/topic.json | 1 +
public/language/vi/admin/settings/post.json | 3 +
public/language/vi/topic.json | 1 +
.../language/zh-CN/admin/settings/post.json | 3 +
public/language/zh-CN/topic.json | 1 +
.../language/zh-TW/admin/settings/post.json | 3 +
public/language/zh-TW/topic.json | 1 +
89 files changed, 260 insertions(+), 84 deletions(-)
diff --git a/public/language/ar/admin/settings/post.json b/public/language/ar/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/ar/admin/settings/post.json
+++ b/public/language/ar/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/ar/topic.json b/public/language/ar/topic.json
index dd877b32dd..5541e97d22 100644
--- a/public/language/ar/topic.json
+++ b/public/language/ar/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "اضغط هنا للعودة لأخر مشاركة مقروءة في الموضوع",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/bg/admin/settings/post.json b/public/language/bg/admin/settings/post.json
index 8f4ef2a238..4f41a2cd57 100644
--- a/public/language/bg/admin/settings/post.json
+++ b/public/language/bg/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Показване на раздела „Помощ“",
"composer.enable-plugin-help": "Позволяване на добавките да добавят съдържание в раздела за помощ",
"composer.custom-help": "Персонализиран текст за помощ",
+ "backlinks": "Обратни връзки",
+ "backlinks.enabled": "Включване на обратните връзки в темите",
+ "backlinks.help": "Ако в публикацията има препратка към друга тема, там ще бъде поставена връзка към публикацията, с конкретното време.",
"ip-tracking": "Записване на IP адреса",
"ip-tracking.each-post": "Записване на IP адреса за всяка публикация",
"enable-post-history": "Включване на историята на публикациите"
diff --git a/public/language/bg/topic.json b/public/language/bg/topic.json
index ecc9ad950a..b1a10de9b7 100644
--- a/public/language/bg/topic.json
+++ b/public/language/bg/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Възстановена от",
"moved-from-by": "Преместена от %1 от",
"queued-by": "Публикацията е добавена в опашката за одобрение →",
+ "backlink": "Спомената от",
"bookmark_instructions": "Щракнете тук, за да се върнете към последно прочетената публикация в тази тема.",
"flag-post": "Докладване на тази публикация",
"flag-user": "Докладване на този потребител",
diff --git a/public/language/bn/admin/settings/post.json b/public/language/bn/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/bn/admin/settings/post.json
+++ b/public/language/bn/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/bn/topic.json b/public/language/bn/topic.json
index c44b134150..f7482e41b5 100644
--- a/public/language/bn/topic.json
+++ b/public/language/bn/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Click here to return to the last read post in this thread.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/cs/admin/settings/post.json b/public/language/cs/admin/settings/post.json
index af5702173a..a76f6b446f 100644
--- a/public/language/cs/admin/settings/post.json
+++ b/public/language/cs/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Zobrazit záložku „Nápověda”",
"composer.enable-plugin-help": "Povolit rozšíření přidat obsah do záložky nápovědy",
"composer.custom-help": "Uživatelský text nápovědy",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "Sledování IP",
"ip-tracking.each-post": "Sledovat adresu IP u každého příspěvku",
"enable-post-history": "Povolit historii příspěvku"
diff --git a/public/language/cs/topic.json b/public/language/cs/topic.json
index 58d554e1c8..96cf0fbffe 100644
--- a/public/language/cs/topic.json
+++ b/public/language/cs/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Pro návrat k poslednímu čtenému příspěvku v tématu, klikněte zde.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/da/admin/settings/post.json b/public/language/da/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/da/admin/settings/post.json
+++ b/public/language/da/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/da/topic.json b/public/language/da/topic.json
index 5d5ff1d1d5..5d6d8ac404 100644
--- a/public/language/da/topic.json
+++ b/public/language/da/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Klik her for at vende tilbage til den sidst læste indlæg i denne tråd.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/de/admin/settings/post.json b/public/language/de/admin/settings/post.json
index caa1fae9ae..09f5c41b56 100644
--- a/public/language/de/admin/settings/post.json
+++ b/public/language/de/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "\"Hilfe\"-Tab anzeigen",
"composer.enable-plugin-help": "Plugins erlauben Inhalte dem \"Help\"-Tab hinzuzufügen",
"composer.custom-help": "Benutzerdefinierter Hilfe-Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP-Verfolgung",
"ip-tracking.each-post": "IP-Adresse für jeden Beitrag speichern",
"enable-post-history": "Aktiviere Beitrags-Änderungsgeschichte"
diff --git a/public/language/de/topic.json b/public/language/de/topic.json
index dfe3a8fcdf..63581ae290 100644
--- a/public/language/de/topic.json
+++ b/public/language/de/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Klicke hier, um zum letzten gelesenen Beitrag des Themas zurückzukehren.",
"flag-post": "Diesen Post melden",
"flag-user": "Diesen Benutzer melden",
diff --git a/public/language/el/admin/settings/post.json b/public/language/el/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/el/admin/settings/post.json
+++ b/public/language/el/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/el/topic.json b/public/language/el/topic.json
index ddc2e4bec1..94b2586d41 100644
--- a/public/language/el/topic.json
+++ b/public/language/el/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Click here to return to the last read post in this thread.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/en-US/admin/settings/post.json b/public/language/en-US/admin/settings/post.json
index f91a065e46..05656c9fba 100644
--- a/public/language/en-US/admin/settings/post.json
+++ b/public/language/en-US/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/en-US/topic.json b/public/language/en-US/topic.json
index 29384a4160..ae2389ee4e 100644
--- a/public/language/en-US/topic.json
+++ b/public/language/en-US/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Click here to return to the last read post in this thread.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/en-x-pirate/admin/settings/post.json b/public/language/en-x-pirate/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/en-x-pirate/admin/settings/post.json
+++ b/public/language/en-x-pirate/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/en-x-pirate/topic.json b/public/language/en-x-pirate/topic.json
index 29384a4160..ae2389ee4e 100644
--- a/public/language/en-x-pirate/topic.json
+++ b/public/language/en-x-pirate/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Click here to return to the last read post in this thread.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/es/admin/settings/post.json b/public/language/es/admin/settings/post.json
index 8525d35a08..72e094800d 100644
--- a/public/language/es/admin/settings/post.json
+++ b/public/language/es/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Mostrar pestaña \"Ayuda\"",
"composer.enable-plugin-help": "Permitir a plugins añadir contenido a la pestaña de ayuda",
"composer.custom-help": "Texto de Ayuda Personalizado",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "Seguimiento de IP",
"ip-tracking.each-post": "Seguir la IP para cada entrada/respuesta",
"enable-post-history": "Activar historial de respuestas"
diff --git a/public/language/es/topic.json b/public/language/es/topic.json
index aab7521175..84a7e4c422 100644
--- a/public/language/es/topic.json
+++ b/public/language/es/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restaurado por",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Haz click aquí para volver a tu último mensaje leído en este tema",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/et/admin/settings/post.json b/public/language/et/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/et/admin/settings/post.json
+++ b/public/language/et/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/et/topic.json b/public/language/et/topic.json
index b15b22e432..f99933c619 100644
--- a/public/language/et/topic.json
+++ b/public/language/et/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Vajuta siia, et tagasi minna viimati loetud postituse juurde siin teemas.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/fa-IR/admin/settings/post.json b/public/language/fa-IR/admin/settings/post.json
index fb0a7ad95e..57fd21e92f 100644
--- a/public/language/fa-IR/admin/settings/post.json
+++ b/public/language/fa-IR/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/fa-IR/topic.json b/public/language/fa-IR/topic.json
index 1ee8d5f593..c7e8c2bdb4 100644
--- a/public/language/fa-IR/topic.json
+++ b/public/language/fa-IR/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "برای بازگشت به آخرین پست در این موضوع اینجا را کلیک کنید.",
"flag-post": "گزارش این پست",
"flag-user": "گزارش این کاربر",
diff --git a/public/language/fi/admin/settings/post.json b/public/language/fi/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/fi/admin/settings/post.json
+++ b/public/language/fi/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/fi/topic.json b/public/language/fi/topic.json
index a5153c2f3b..c58b5350f1 100644
--- a/public/language/fi/topic.json
+++ b/public/language/fi/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Klikkaa tästä palataksesi viimeisimpään luettuun viestiin tässä aiheessa",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/fr/admin/settings/post.json b/public/language/fr/admin/settings/post.json
index b8cbb4c803..13887a5f54 100644
--- a/public/language/fr/admin/settings/post.json
+++ b/public/language/fr/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Afficher l'onglet \"Aide\"",
"composer.enable-plugin-help": "Autoriser les plugins à modifier l'onglet d'aide",
"composer.custom-help": "Message d'aide personnalisé",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "Suivi d'IP",
"ip-tracking.each-post": "Suivre l'adresse IP pour chaque message",
"enable-post-history": "Activer l'historique des publications"
diff --git a/public/language/fr/topic.json b/public/language/fr/topic.json
index 429b99381e..c5e793b337 100644
--- a/public/language/fr/topic.json
+++ b/public/language/fr/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restauré par",
"moved-from-by": "Déplacé de %1 par",
"queued-by": "Message en attente d'approbation →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Cliquez ici pour retourner au dernier message lu de ce fil.",
"flag-post": "Signaler ce message",
"flag-user": "Signaler cet utilisateur",
diff --git a/public/language/gl/admin/settings/post.json b/public/language/gl/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/gl/admin/settings/post.json
+++ b/public/language/gl/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/gl/topic.json b/public/language/gl/topic.json
index 61757a9699..72e77219fa 100644
--- a/public/language/gl/topic.json
+++ b/public/language/gl/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Pica aquí para volver á última mensaxe lida neste tema ",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/he/admin/settings/post.json b/public/language/he/admin/settings/post.json
index ecca8e24f7..f2f1611796 100644
--- a/public/language/he/admin/settings/post.json
+++ b/public/language/he/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "הצג כרטיסיית \"עזרה\"",
"composer.enable-plugin-help": "אפשר לתוסיפים להוסיף תוכן ללשונית עזרה",
"composer.custom-help": "טקסט עזרה מותאם אישית",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP מעקב",
"ip-tracking.each-post": "מעקב אחר כתובת IP על כל הודעה",
"enable-post-history": "הפוך היסטוריית פוסטים לזמינה"
diff --git a/public/language/he/topic.json b/public/language/he/topic.json
index 3ea51ee041..964c73d19c 100644
--- a/public/language/he/topic.json
+++ b/public/language/he/topic.json
@@ -47,6 +47,7 @@
"restored-by": "שוחזר על ידי",
"moved-from-by": "Moved from %1 by",
"queued-by": "הפוסט ממתין לאישור →",
+ "backlink": "Referenced by",
"bookmark_instructions": "לחץ כאן בכדי לחזור לפוסט האחרון שקראת בנושא הזה.",
"flag-post": "דווח על פוסט זה",
"flag-user": "דווח על משתמש זה",
diff --git a/public/language/hr/admin/settings/post.json b/public/language/hr/admin/settings/post.json
index 4b6d50fc5a..b32357dc51 100644
--- a/public/language/hr/admin/settings/post.json
+++ b/public/language/hr/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Prikaži \"Pomoć\"",
"composer.enable-plugin-help": "Dozvoli dodatcima da dodaju sadržaj u \"Pomoć\"",
"composer.custom-help": "Tekst \"Pomoć\"",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP praćenje",
"ip-tracking.each-post": "Prati IP adresu za svaku objavu",
"enable-post-history": "Enable Post History"
diff --git a/public/language/hr/topic.json b/public/language/hr/topic.json
index c35f16e278..31110f9f84 100644
--- a/public/language/hr/topic.json
+++ b/public/language/hr/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Klikni ovdje za povratak na zadnji pročitani post.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/hu/admin/settings/post.json b/public/language/hu/admin/settings/post.json
index 3091efd2f2..2bae9b654e 100644
--- a/public/language/hu/admin/settings/post.json
+++ b/public/language/hu/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "\"Segítség\" panel megjelenítése",
"composer.enable-plugin-help": "Beépülők hozzáadhassanak saját tartalmaz a segítség panelhoz",
"composer.custom-help": "Egyedi szöveg a segítségnél",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP nyomonkövetés",
"ip-tracking.each-post": "IP cím követése minden hozzászólásnál",
"enable-post-history": "Hozzászólás történetiség engedélyezése"
diff --git a/public/language/hu/topic.json b/public/language/hu/topic.json
index 859c6b8a00..8e39ba268a 100644
--- a/public/language/hu/topic.json
+++ b/public/language/hu/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Visszaállította",
"moved-from-by": "Moved from %1 by",
"queued-by": "Hozzászólás jóváhagyásra bejegyezve →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Kattints ide a beszélgetés utolsó hozzászólására ugráshoz.",
"flag-post": "Jelöld meg ezt a bejegyzést",
"flag-user": "Jelöld meg ezt a felhasználót",
diff --git a/public/language/id/admin/settings/post.json b/public/language/id/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/id/admin/settings/post.json
+++ b/public/language/id/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/id/topic.json b/public/language/id/topic.json
index 69e2ddebbe..700abd5285 100644
--- a/public/language/id/topic.json
+++ b/public/language/id/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Klik di sini untuk kembali ke posting yang terakhir kali dibaca pada topik ini.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/it/admin/settings/post.json b/public/language/it/admin/settings/post.json
index fa1b9066dc..aaecd61292 100644
--- a/public/language/it/admin/settings/post.json
+++ b/public/language/it/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Mostra la scheda \"Aiuto\"",
"composer.enable-plugin-help": "Consenti ai plug-in di aggiungere contenuti alla scheda Guida",
"composer.custom-help": "Testo di aiuto personalizzato",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "Monitoraggio IP",
"ip-tracking.each-post": "Traccia l'indirizzo IP per ogni post",
"enable-post-history": "Abilita Cronologia post"
diff --git a/public/language/it/topic.json b/public/language/it/topic.json
index 886e8acd7c..5d695f9a47 100644
--- a/public/language/it/topic.json
+++ b/public/language/it/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Ripristinato da",
"moved-from-by": "Spostato da %1 da",
"queued-by": "Post in coda per l'approvazione →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Clicca qui per tornare all'ultimo post letto in questa discussione.",
"flag-post": "Segnala questo post",
"flag-user": "Segnala questo utente",
diff --git a/public/language/ja/admin/settings/post.json b/public/language/ja/admin/settings/post.json
index 09cfa068b9..43cd02324a 100644
--- a/public/language/ja/admin/settings/post.json
+++ b/public/language/ja/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "「ヘルプ」タグを表示",
"composer.enable-plugin-help": "プラグインがヘルプタブにコンテンツを追加できるようにする",
"composer.custom-help": "カスタムヘルプテキスト",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IPトラッキング",
"ip-tracking.each-post": "各投稿のトラックIPアドレス",
"enable-post-history": "Enable Post History"
diff --git a/public/language/ja/topic.json b/public/language/ja/topic.json
index 108e6e56ec..21750ccff3 100644
--- a/public/language/ja/topic.json
+++ b/public/language/ja/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "ここをクリックすると、このスレッドの最後に読んでいた投稿へ移動します。",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/ko/admin/settings/post.json b/public/language/ko/admin/settings/post.json
index 3ca69a289f..475c087504 100644
--- a/public/language/ko/admin/settings/post.json
+++ b/public/language/ko/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "\"도움말\" 탭 표시",
"composer.enable-plugin-help": "플러그인의 도움말 탭 내용 추가 허용",
"composer.custom-help": "사용자 정의 \"도움말\" 텍스트",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP 추적",
"ip-tracking.each-post": "모든 포스트 IP 추적",
"enable-post-history": "게시글 편집 기록 활성화"
diff --git a/public/language/ko/topic.json b/public/language/ko/topic.json
index 6dce045ed6..7b9c6331d4 100644
--- a/public/language/ko/topic.json
+++ b/public/language/ko/topic.json
@@ -47,6 +47,7 @@
"restored-by": "복원한 사용자:",
"moved-from-by": "Moved from %1 by",
"queued-by": "게시 승인 대기 중 →",
+ "backlink": "Referenced by",
"bookmark_instructions": "이 쓰레드에서 읽은 마지막 포스트로 이동하려면 여기를 클릭 하세요.",
"flag-post": "해당 포스트 신고",
"flag-user": "해당 유저 신고",
diff --git a/public/language/lt/admin/settings/post.json b/public/language/lt/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/lt/admin/settings/post.json
+++ b/public/language/lt/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/lt/topic.json b/public/language/lt/topic.json
index f27d966669..731eabcbcb 100644
--- a/public/language/lt/topic.json
+++ b/public/language/lt/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Click here to return to the last read post in this thread.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/lv/admin/settings/post.json b/public/language/lv/admin/settings/post.json
index d38fda1644..51c48dc131 100644
--- a/public/language/lv/admin/settings/post.json
+++ b/public/language/lv/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Rādīt \"palīdzība\" cilni",
"composer.enable-plugin-help": "Atļaut spraudņiem pievienot saturu palīdzības cilnei",
"composer.custom-help": "Pielāgotais palīdzības teksts",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP adrešu pierakstīšana",
"ip-tracking.each-post": "Pierakstīt katra raksta IP adresi",
"enable-post-history": "Iespējot rakstu vēsturi"
diff --git a/public/language/lv/topic.json b/public/language/lv/topic.json
index fbc2f52c19..958840aa41 100644
--- a/public/language/lv/topic.json
+++ b/public/language/lv/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Noklikšķināt, lai atgrieztos pēdējā lasītā rakstā šajā pavedienā.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/ms/admin/settings/post.json b/public/language/ms/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/ms/admin/settings/post.json
+++ b/public/language/ms/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/ms/topic.json b/public/language/ms/topic.json
index 69e7271d7d..407624794f 100644
--- a/public/language/ms/topic.json
+++ b/public/language/ms/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Click here to return to the last read post in this thread.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/nb/admin/settings/post.json b/public/language/nb/admin/settings/post.json
index f2b9a5e674..30a0e25fed 100644
--- a/public/language/nb/admin/settings/post.json
+++ b/public/language/nb/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/nb/topic.json b/public/language/nb/topic.json
index 877290e4ff..83ca054214 100644
--- a/public/language/nb/topic.json
+++ b/public/language/nb/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Gjenopprettet av",
"moved-from-by": "Moved from %1 by",
"queued-by": "Innlegg i kø for godkjenning & rarr;",
+ "backlink": "Referenced by",
"bookmark_instructions": "Klikk her for å gå tilbake til det siste innlegget i denne tråden.",
"flag-post": "Flagg denne posten",
"flag-user": "Flagg denne brukeren",
diff --git a/public/language/nl/admin/settings/post.json b/public/language/nl/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/nl/admin/settings/post.json
+++ b/public/language/nl/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/nl/topic.json b/public/language/nl/topic.json
index 460cb990c6..d323b9250e 100644
--- a/public/language/nl/topic.json
+++ b/public/language/nl/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Klik hier om terug te keren naar de laatst gelezen post in deze thread.",
"flag-post": "Rapporteer dit bericht",
"flag-user": "Rapporteer deze gebruiker",
diff --git a/public/language/pl/admin/settings/post.json b/public/language/pl/admin/settings/post.json
index 4fc718bd4c..7659b24546 100644
--- a/public/language/pl/admin/settings/post.json
+++ b/public/language/pl/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Pokazuj zakładkę „Pomoc”",
"composer.enable-plugin-help": "Zezwalaj wtyczkom na dodawanie zawartości do zakładki pomocy",
"composer.custom-help": "Własny tekst pomocy",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "Śledzenie IP",
"ip-tracking.each-post": "Śledź adres IP dla każdego postu",
"enable-post-history": "Włącz historię wpisu"
diff --git a/public/language/pl/topic.json b/public/language/pl/topic.json
index ec4bf2ca62..a5232eb3fe 100644
--- a/public/language/pl/topic.json
+++ b/public/language/pl/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Kliknij tutaj, by powrócić do ostatniego przeczytanego postu w tym temacie.",
"flag-post": "Zgłoś ten post",
"flag-user": "Zgłoś tego użytkownika",
diff --git a/public/language/pt-BR/admin/settings/post.json b/public/language/pt-BR/admin/settings/post.json
index 764ec57c0a..6bfc361519 100644
--- a/public/language/pt-BR/admin/settings/post.json
+++ b/public/language/pt-BR/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Mostrar aba \"Ajuda\"",
"composer.enable-plugin-help": "Permitir plugins de adicionar conteúdo à aba ajuda",
"composer.custom-help": "Texto de Ajuda Personalizado",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "Rastreamento de IP",
"ip-tracking.each-post": "Rastrear Endereço IP para cada post",
"enable-post-history": "Ativar o Histórico de Postagem"
diff --git a/public/language/pt-BR/topic.json b/public/language/pt-BR/topic.json
index dc1ac1ba25..7af51142e4 100644
--- a/public/language/pt-BR/topic.json
+++ b/public/language/pt-BR/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Recuperado por",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post aguardando aprovação →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Clique aqui para retornar ao último post lido neste tópico.",
"flag-post": "Marque este post",
"flag-user": "Marque este usuário",
diff --git a/public/language/pt-PT/admin/settings/post.json b/public/language/pt-PT/admin/settings/post.json
index 44ff5a2c1d..7e04a1cf14 100644
--- a/public/language/pt-PT/admin/settings/post.json
+++ b/public/language/pt-PT/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Mostrar separador \"Ajuda\"",
"composer.enable-plugin-help": "Permitir aos plugins adicionarem conteúdo ao separador de ajuda",
"composer.custom-help": "Texto de ajuda personalizado",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Ativar histórico de publicações"
diff --git a/public/language/pt-PT/topic.json b/public/language/pt-PT/topic.json
index 5087f71f28..65aa9a3bf2 100644
--- a/public/language/pt-PT/topic.json
+++ b/public/language/pt-PT/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Carrega aqui para voltares à última publicação lide assunto.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/ro/admin/settings/post.json b/public/language/ro/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/ro/admin/settings/post.json
+++ b/public/language/ro/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/ro/topic.json b/public/language/ro/topic.json
index 79968f2238..e418c2667c 100644
--- a/public/language/ro/topic.json
+++ b/public/language/ro/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Click here to return to the last read post in this thread.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/ru/admin/settings/post.json b/public/language/ru/admin/settings/post.json
index 4c6345eb37..86f7ee90a0 100644
--- a/public/language/ru/admin/settings/post.json
+++ b/public/language/ru/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Показывать вкладку с подсказками",
"composer.enable-plugin-help": "Разрешить плагинам добавлять подсказки на вкладку",
"composer.custom-help": "Пользовательский текст для вкладки с подсказками",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "Отслеживание IP",
"ip-tracking.each-post": "Отслеживать IP для каждого сообщения",
"enable-post-history": "Включить историю правок"
diff --git a/public/language/ru/topic.json b/public/language/ru/topic.json
index 5259b3883e..ab3da55d0d 100644
--- a/public/language/ru/topic.json
+++ b/public/language/ru/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Восстановлено",
"moved-from-by": "Moved from %1 by",
"queued-by": "Сообщение поставлено в очередь на утверждение;",
+ "backlink": "Referenced by",
"bookmark_instructions": "Нажмите здесь, чтобы вернуться к последнему прочитанному сообщению в этой теме.",
"flag-post": "Пожаловаться на это сообщение",
"flag-user": "Пожаловаться на этого пользователя",
diff --git a/public/language/rw/admin/settings/post.json b/public/language/rw/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/rw/admin/settings/post.json
+++ b/public/language/rw/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/rw/topic.json b/public/language/rw/topic.json
index 5d5ca82011..6de704a7b1 100644
--- a/public/language/rw/topic.json
+++ b/public/language/rw/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Click here to return to the last read post in this thread.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/sc/admin/settings/post.json b/public/language/sc/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/sc/admin/settings/post.json
+++ b/public/language/sc/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/sc/topic.json b/public/language/sc/topic.json
index f409e39538..4fdfd25116 100644
--- a/public/language/sc/topic.json
+++ b/public/language/sc/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Click here to return to the last read post in this thread.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/sk/admin/settings/post.json b/public/language/sk/admin/settings/post.json
index a99c0684e0..8ebf0cc3d1 100644
--- a/public/language/sk/admin/settings/post.json
+++ b/public/language/sk/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Zobraziť záložku „Nápoveda”",
"composer.enable-plugin-help": "Povoliť zásuvné moduly pre pridanie obsahu do záložky nápovedy",
"composer.custom-help": "Používateľský text nápovedy",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "Sledovanie IP adresy",
"ip-tracking.each-post": "Sledovať IP adresu pri každom príspevku",
"enable-post-history": "Povoliť históriu príspevkov"
diff --git a/public/language/sk/topic.json b/public/language/sk/topic.json
index bed5926c8a..9f742f4009 100644
--- a/public/language/sk/topic.json
+++ b/public/language/sk/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Kliknite sem pre návrat k poslednému prečítanému príspevku vo vlákne.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/sl/admin/settings/post.json b/public/language/sl/admin/settings/post.json
index 28b28bde7e..c12fe04617 100644
--- a/public/language/sl/admin/settings/post.json
+++ b/public/language/sl/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Prikaži zavihek \"Pomoč\"",
"composer.enable-plugin-help": "Dovoli vtičnikom dodajanje vsebine na zavihek za pomoč",
"composer.custom-help": "Besedilo pomoči po meri",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP sledenje",
"ip-tracking.each-post": "Sledi IP naslov za vsako objavo",
"enable-post-history": "Omogoči zgodovino objav"
diff --git a/public/language/sl/flags.json b/public/language/sl/flags.json
index 5bd46b6b1d..be4fdfcc04 100644
--- a/public/language/sl/flags.json
+++ b/public/language/sl/flags.json
@@ -5,7 +5,7 @@
"no-flags": "Hooray! No flags found.",
"assignee": "Assignee",
"update": "Update",
- "updated": "Updated",
+ "updated": "Posodobljeno",
"resolved": "Resolved",
"target-purged": "The content this flag referred to has been purged and is no longer available.",
@@ -13,61 +13,61 @@
"quick-filters": "Quick Filters",
"filter-active": "There are one or more filters active in this list of flags",
"filter-reset": "Remove Filters",
- "filters": "Filter Options",
+ "filters": "Možnosti filtra",
"filter-reporterId": "Reporter UID",
"filter-targetUid": "Flagged UID",
"filter-type": "Flag Type",
"filter-type-all": "All Content",
- "filter-type-post": "Post",
- "filter-type-user": "User",
+ "filter-type-post": "Objava",
+ "filter-type-user": "Uporabnik",
"filter-state": "State",
"filter-assignee": "Assignee UID",
- "filter-cid": "Category",
- "filter-quick-mine": "Assigned to me",
- "filter-cid-all": "All categories",
- "apply-filters": "Apply Filters",
- "more-filters": "More Filters",
- "fewer-filters": "Fewer Filters",
+ "filter-cid": "Kategorija",
+ "filter-quick-mine": "Dodeljeno meni",
+ "filter-cid-all": "Vse kategorije",
+ "apply-filters": "Uveljavi filtre",
+ "more-filters": "Več filtrov",
+ "fewer-filters": "Manj filtrov",
- "quick-actions": "Quick Actions",
+ "quick-actions": "Hitra dejanja",
"flagged-user": "Flagged User",
- "view-profile": "View Profile",
- "start-new-chat": "Start New Chat",
+ "view-profile": "Poglej profil",
+ "start-new-chat": "Začni nov klepet",
"go-to-target": "View Flag Target",
- "assign-to-me": "Assign To Me",
- "delete-post": "Delete Post",
+ "assign-to-me": "Dodeli meni",
+ "delete-post": "Izbriši objavo",
"purge-post": "Purge Post",
- "restore-post": "Restore Post",
+ "restore-post": "Obnovi objavo",
- "user-view": "View Profile",
- "user-edit": "Edit Profile",
+ "user-view": "Poglej profil",
+ "user-edit": "Uredi profil",
"notes": "Flag Notes",
- "add-note": "Add Note",
- "no-notes": "No shared notes.",
+ "add-note": "Dodaj opombo",
+ "no-notes": "Ni deljenih opomb.",
"delete-note-confirm": "Are you sure you want to delete this flag note?",
- "note-added": "Note Added",
- "note-deleted": "Note Deleted",
+ "note-added": "Opomba dodana",
+ "note-deleted": "Opomba izbrisana",
"history": "Account & Flag History",
"no-history": "No flag history.",
"state-all": "All states",
- "state-open": "New/Open",
+ "state-open": "Nov/Odpri",
"state-wip": "Work in Progress",
"state-resolved": "Resolved",
- "state-rejected": "Rejected",
- "no-assignee": "Not Assigned",
+ "state-rejected": "Zavrnjeno",
+ "no-assignee": "Ni dodeljeno",
- "sort": "Sort by",
+ "sort": "Razvrsti po",
"sort-newest": "Newest first",
"sort-oldest": "Oldest first",
"sort-reports": "Most reports",
"sort-all": "All flag types...",
"sort-posts-only": "Posts only...",
- "sort-downvotes": "Most downvotes",
- "sort-upvotes": "Most upvotes",
- "sort-replies": "Most replies",
+ "sort-downvotes": "Največ glasov proti",
+ "sort-upvotes": "Največ glasov za",
+ "sort-replies": "Največ odgovorov",
"modal-title": "Report Content",
"modal-body": "Please specify your reason for flagging %1 %2 for review. Alternatively, use one of the quick report buttons if applicable.",
diff --git a/public/language/sl/topic.json b/public/language/sl/topic.json
index 35ed423e4f..bfa42068c4 100644
--- a/public/language/sl/topic.json
+++ b/public/language/sl/topic.json
@@ -1,6 +1,6 @@
{
"topic": "Tema",
- "title": "Title",
+ "title": "Naslov",
"no_topics_found": "Ni najdenih tem!",
"no_posts_found": "Ni najdenih objav!",
"post_is_deleted": "Ta objava je izbrisana!",
@@ -12,41 +12,42 @@
"notify_me": "Bodi obveščen o novih odgovorih na to temo",
"quote": "Citiraj",
"reply": "Odgovori",
- "replies_to_this_post": "%1 Replies",
- "one_reply_to_this_post": "1 Reply",
- "last_reply_time": "Last reply",
+ "replies_to_this_post": "Št. odogvorov: %1",
+ "one_reply_to_this_post": "1 odgovor",
+ "last_reply_time": "Zadnji odgovor",
"reply-as-topic": "Odgovori s temo",
"guest-login-reply": "Prijavi se za odgovor",
"login-to-view": "🔒 Log in to view",
"edit": "Uredi",
"delete": "Izbriši",
- "delete-event": "Delete Event",
- "delete-event-confirm": "Are you sure you want to delete this event?",
+ "delete-event": "Izbriši dogodek",
+ "delete-event-confirm": "Ste prepričani, da želite izbrisati ta dogodek?",
"purge": "Očisti",
- "restore": "Razveljavi",
+ "restore": "Obnovi",
"move": "Premakni",
- "change-owner": "Change Owner",
+ "change-owner": "Spremeni lastnika",
"fork": "Razcepi",
"link": "Povezava",
"share": "Deli",
"tools": "Orodja",
"locked": "Zaklenjeno",
"pinned": "Pripeto",
- "pinned-with-expiry": "Pinned until %1",
+ "pinned-with-expiry": "Pripeto do %1",
"scheduled": "Scheduled",
"moved": "Premaknjeno",
"moved-from": "Moved from %1",
- "copy-ip": "Copy IP",
- "ban-ip": "Ban IP",
- "view-history": "Edit History",
- "locked-by": "Locked by",
- "unlocked-by": "Unlocked by",
- "pinned-by": "Pinned by",
- "unpinned-by": "Unpinned by",
- "deleted-by": "Deleted by",
- "restored-by": "Restored by",
+ "copy-ip": "Kopiraj IP",
+ "ban-ip": "Prepovej IP",
+ "view-history": "Uredi zgodovino",
+ "locked-by": "Zaklenil/a",
+ "unlocked-by": "Odklenil/a",
+ "pinned-by": "Pripel/a",
+ "unpinned-by": "Odpel/a",
+ "deleted-by": "Izbrisal/a",
+ "restored-by": "Povrnil/a",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Klikni tukaj za vrnitev na zadnje prebrano objavo v tej niti",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
@@ -82,8 +83,8 @@
"thread_tools.move": "Premakni temo",
"thread_tools.move-posts": "Premakni objave",
"thread_tools.move_all": "Premakni vse",
- "thread_tools.change_owner": "Change Owner",
- "thread_tools.select_category": "Select Category",
+ "thread_tools.change_owner": "Spremeni lastnika",
+ "thread_tools.select_category": "Izberi kategorijo",
"thread_tools.fork": "Razcepi temo",
"thread_tools.delete": "Izbriši temo",
"thread_tools.delete-posts": "Izbriši objave",
@@ -92,23 +93,23 @@
"thread_tools.restore_confirm": "Ste prepričani, da želite obnoviti to temo?",
"thread_tools.purge": "Očisti temo",
"thread_tools.purge_confirm": "Ste prepričani, da želite očistiti to temo?",
- "thread_tools.merge_topics": "Merge Topics",
- "thread_tools.merge": "Merge",
- "topic_move_success": "This topic will be moved to \"%1\" shortly. Click here to undo.",
- "topic_move_multiple_success": "These topics will be moved to \"%1\" shortly. Click here to undo.",
- "topic_move_all_success": "All topics will be moved to \"%1\" shortly. Click here to undo.",
- "topic_move_undone": "Topic move undone",
- "topic_move_posts_success": "Posts will be moved shortly. Click here to undo.",
- "topic_move_posts_undone": "Post move undone",
+ "thread_tools.merge_topics": "Združi teme",
+ "thread_tools.merge": "Združi",
+ "topic_move_success": "Ta tema bo kmalu premaknjena v \"%1\". Kliknite tukaj, če želite razveljaviti.",
+ "topic_move_multiple_success": "Te teme bodo kmalu premaknjene v \"%1\". Kliknite tukaj, če želite razveljaviti.",
+ "topic_move_all_success": "Vse teme bodo kmalu premaknjene v \"%1\". Kliknite tukaj, če želite razveljaviti.",
+ "topic_move_undone": "Premik teme razveljavljen",
+ "topic_move_posts_success": "Objave bodo kmalu premaknjene. Kliknite tukaj, če želite razveljaviti.",
+ "topic_move_posts_undone": "Premik objav razveljavljen",
"post_delete_confirm": "Ste prepričani, da želite izbrisati to objavo?",
- "post_restore_confirm": "Ste prepričani, da želite razveljaviti to objavo?",
+ "post_restore_confirm": "Ste prepričani, da želite obnoviti to objavo?",
"post_purge_confirm": "Ste prepričani, da želite očistiti to objavo?",
- "pin-modal-expiry": "Expiration Date",
+ "pin-modal-expiry": "Datum poteka veljavnosti",
"pin-modal-help": "You can optionally set an expiration date for the pinned topic(s) here. Alternatively, you can leave this field blank to have the topic stay pinned until it is manually unpinned.",
"load_categories": "Nalagam kategorije",
"confirm_move": "Premakni",
"confirm_fork": "Razcepi",
- "bookmark": "Bookmark",
+ "bookmark": "Zaznamek",
"bookmarks": "Zaznamki",
"bookmarks.has_no_bookmarks": "Zaznamovali še niste nobenih objav.",
"loading_more_posts": "Nalagam več objav",
@@ -117,23 +118,23 @@
"move_post": "Premakni objavo",
"post_moved": "Objava premaknjena!",
"fork_topic": "Razcepi temo",
- "enter-new-topic-title": "Enter new topic title",
+ "enter-new-topic-title": "Vnesite nov naslov teme",
"fork_topic_instruction": "Klikni na objavo, ki o želiš odcepiti",
"fork_no_pids": "Ni izbranih objav!",
- "no-posts-selected": "No posts selected!",
- "x-posts-selected": "%1 post(s) selected",
+ "no-posts-selected": "Ni izbranih objav!",
+ "x-posts-selected": "Izbranih objav: %1 ",
"x-posts-will-be-moved-to-y": "%1 post(s) will be moved to \"%2\"",
"fork_pid_count": "Izbranih objav: %1 ",
"fork_success": "Uspešno ste razcepili temo! Klikni tu za ogled te teme.",
"delete_posts_instruction": "Kliknite na teme, ki jih želite izbrisati/očistiti ",
- "merge_topics_instruction": "Click the topics you want to merge or search for them",
- "merge-topic-list-title": "List of topics to be merged",
- "merge-options": "Merge options",
- "merge-select-main-topic": "Select the main topic",
- "merge-new-title-for-topic": "New title for topic",
- "topic-id": "Topic ID",
- "move_posts_instruction": "Click the posts you want to move then enter a topic ID or go to the target topic",
- "change_owner_instruction": "Click the posts you want to assign to another user",
+ "merge_topics_instruction": "Kliknite teme, ki jih želite združiti, ali jih poiščite",
+ "merge-topic-list-title": "Seznam tem za združevanje",
+ "merge-options": "Možnosti združevanja",
+ "merge-select-main-topic": "Izberi glavno temo",
+ "merge-new-title-for-topic": "Nov naslov teme",
+ "topic-id": "ID teme",
+ "move_posts_instruction": "Kliknite objave, ki jih želite premakniti, nato vnesite ID teme ali pojdite na ciljno temo",
+ "change_owner_instruction": "Kliknite objave, ki jih želite dodeliti drugemu uporabniku",
"composer.title_placeholder": "Vpiši naslov teme...",
"composer.handle_placeholder": "Enter your name/handle here",
"composer.discard": "Zavrzi",
@@ -141,7 +142,7 @@
"composer.schedule": "Schedule",
"composer.replying_to": "Odgovor na %1",
"composer.new_topic": "Nova tema",
- "composer.editing": "Editing",
+ "composer.editing": "Urejanje",
"composer.uploading": "nalagam...",
"composer.thumb_url_label": "Prilepite URL sličice teme",
"composer.thumb_title": "Dodajte sličico tej temi",
@@ -158,25 +159,25 @@
"newest_to_oldest": "Od novejšega do starejšega",
"most_votes": "Največ glasov",
"most_posts": "Največ objav",
- "most_views": "Most Views",
+ "most_views": "Največ ogledov",
"stale.title": "Raje ustvari novo temo?",
"stale.warning": "Tema na katero odgovarjaš je precej stara. A ne bi raje ustvaril novo temo namesto te, z sklicem na to v tvojem odgovoru?",
"stale.create": "Ustvari novo temo",
"stale.reply_anyway": "Vseeno odgovori na to temo",
"link_back": "Odg: [%1](%2)",
- "diffs.title": "Post Edit History",
+ "diffs.title": "Zgodovina urejanja objav",
"diffs.description": "This post has %1 revisions. Click one of the revisions below to see the post content at that point in time.",
"diffs.no-revisions-description": "This post has %1 revisions.",
- "diffs.current-revision": "current revision",
- "diffs.original-revision": "original revision",
- "diffs.restore": "Restore this revision",
- "diffs.restore-description": "A new revision will be appended to this post's edit history after restoring.",
- "diffs.post-restored": "Post successfully restored to earlier revision",
- "diffs.delete": "Delete this revision",
- "diffs.deleted": "Revision deleted",
+ "diffs.current-revision": "trenutna različica",
+ "diffs.original-revision": "izvirna različica",
+ "diffs.restore": "Obnovi to različico",
+ "diffs.restore-description": "Po obnovitvi bo v zgodovino urejanj te objave dodana nova različica.",
+ "diffs.post-restored": "Objava je bila uspešno obnovljena na prejšnjo različico",
+ "diffs.delete": "Izbriši to različico",
+ "diffs.deleted": "Različica izbrisana",
"timeago_later": "%1 later",
"timeago_earlier": "%1 earlier",
- "first-post": "First post",
- "last-post": "Last post",
- "post-quick-reply": "Post quick reply"
+ "first-post": "Prva objava",
+ "last-post": "Zadnja obava",
+ "post-quick-reply": "Objavi hitri odgovor"
}
\ No newline at end of file
diff --git a/public/language/sr/admin/settings/post.json b/public/language/sr/admin/settings/post.json
index f3ae9fccb5..c1a2a7003b 100644
--- a/public/language/sr/admin/settings/post.json
+++ b/public/language/sr/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Prikaži tab \"Pomoć\"",
"composer.enable-plugin-help": "Dozvoli plugin-ovima da dodaju sadržaj na tab-u \"pomoć\"",
"composer.custom-help": "Prilagođen tekst za pomoć",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "Praćenje IP adrese",
"ip-tracking.each-post": "Prati IP Adresu za svaki post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/sr/topic.json b/public/language/sr/topic.json
index 1c3ed23132..798f6d2dca 100644
--- a/public/language/sr/topic.json
+++ b/public/language/sr/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Вратио",
"moved-from-by": "Moved from %1 by",
"queued-by": "Порука је на чекању за одобрење →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Кликните овде за повратак на последњу прочитану поруку у овој теми.",
"flag-post": "Обележи заставицом поруку",
"flag-user": "Обележи заставицом корисника",
diff --git a/public/language/sv/admin/settings/post.json b/public/language/sv/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/sv/admin/settings/post.json
+++ b/public/language/sv/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/sv/topic.json b/public/language/sv/topic.json
index a242da20de..f88cf9d472 100644
--- a/public/language/sv/topic.json
+++ b/public/language/sv/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Klicka här för att återgå till senast lästa inlägg i detta ämne.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/th/admin/settings/post.json b/public/language/th/admin/settings/post.json
index 27493aafbd..00baa56fc1 100644
--- a/public/language/th/admin/settings/post.json
+++ b/public/language/th/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Show \"Help\" tab",
"composer.enable-plugin-help": "Allow plugins to add content to the help tab",
"composer.custom-help": "Custom Help Text",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP Tracking",
"ip-tracking.each-post": "Track IP Address for each post",
"enable-post-history": "Enable Post History"
diff --git a/public/language/th/topic.json b/public/language/th/topic.json
index 5a49d5e8d0..5af3eb6a83 100644
--- a/public/language/th/topic.json
+++ b/public/language/th/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "คลิกที่นี่เพื่อกลับไปยังโพสต์ล่าสุดในหัวข้อนี้",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/tr/admin/settings/post.json b/public/language/tr/admin/settings/post.json
index 8122ec2fd1..dee17e7dc2 100644
--- a/public/language/tr/admin/settings/post.json
+++ b/public/language/tr/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "\"Yardım\" sekmesini göster",
"composer.enable-plugin-help": "Eklentilerin yardım sekmesine içerik eklemesine izin ver",
"composer.custom-help": "Özel Yardım Metni",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP İzleme",
"ip-tracking.each-post": "Her ileti için IP Adresini takip et",
"enable-post-history": "Gönderi Geçmişini Etkinleştir"
diff --git a/public/language/tr/topic.json b/public/language/tr/topic.json
index 305cb09eba..172e29cdbb 100644
--- a/public/language/tr/topic.json
+++ b/public/language/tr/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Tekrar Yüklendi",
"moved-from-by": "Moved from %1 by",
"queued-by": "İleti onay için sıraya alındı →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Bu konuda en son kaldığın yere dönmek için tıkla.",
"flag-post": "Bu iletiyi şikayet et",
"flag-user": "Bu kullanıcıyı şikayet et",
diff --git a/public/language/uk/admin/settings/post.json b/public/language/uk/admin/settings/post.json
index f59375f68f..5219e9aded 100644
--- a/public/language/uk/admin/settings/post.json
+++ b/public/language/uk/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Показувати вкладку \"Довідка\"",
"composer.enable-plugin-help": "Дозволити плагінам додавати зміст довідки",
"composer.custom-help": "Користувацький текст довідки",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "Відстеження IP",
"ip-tracking.each-post": "Відстежувати IP адреси для кожного посту",
"enable-post-history": "Увімкнути Історію Постів"
diff --git a/public/language/uk/topic.json b/public/language/uk/topic.json
index 9cbd7655ca..732286d2ce 100644
--- a/public/language/uk/topic.json
+++ b/public/language/uk/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Натисніть тут, щоб повернутися до останнього прочитаного посту у цій темі.",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
diff --git a/public/language/vi/admin/settings/post.json b/public/language/vi/admin/settings/post.json
index 1a9a24f454..e35c4647a4 100644
--- a/public/language/vi/admin/settings/post.json
+++ b/public/language/vi/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "Hiển thị tab \"Trợ giúp\"",
"composer.enable-plugin-help": "Cho phép các plugin thêm nội dung vào tab trợ giúp",
"composer.custom-help": "Văn Bản Trợ Giúp Tùy Chỉnh",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "Theo dõi IP",
"ip-tracking.each-post": "Theo dõi Địa chỉ IP mỗi bài đăng",
"enable-post-history": "Bật Lịch Sử Bài Đăng"
diff --git a/public/language/vi/topic.json b/public/language/vi/topic.json
index 56f543a1a1..d714766514 100644
--- a/public/language/vi/topic.json
+++ b/public/language/vi/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Được khôi phục bởi",
"moved-from-by": "Đã chuyển từ %1 bởi",
"queued-by": "Bài đăng được xếp hàng chờ duyệt →",
+ "backlink": "Referenced by",
"bookmark_instructions": "Nhấn vào đây để trở lại bài viết đã đọc cuối cùng trong chủ đề này.",
"flag-post": "Gắn cờ bài đăng này",
"flag-user": "Gắn cờ người dùng này",
diff --git a/public/language/zh-CN/admin/settings/post.json b/public/language/zh-CN/admin/settings/post.json
index c1b58d8595..7dc59bb94b 100644
--- a/public/language/zh-CN/admin/settings/post.json
+++ b/public/language/zh-CN/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "显示“帮助”选项卡",
"composer.enable-plugin-help": "允许插件添加内容到帮助选项卡",
"composer.custom-help": "自定义帮助文本",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP 跟踪",
"ip-tracking.each-post": "跟踪每个帖子的 IP 地址",
"enable-post-history": "启用回复历史"
diff --git a/public/language/zh-CN/topic.json b/public/language/zh-CN/topic.json
index 8f0bfb0c2e..20188e117a 100644
--- a/public/language/zh-CN/topic.json
+++ b/public/language/zh-CN/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "点击阅读本主题帖中的最新回复",
"flag-post": "举报此帖",
"flag-user": "举报此用户",
diff --git a/public/language/zh-TW/admin/settings/post.json b/public/language/zh-TW/admin/settings/post.json
index eccfaf3af7..607923bae4 100644
--- a/public/language/zh-TW/admin/settings/post.json
+++ b/public/language/zh-TW/admin/settings/post.json
@@ -56,6 +56,9 @@
"composer.show-help": "顯示“幫助”選項卡",
"composer.enable-plugin-help": "允許外掛添加內容到幫助選項卡",
"composer.custom-help": "自訂幫助文字",
+ "backlinks": "Backlinks",
+ "backlinks.enabled": "Enable topic backlinks",
+ "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
"ip-tracking": "IP 跟蹤",
"ip-tracking.each-post": "跟蹤每個貼文的 IP 地址",
"enable-post-history": "啟用回覆歷史"
diff --git a/public/language/zh-TW/topic.json b/public/language/zh-TW/topic.json
index 5a220a0af8..4bfd341313 100644
--- a/public/language/zh-TW/topic.json
+++ b/public/language/zh-TW/topic.json
@@ -47,6 +47,7 @@
"restored-by": "Restored by",
"moved-from-by": "Moved from %1 by",
"queued-by": "Post queued for approval →",
+ "backlink": "Referenced by",
"bookmark_instructions": "點擊閱讀本主題貼文中的最新回覆",
"flag-post": "Flag this post",
"flag-user": "Flag this user",
From 7d1c7e0a7b05ef2eb52acf8dafb24b945b1b62c7 Mon Sep 17 00:00:00 2001
From: "Misty (Bot)"
Date: Fri, 1 Oct 2021 09:06:21 +0000
Subject: [PATCH 40/62] Latest translations and fallbacks
---
public/language/vi/admin/settings/post.json | 6 +++---
public/language/vi/topic.json | 4 ++--
2 files changed, 5 insertions(+), 5 deletions(-)
diff --git a/public/language/vi/admin/settings/post.json b/public/language/vi/admin/settings/post.json
index e35c4647a4..1db0f903f1 100644
--- a/public/language/vi/admin/settings/post.json
+++ b/public/language/vi/admin/settings/post.json
@@ -56,9 +56,9 @@
"composer.show-help": "Hiển thị tab \"Trợ giúp\"",
"composer.enable-plugin-help": "Cho phép các plugin thêm nội dung vào tab trợ giúp",
"composer.custom-help": "Văn Bản Trợ Giúp Tùy Chỉnh",
- "backlinks": "Backlinks",
- "backlinks.enabled": "Enable topic backlinks",
- "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
+ "backlinks": "Liên kết ngược",
+ "backlinks.enabled": "Bật liên kết ngược chủ đề",
+ "backlinks.help": "Nếu một bài đăng tham chiếu đến chủ đề khác, một liên kết quay lại bài đăng sẽ được chèn vào chủ đề được tham chiếu tại thời điểm đó.",
"ip-tracking": "Theo dõi IP",
"ip-tracking.each-post": "Theo dõi Địa chỉ IP mỗi bài đăng",
"enable-post-history": "Bật Lịch Sử Bài Đăng"
diff --git a/public/language/vi/topic.json b/public/language/vi/topic.json
index d714766514..04c1344637 100644
--- a/public/language/vi/topic.json
+++ b/public/language/vi/topic.json
@@ -47,7 +47,7 @@
"restored-by": "Được khôi phục bởi",
"moved-from-by": "Đã chuyển từ %1 bởi",
"queued-by": "Bài đăng được xếp hàng chờ duyệt →",
- "backlink": "Referenced by",
+ "backlink": "Được giới thiệu bởi",
"bookmark_instructions": "Nhấn vào đây để trở lại bài viết đã đọc cuối cùng trong chủ đề này.",
"flag-post": "Gắn cờ bài đăng này",
"flag-user": "Gắn cờ người dùng này",
@@ -159,7 +159,7 @@
"newest_to_oldest": "Mới đến cũ",
"most_votes": "Nhiều Bình Chọn",
"most_posts": "Nhiều Bài Đăng",
- "most_views": "Most Views",
+ "most_views": "Xem Nhiều",
"stale.title": "Tạo chủ đề mới thay thế?",
"stale.warning": "Chủ đề bạn đang trả lời đã khá cũ. Bạn có muốn tạo chủ đề mới, và liên kết với chủ đề hiện tại trong bài viết trả lời của bạn?",
"stale.create": "Tạo chủ đề mới",
From ea04aeded4064d79ab3599c77b39056afc612f0a Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Bar=C4=B1=C5=9F=20Soner=20U=C5=9Fakl=C4=B1?=
Date: Fri, 1 Oct 2021 15:24:19 -0400
Subject: [PATCH 41/62] perf: convert promise.all to single query (#9851)
---
src/database/postgres/hash.js | 81 ++++++++++++++++++++++++++---------
test/database/hash.js | 7 +++
2 files changed, 67 insertions(+), 21 deletions(-)
diff --git a/src/database/postgres/hash.js b/src/database/postgres/hash.js
index 04b38713c2..015154aa42 100644
--- a/src/database/postgres/hash.js
+++ b/src/database/postgres/hash.js
@@ -16,7 +16,20 @@ module.exports = function (module) {
}
await module.transaction(async (client) => {
const dataString = JSON.stringify(data);
- async function setOne(key) {
+
+ if (Array.isArray(key)) {
+ await helpers.ensureLegacyObjectsType(client, key, 'hash');
+ await client.query({
+ name: 'setObjectKeys',
+ text: `
+ INSERT INTO "legacy_hash" ("_key", "data")
+ SELECT k, $2::TEXT::JSONB
+ FROM UNNEST($1::TEXT[]) vs(k)
+ ON CONFLICT ("_key")
+ DO UPDATE SET "data" = "legacy_hash"."data" || $2::TEXT::JSONB`,
+ values: [key, dataString],
+ });
+ } else {
await helpers.ensureLegacyObjectType(client, key, 'hash');
await client.query({
name: 'setObject',
@@ -28,11 +41,6 @@ module.exports = function (module) {
values: [key, dataString],
});
}
- if (Array.isArray(key)) {
- await Promise.all(key.map(k => setOne(k)));
- } else {
- await setOne(key);
- }
});
};
@@ -40,8 +48,36 @@ module.exports = function (module) {
if (!keys.length || !data.length) {
return;
}
- // TODO: single query?
- await Promise.all(keys.map((k, i) => module.setObject(k, data[i])));
+ await module.transaction(async (client) => {
+ keys = keys.slice();
+ data = data.filter((d, i) => {
+ if (d.hasOwnProperty('')) {
+ delete d[''];
+ }
+ const keep = !!Object.keys(d).length;
+ if (!keep) {
+ keys.splice(i, 1);
+ }
+ return keep;
+ });
+
+ if (!keys.length) {
+ return;
+ }
+
+ await helpers.ensureLegacyObjectsType(client, keys, 'hash');
+ const dataStrings = data.map(JSON.stringify);
+ await client.query({
+ name: 'setObjectBulk',
+ text: `
+ INSERT INTO "legacy_hash" ("_key", "data")
+ SELECT k, d
+ FROM UNNEST($1::TEXT[], $2::TEXT::JSONB[]) vs(k, d)
+ ON CONFLICT ("_key")
+ DO UPDATE SET "data" = "legacy_hash"."data" || EXCLUDED.data`,
+ values: [keys, dataStrings],
+ });
+ });
};
module.setObjectField = async function (key, field, value) {
@@ -51,7 +87,9 @@ module.exports = function (module) {
await module.transaction(async (client) => {
const valueString = JSON.stringify(value);
- async function setOne(key) {
+ if (Array.isArray(key)) {
+ await module.setObject(key, { [field]: value });
+ } else {
await helpers.ensureLegacyObjectType(client, key, 'hash');
await client.query({
name: 'setObjectField',
@@ -63,12 +101,6 @@ module.exports = function (module) {
values: [key, field, valueString],
});
}
-
- if (Array.isArray(key)) {
- await Promise.all(key.map(k => setOne(k)));
- } else {
- await setOne(key);
- }
});
};
@@ -269,7 +301,19 @@ SELECT (h."data" ? $2::TEXT AND h."data"->>$2::TEXT IS NOT NULL) b
if (!key || (Array.isArray(key) && !key.length) || !Array.isArray(fields) || !fields.length) {
return;
}
- async function delKey(key, fields) {
+
+ if (Array.isArray(key)) {
+ await module.pool.query({
+ name: 'deleteObjectFieldsKeys',
+ text: `
+ UPDATE "legacy_hash"
+ SET "data" = COALESCE((SELECT jsonb_object_agg("key", "value")
+ FROM jsonb_each("data")
+ WHERE "key" <> ALL ($2::TEXT[])), '{}')
+ WHERE "_key" = ANY($1::TEXT[])`,
+ values: [key, fields],
+ });
+ } else {
await module.pool.query({
name: 'deleteObjectFields',
text: `
@@ -281,11 +325,6 @@ SELECT (h."data" ? $2::TEXT AND h."data"->>$2::TEXT IS NOT NULL) b
values: [key, fields],
});
}
- if (Array.isArray(key)) {
- await Promise.all(key.map(k => delKey(k, fields)));
- } else {
- await delKey(key, fields);
- }
};
module.incrObjectField = async function (key, field) {
diff --git a/test/database/hash.js b/test/database/hash.js
index 650afae8bf..e2e2ee7364 100644
--- a/test/database/hash.js
+++ b/test/database/hash.js
@@ -90,6 +90,13 @@ describe('Hash methods', () => {
assert.deepStrictEqual(result, [{ foo: '1' }, null]);
});
+ it('should update existing object on second call', async () => {
+ await db.setObjectBulk(['bulkKey3.5'], [{ foo: '1' }]);
+ await db.setObjectBulk(['bulkKey3.5'], [{ baz: '2' }]);
+ const result = await db.getObject('bulkKey3.5');
+ assert.deepStrictEqual(result, { foo: '1', baz: '2' });
+ });
+
it('should not error if object is empty', async () => {
const keys = ['bulkKey5'];
const data = [{ }];
From e6a17a6349586561fac4cbf427c4c2640d0ed8ff Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Bar=C4=B1=C5=9F=20Soner=20U=C5=9Fakl=C4=B1?=
Date: Fri, 1 Oct 2021 19:36:42 -0400
Subject: [PATCH 42/62] Psql multikey (#9852)
* perf: convert promise.all to single query
* perf: single query for removeBulk
* perf: list
---
src/database/postgres/list.js | 63 +++++++++-----------------
src/database/postgres/sorted/remove.js | 34 ++++++--------
test/database/sorted.js | 23 ++++++++++
3 files changed, 60 insertions(+), 60 deletions(-)
diff --git a/src/database/postgres/list.js b/src/database/postgres/list.js
index 4fb4fc40f1..885adb3825 100644
--- a/src/database/postgres/list.js
+++ b/src/database/postgres/list.js
@@ -9,28 +9,18 @@ module.exports = function (module) {
}
await module.transaction(async (client) => {
- async function doPrepend(value) {
- await client.query({
- name: 'listPrepend',
- text: `
- INSERT INTO "legacy_list" ("_key", "array")
- VALUES ($1::TEXT, ARRAY[$2::TEXT])
- ON CONFLICT ("_key")
- DO UPDATE SET "array" = ARRAY[$2::TEXT] || "legacy_list"."array"`,
- values: [key, value],
- });
- }
-
await helpers.ensureLegacyObjectType(client, key, 'list');
- if (Array.isArray(value)) {
- // TODO: perf make single query
- for (const v of value) {
- // eslint-disable-next-line
- await doPrepend(v);
- }
- return;
- }
- await doPrepend(value);
+ value = Array.isArray(value) ? value : [value];
+ value.reverse();
+ await client.query({
+ name: 'listPrependValues',
+ text: `
+INSERT INTO "legacy_list" ("_key", "array")
+VALUES ($1::TEXT, $2::TEXT[])
+ON CONFLICT ("_key")
+DO UPDATE SET "array" = EXCLUDED.array || "legacy_list"."array"`,
+ values: [key, value],
+ });
});
};
@@ -39,27 +29,18 @@ module.exports = function (module) {
return;
}
await module.transaction(async (client) => {
- async function doAppend(value) {
- await client.query({
- name: 'listAppend',
- text: `
- INSERT INTO "legacy_list" ("_key", "array")
- VALUES ($1::TEXT, ARRAY[$2::TEXT])
- ON CONFLICT ("_key")
- DO UPDATE SET "array" = "legacy_list"."array" || ARRAY[$2::TEXT]`,
- values: [key, value],
- });
- }
+ value = Array.isArray(value) ? value : [value];
+
await helpers.ensureLegacyObjectType(client, key, 'list');
- if (Array.isArray(value)) {
- // TODO: perf make single query
- for (const v of value) {
- // eslint-disable-next-line
- await doAppend(v);
- }
- return;
- }
- await doAppend(value);
+ await client.query({
+ name: 'listAppend',
+ text: `
+INSERT INTO "legacy_list" ("_key", "array")
+VALUES ($1::TEXT, $2::TEXT[])
+ON CONFLICT ("_key")
+DO UPDATE SET "array" = "legacy_list"."array" || EXCLUDED.array`,
+ values: [key, value],
+ });
});
};
diff --git a/src/database/postgres/sorted/remove.js b/src/database/postgres/sorted/remove.js
index 54bed38505..2b90dd8bc2 100644
--- a/src/database/postgres/sorted/remove.js
+++ b/src/database/postgres/sorted/remove.js
@@ -71,25 +71,21 @@ DELETE FROM "legacy_zset"
};
module.sortedSetRemoveBulk = async function (data) {
- // const keys = [];
- // const values = [];
-
- // data.forEach(function (item) {
- // keys.push(item[0]);
- // values.push(item[1]);
- // });
-
- const promises = data.map(item => module.sortedSetRemove(item[0], item[1]));
- await Promise.all(promises);
+ if (!Array.isArray(data) || !data.length) {
+ return;
+ }
+ const keys = data.map(d => d[0]);
+ const values = data.map(d => d[1]);
- // TODO
- // await query({
- // name: 'sortedSetRemoveBulk',
- // text: `
- // DELETE FROM "legacy_zset"
- // SELECT k, v
- // FROM UNNEST($1::TEXT[], $2::TEXT[]) vs(k, v)`,
- // values: [keys, values],
- // });
+ await module.pool.query({
+ name: 'sortedSetRemoveBulk',
+ text: `
+ DELETE FROM "legacy_zset"
+ WHERE (_key, value) IN (
+ SELECT k, v
+ FROM UNNEST($1::TEXT[], $2::TEXT[]) vs(k, v)
+ )`,
+ values: [keys, values],
+ });
};
};
diff --git a/test/database/sorted.js b/test/database/sorted.js
index 8b348961ee..ede6cc8c5d 100644
--- a/test/database/sorted.js
+++ b/test/database/sorted.js
@@ -1119,6 +1119,29 @@ describe('Sorted Set methods', () => {
const members = await db.getSortedSetsMembers(['bulkRemove1', 'bulkRemove2']);
assert.deepStrictEqual(members, [[], []]);
});
+
+ it('should not remove wrong elements in bulk remove', async () => {
+ await db.sortedSetAddBulk([
+ ['bulkRemove4', 1, 'value1'],
+ ['bulkRemove4', 2, 'value2'],
+ ['bulkRemove4', 3, 'value4'],
+ ['bulkRemove5', 1, 'value1'],
+ ['bulkRemove5', 2, 'value2'],
+ ['bulkRemove5', 3, 'value3'],
+ ]);
+ await db.sortedSetRemoveBulk([
+ ['bulkRemove4', 'value1'],
+ ['bulkRemove4', 'value3'],
+ ['bulkRemove5', 'value1'],
+ ['bulkRemove5', 'value4'],
+ ]);
+ const members = await Promise.all([
+ db.getSortedSetRange('bulkRemove4', 0, -1),
+ db.getSortedSetRange('bulkRemove5', 0, -1),
+ ]);
+ assert.deepStrictEqual(members[0], ['value2', 'value4']);
+ assert.deepStrictEqual(members[1], ['value2', 'value3']);
+ });
});
describe('sortedSetsRemove()', () => {
From cb25faaa2d4ce7429d2f5109c16cb0146340af2c Mon Sep 17 00:00:00 2001
From: "Misty (Bot)"
Date: Sat, 2 Oct 2021 09:06:06 +0000
Subject: [PATCH 43/62] Latest translations and fallbacks
---
public/language/fr/admin/settings/post.json | 4 ++--
public/language/fr/topic.json | 4 ++--
2 files changed, 4 insertions(+), 4 deletions(-)
diff --git a/public/language/fr/admin/settings/post.json b/public/language/fr/admin/settings/post.json
index 13887a5f54..8c033dcd9e 100644
--- a/public/language/fr/admin/settings/post.json
+++ b/public/language/fr/admin/settings/post.json
@@ -57,8 +57,8 @@
"composer.enable-plugin-help": "Autoriser les plugins à modifier l'onglet d'aide",
"composer.custom-help": "Message d'aide personnalisé",
"backlinks": "Backlinks",
- "backlinks.enabled": "Enable topic backlinks",
- "backlinks.help": "If a post references another topic, a link back to the post will be inserted into the referenced topic at that point in time.",
+ "backlinks.enabled": "Activer les backlinks de sujet",
+ "backlinks.help": "Si un message fait référence à un autre sujet, un lien vers le message sera inséré dans le sujet référencé.",
"ip-tracking": "Suivi d'IP",
"ip-tracking.each-post": "Suivre l'adresse IP pour chaque message",
"enable-post-history": "Activer l'historique des publications"
diff --git a/public/language/fr/topic.json b/public/language/fr/topic.json
index c5e793b337..5badf716ca 100644
--- a/public/language/fr/topic.json
+++ b/public/language/fr/topic.json
@@ -47,7 +47,7 @@
"restored-by": "Restauré par",
"moved-from-by": "Déplacé de %1 par",
"queued-by": "Message en attente d'approbation →",
- "backlink": "Referenced by",
+ "backlink": "Référencé par",
"bookmark_instructions": "Cliquez ici pour retourner au dernier message lu de ce fil.",
"flag-post": "Signaler ce message",
"flag-user": "Signaler cet utilisateur",
@@ -159,7 +159,7 @@
"newest_to_oldest": "Du plus récent au plus ancien",
"most_votes": "Les plus votés",
"most_posts": "Meilleurs messages",
- "most_views": "Most Views",
+ "most_views": "Les plus vues",
"stale.title": "Créer un nouveau sujet à la place ?",
"stale.warning": "Le sujet auquel vous répondez est assez ancien. Ne voudriez-vous pas créer un nouveau sujet à la place et placer une référence vers celui-ci dans votre réponse ?",
"stale.create": "Créer un nouveau sujet",
From 4404e81991cb1e64112d2018685ff34d4c31fe10 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Bar=C4=B1=C5=9F=20Soner=20U=C5=9Fakl=C4=B1?=
Date: Sat, 2 Oct 2021 13:35:58 -0400
Subject: [PATCH 44/62] fix: switch inf. scroll to xhr (#9854)
this fixes infinitescroll when url has custom query parameters
also fixes infinitescroll for plugins like QnA
fixes infinitescroll on tags page
deprecate topics.loadMoreSortedTopics
deprecate topics.loadMoreFromSet
---
public/src/client/tag.js | 14 ++------------
public/src/modules/topicList.js | 25 ++++++-------------------
src/socket.io/topics/infinitescroll.js | 4 ++++
3 files changed, 12 insertions(+), 31 deletions(-)
diff --git a/public/src/client/tag.js b/public/src/client/tag.js
index a23690ba68..ce45a94aae 100644
--- a/public/src/client/tag.js
+++ b/public/src/client/tag.js
@@ -1,22 +1,12 @@
'use strict';
-
-define('forum/tag', ['topicList', 'forum/infinitescroll'], function (topicList, infinitescroll) {
+define('forum/tag', ['topicList', 'forum/infinitescroll'], function (topicList) {
var Tag = {};
Tag.init = function () {
app.enterRoom('tags');
- topicList.init('tag', loadMoreTopics);
-
- function loadMoreTopics(after, direction, callback) {
- infinitescroll.loadMore('topics.loadMoreFromSet', {
- set: 'tag:' + ajaxify.data.tag + ':topics',
- after: after,
- direction: direction,
- count: config.topicsPerPage,
- }, callback);
- }
+ topicList.init('tag');
};
return Tag;
diff --git a/public/src/modules/topicList.js b/public/src/modules/topicList.js
index b85e04aef9..6ff9e33c24 100644
--- a/public/src/modules/topicList.js
+++ b/public/src/modules/topicList.js
@@ -11,13 +11,6 @@ define('topicList', [
var TopicList = {};
var templateName = '';
- var tplToSort = {
- recent: 'recent',
- unread: 'unread',
- popular: 'posts',
- top: 'votes',
- };
-
var newTopicCount = 0;
var newPostCount = 0;
@@ -197,21 +190,15 @@ define('topicList', [
});
};
+ function calculateNextPage(after, direction) {
+ return Math.floor(after / config.topicsPerPage) + (direction > 0 ? 1 : 0);
+ }
+
function loadTopicsAfter(after, direction, callback) {
callback = callback || function () {};
var query = utils.params();
- infinitescroll.loadMore('topics.loadMoreSortedTopics', {
- after: after,
- direction: direction,
- sort: tplToSort[templateName],
- count: config.topicsPerPage,
- cid: query.cid,
- tags: query.tags,
- query: query,
- term: ajaxify.data.selectedTerm && ajaxify.data.selectedTerm.term,
- filter: ajaxify.data.selectedFilter.filter,
- set: topicListEl.attr('data-set') ? topicListEl.attr('data-set') : 'topics:recent',
- }, callback);
+ query.page = calculateNextPage(after, direction);
+ infinitescroll.loadMoreXhr(query, callback);
}
function filterTopicsOnDom(topics) {
diff --git a/src/socket.io/topics/infinitescroll.js b/src/socket.io/topics/infinitescroll.js
index 03266a3059..93d2bbeb49 100644
--- a/src/socket.io/topics/infinitescroll.js
+++ b/src/socket.io/topics/infinitescroll.js
@@ -1,5 +1,7 @@
'use strict';
+const winston = require('winston');
+
const topics = require('../../topics');
const privileges = require('../../privileges');
const meta = require('../../meta');
@@ -62,6 +64,7 @@ module.exports = function (SocketTopics) {
};
SocketTopics.loadMoreSortedTopics = async function (socket, data) {
+ winston.warn('[deprecated] use infinitescroll.loadMoreXhr'); // TODO: remove in 1.19.0
if (!data || !utils.isNumber(data.after) || parseInt(data.after, 10) < 0) {
throw new Error('[[error:invalid-data]]');
}
@@ -85,6 +88,7 @@ module.exports = function (SocketTopics) {
};
SocketTopics.loadMoreFromSet = async function (socket, data) {
+ winston.warn('[deprecated] use infinitescroll.loadMoreXhr'); // TODO: remove in 1.19.0
if (!data || !utils.isNumber(data.after) || parseInt(data.after, 10) < 0 || !data.set) {
throw new Error('[[error:invalid-data]]');
}
From 5aea6c6aa13ae93d15fa2a456f5893e87b932ba0 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Bar=C4=B1=C5=9F=20Soner=20U=C5=9Fakl=C4=B1?=
Date: Sun, 3 Oct 2021 15:05:30 -0400
Subject: [PATCH 45/62] feat: #9855, allow uid for post queue notifications
---
public/language/en-GB/admin/settings/notifications.json | 3 ++-
src/socket.io/posts.js | 8 ++++++--
src/views/admin/settings/notifications.tpl | 1 +
3 files changed, 9 insertions(+), 3 deletions(-)
diff --git a/public/language/en-GB/admin/settings/notifications.json b/public/language/en-GB/admin/settings/notifications.json
index da6c9680a3..c6d8b928ce 100644
--- a/public/language/en-GB/admin/settings/notifications.json
+++ b/public/language/en-GB/admin/settings/notifications.json
@@ -2,5 +2,6 @@
"notifications": "Notifications",
"welcome-notification": "Welcome Notification",
"welcome-notification-link": "Welcome Notification Link",
- "welcome-notification-uid": "Welcome Notification User (UID)"
+ "welcome-notification-uid": "Welcome Notification User (UID)",
+ "post-queue-notification-uid": "Post Queue User (UID)"
}
\ No newline at end of file
diff --git a/src/socket.io/posts.js b/src/socket.io/posts.js
index 7ff99d6992..a4ab025cc4 100644
--- a/src/socket.io/posts.js
+++ b/src/socket.io/posts.js
@@ -150,13 +150,17 @@ async function acceptOrReject(method, socket, data) {
}
async function sendQueueNotification(type, targetUid, path) {
- const notifObj = await notifications.create({
+ const notifData = {
type: type,
nid: `${type}-${targetUid}-${path}`,
bodyShort: type === 'post-queue-accepted' ?
'[[notifications:post-queue-accepted]]' : '[[notifications:post-queue-rejected]]',
path: path,
- });
+ };
+ if (parseInt(meta.config.postQueueNotificationUid, 10) > 0) {
+ notifData.from = meta.config.postQueueNotificationUid;
+ }
+ const notifObj = await notifications.create(notifData);
await notifications.push(notifObj, [targetUid]);
}
diff --git a/src/views/admin/settings/notifications.tpl b/src/views/admin/settings/notifications.tpl
index 3e68295699..7fc1934832 100644
--- a/src/views/admin/settings/notifications.tpl
+++ b/src/views/admin/settings/notifications.tpl
@@ -7,6 +7,7 @@
[[admin/settings/notifications:welcome-notification]]