mirror of
https://github.com/coracle-social/coracle.git
synced 2024-09-18 19:23:40 +00:00
Fix a few small bugs
This commit is contained in:
parent
e9a2e581d5
commit
f2e710c842
@ -40,7 +40,7 @@ export const initializeRelayList = async () => {
|
||||
const url = import.meta.env.VITE_DUFFLEPUD_URL + "/relay"
|
||||
const json = await fetchJson(url)
|
||||
|
||||
await relays.bulkPatch(map(objOf("url"), json.relays.filter(isRelay)))
|
||||
await relays.bulkPatch(json.relays.filter(isRelay).map(objOf("url")))
|
||||
} catch (e) {
|
||||
warn("Failed to fetch relays list", e)
|
||||
}
|
||||
@ -88,7 +88,11 @@ export const getAllPubkeyWriteRelays = pubkeys => getAllPubkeyRelays(pubkeys, "w
|
||||
|
||||
// Current user
|
||||
|
||||
export const getUserRelays = () => user.getRelays().map(assoc("score", 1))
|
||||
export const getUserRelays = () =>
|
||||
user
|
||||
.getRelays()
|
||||
.filter(({url}) => isRelay(url))
|
||||
.map(assoc("score", 1))
|
||||
|
||||
export const getUserReadRelays = () =>
|
||||
getUserRelays()
|
||||
|
@ -32,7 +32,7 @@
|
||||
<div in:slide class="relative">
|
||||
<Media link={annotated[0]} onClose={close} />
|
||||
{#if annotated.length > 1}
|
||||
<p class="text-gray-500 py-4 text-center underline" on:click={openModal}>
|
||||
<p class="text-gray-500 cursor-pointer py-4 text-center underline" on:click={openModal}>
|
||||
<i class="fa fa-plus" /> Show {annotated.length} link previews
|
||||
</p>
|
||||
{/if}
|
||||
|
@ -119,6 +119,7 @@ export const parseContent = content => {
|
||||
}
|
||||
|
||||
for (; i < text.length; ) {
|
||||
const prev = last(result)
|
||||
const tail = text.slice(i)
|
||||
|
||||
const newLine = tail.match(/^\n+/)
|
||||
@ -162,7 +163,7 @@ export const parseContent = content => {
|
||||
)
|
||||
|
||||
// Skip url if it's just the end of a filepath
|
||||
if (urlMatch && !last(result)?.value.endsWith("/")) {
|
||||
if (urlMatch && (prev?.type !== "text" || !prev.value.endsWith("/"))) {
|
||||
let url = urlMatch[0]
|
||||
|
||||
// Skip ellipses and very short non-urls
|
||||
|
@ -114,7 +114,7 @@ export const isNotification = (e, pubkey) => {
|
||||
export const isRelay = url =>
|
||||
typeof url === "string" &&
|
||||
// It should have the protocol included
|
||||
url.match(/^wss?:\/\/.+/)
|
||||
url.match(/^wss:\/\/.+/)
|
||||
|
||||
export const isShareableRelay = url =>
|
||||
isRelay(url) &&
|
||||
|
@ -1,7 +1,19 @@
|
||||
<script lang="ts">
|
||||
import cx from "classnames"
|
||||
import {nip19} from "nostr-tools"
|
||||
import {find, sum, last, whereEq, without, uniq, pluck, reject, propEq} from "ramda"
|
||||
import {
|
||||
sortBy,
|
||||
identity,
|
||||
find,
|
||||
sum,
|
||||
last,
|
||||
whereEq,
|
||||
without,
|
||||
uniq,
|
||||
pluck,
|
||||
reject,
|
||||
propEq,
|
||||
} from "ramda"
|
||||
import {onMount} from "svelte"
|
||||
import {tweened} from "svelte/motion"
|
||||
import {slide} from "svelte/transition"
|
||||
@ -477,7 +489,7 @@
|
||||
<div
|
||||
style="transform: scale(-1, 1)"
|
||||
class="absolute top-0 right-0 m-3 grid grid-cols-3 gap-2 sm:hidden">
|
||||
{#each note.seen_on as url, i}
|
||||
{#each sortBy(identity, note.seen_on) as url, i}
|
||||
<div class={`cursor-pointer order-${3 - (i % 3)}`}>
|
||||
<div
|
||||
class="h-3 w-3 rounded-full border border-solid border-gray-6"
|
||||
@ -488,10 +500,10 @@
|
||||
</div>
|
||||
<!-- Desktop version -->
|
||||
<div
|
||||
class={cx("hidden sm:flex transition-opacity", {
|
||||
class={cx("hidden transition-opacity sm:flex", {
|
||||
"opacity-0 group-hover:opacity-100": !showEntire,
|
||||
})}>
|
||||
{#each note.seen_on as url, i}
|
||||
{#each sortBy(identity, note.seen_on) as url, i}
|
||||
<Popover triggerType="mouseenter" interactive={false}>
|
||||
<div slot="trigger" class="cursor-pointer p-1">
|
||||
<div
|
||||
|
Loading…
Reference in New Issue
Block a user