about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorPaul Frazee <pfrazee@gmail.com>2022-11-22 13:16:40 -0600
committerPaul Frazee <pfrazee@gmail.com>2022-11-22 13:16:40 -0600
commitce56d4e34e75258104b26e2cdc14c423d937a8af (patch)
treeb0d29452db7bcdf53757a66c3e372ae7ad7fe04a /src
parent27db820a9d9731a16161d08f20e224f7e77a6af5 (diff)
downloadvoidsky-ce56d4e34e75258104b26e2cdc14c423d937a8af.tar.zst
Shorten rendered URLs in posts
Diffstat (limited to 'src')
-rw-r--r--src/lib/strings.ts17
-rw-r--r--src/view/com/util/RichText.tsx5
2 files changed, 20 insertions, 2 deletions
diff --git a/src/lib/strings.ts b/src/lib/strings.ts
index 8f2c3a3ea..c8a9171a3 100644
--- a/src/lib/strings.ts
+++ b/src/lib/strings.ts
@@ -141,6 +141,23 @@ export function toNiceDomain(url: string): string {
   }
 }
 
+export function toShortUrl(url: string): string {
+  try {
+    const urlp = new URL(url)
+    const shortened =
+      urlp.host +
+      (urlp.pathname === '/' ? '' : urlp.pathname) +
+      urlp.search +
+      urlp.hash
+    if (shortened.length > 20) {
+      return shortened.slice(0, 17) + '...'
+    }
+    return shortened
+  } catch (e) {
+    return url
+  }
+}
+
 export function toShareUrl(url: string) {
   if (!url.startsWith('https')) {
     const urlp = new URL('https://bsky.app')
diff --git a/src/view/com/util/RichText.tsx b/src/view/com/util/RichText.tsx
index f865c873a..3c54094ba 100644
--- a/src/view/com/util/RichText.tsx
+++ b/src/view/com/util/RichText.tsx
@@ -1,7 +1,8 @@
 import React from 'react'
-import {Text, TextStyle, StyleProp, View} from 'react-native'
+import {Text, TextStyle, StyleProp} from 'react-native'
 import {TextLink} from './Link'
 import {s} from '../../lib/styles'
+import {toShortUrl} from '../../../lib/strings'
 
 type TextSlice = {start: number; end: number}
 type Entity = {
@@ -45,7 +46,7 @@ export function RichText({
         els.push(
           <TextLink
             key={key}
-            text={segment.text}
+            text={toShortUrl(segment.text)}
             href={segment.entity.value}
             style={[style, s.blue3]}
           />,