summaryrefslogtreecommitdiff
path: root/packages/frontend-shared
diff options
context:
space:
mode:
authordakkar <dakkar@thenautilus.net>2025-04-28 15:00:00 +0100
committerdakkar <dakkar@thenautilus.net>2025-04-28 15:31:28 +0100
commit4981e5ba36bf9286a7bb9ff1dc6a10d7e3855241 (patch)
tree5b00e9f161a2db8f688de1a0dfd3f86fd988592e /packages/frontend-shared
parentfix null checks for background in UserEntityService.ts (diff)
parentmerge: Merge stable into develop (!971) (diff)
downloadsharkey-4981e5ba36bf9286a7bb9ff1dc6a10d7e3855241.tar.gz
sharkey-4981e5ba36bf9286a7bb9ff1dc6a10d7e3855241.tar.bz2
sharkey-4981e5ba36bf9286a7bb9ff1dc6a10d7e3855241.zip
Merge branch 'develop' into merge/2025-03-24
Diffstat (limited to 'packages/frontend-shared')
-rw-r--r--packages/frontend-shared/js/math.ts10
-rw-r--r--packages/frontend-shared/js/url.ts17
2 files changed, 27 insertions, 0 deletions
diff --git a/packages/frontend-shared/js/math.ts b/packages/frontend-shared/js/math.ts
new file mode 100644
index 0000000000..528f3b08bf
--- /dev/null
+++ b/packages/frontend-shared/js/math.ts
@@ -0,0 +1,10 @@
+/*
+ * SPDX-FileCopyrightText: dakkar and other Sharkey contributors
+ * SPDX-License-Identifier: AGPL-3.0-only
+ */
+
+export function clamp(value: number, min: number, max: number) {
+ if (value > max) return max;
+ if (value < min) return min;
+ return value;
+}
diff --git a/packages/frontend-shared/js/url.ts b/packages/frontend-shared/js/url.ts
index eb830b1eea..ed36704d92 100644
--- a/packages/frontend-shared/js/url.ts
+++ b/packages/frontend-shared/js/url.ts
@@ -26,3 +26,20 @@ export function extractDomain(url: string) {
const match = url.match(/^(?:https?:)?(?:\/\/)?(?:[^@\n]+@)?([^:\/\n]+)/im);
return match ? match[1] : null;
}
+
+export function maybeMakeRelative(urlStr: string, baseStr: string): string {
+ try {
+ const baseObj = new URL(baseStr);
+ const urlObj = new URL(urlStr);
+ /* in all places where maybeMakeRelative is used, baseStr is the
+ * instance's public URL, which can't have path components, so the
+ * relative URL will always have the whole path from the urlStr
+ */
+ if (urlObj.origin === baseObj.origin) {
+ return urlObj.pathname + urlObj.search + urlObj.hash;
+ }
+ return urlStr;
+ } catch (error) {
+ return '';
+ }
+}