forked from coracle/flotilla
Spruce up join button on spaces page
This commit is contained in:
@@ -1,11 +1,29 @@
|
||||
<script lang="ts">
|
||||
import {onMount} from 'svelte'
|
||||
import Masonry from 'svelte-bricks'
|
||||
import {GROUP_META} from '@welshman/util'
|
||||
import {append, remove} from '@welshman/lib'
|
||||
import {GROUP_META, displayRelayUrl} from '@welshman/util'
|
||||
import Icon from '@lib/components/Icon.svelte'
|
||||
import {load, relays, groups, searchGroups} from '@app/state'
|
||||
import Button from '@lib/components/Button.svelte'
|
||||
import Spinner from '@lib/components/Spinner.svelte'
|
||||
import {makeSpacePath} from '@app/routes'
|
||||
import {load, relays, groups, searchGroups, relayUrlsByNom, userMembership} from '@app/state'
|
||||
import {updateGroupMemberships} from '@app/commands'
|
||||
|
||||
const getRelayUrls = (nom: string): string[] => $relayUrlsByNom.get(nom) || []
|
||||
|
||||
const join = async (nom: string) => {
|
||||
loading = append(nom, loading)
|
||||
|
||||
try {
|
||||
await updateGroupMemberships(getRelayUrls(nom).map(url => ["group", nom, url]))
|
||||
} finally {
|
||||
loading = remove(nom, loading)
|
||||
}
|
||||
}
|
||||
|
||||
let term = ""
|
||||
let loading: string[] = []
|
||||
|
||||
onMount(() => {
|
||||
load({
|
||||
@@ -22,22 +40,40 @@
|
||||
<Icon icon="magnifer" />
|
||||
<input bind:value={term} class="grow" type="text" placeholder="Search for spaces..." />
|
||||
</label>
|
||||
<Masonry animate={false} items={$searchGroups.searchOptions(term)} minColWidth={250} maxColWidth={800} gap={16} idKey="nom" let:item>
|
||||
<Masonry animate={false} items={$searchGroups.searchOptions(term)} minColWidth={250} maxColWidth={800} gap={16} idKey="nom" let:item={group}>
|
||||
<div class="card bg-base-100 shadow-xl">
|
||||
<div class="avatar center mt-8">
|
||||
<div class="w-20 rounded-full bg-base-300 border-2 border-solid border-base-300 !flex center">
|
||||
{#if item?.picture}
|
||||
<img alt="" src={item.picture} />
|
||||
{#if group?.picture}
|
||||
<img alt="" src={group.picture} />
|
||||
{:else}
|
||||
<Icon icon="ghost" size={7} />
|
||||
{/if}
|
||||
</div>
|
||||
</div>
|
||||
<div class="card-body">
|
||||
<h2 class="card-title justify-center">{item.name}</h2>
|
||||
<p class="text-sm py-4">{item.about}</p>
|
||||
<a href={makeSpacePath(group.nom)}>
|
||||
<h2 class="card-title justify-center">{group.name}</h2>
|
||||
</a>
|
||||
<div class="text-sm text-center">
|
||||
{#each getRelayUrls(group.nom) as url}
|
||||
<div class="badge badge-neutral">{displayRelayUrl(url)}</div>
|
||||
{/each}
|
||||
</div>
|
||||
<p class="text-sm py-4">{group.about}</p>
|
||||
<div class="card-actions">
|
||||
<button class="btn btn-primary w-full">Join Space</button>
|
||||
<Button
|
||||
class="btn btn-primary w-full"
|
||||
disabled={loading.includes(group.nom) || $userMembership?.noms.has(group.nom)}
|
||||
on:click={() => join(group.nom)}>
|
||||
{#if $userMembership?.noms.has(group.nom)}
|
||||
<Icon icon="check-circle" />
|
||||
Joined
|
||||
{:else}
|
||||
<Spinner loading={loading.includes(group.nom)} />
|
||||
Join Space
|
||||
{/if}
|
||||
</Button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
@@ -1,5 +1,16 @@
|
||||
<script lang="ts">
|
||||
export let nom
|
||||
import {page} from '$app/stores'
|
||||
import {deriveGroup, deriveGroupConversation} from '@app/state'
|
||||
|
||||
const group = deriveGroup($page.params.nom)
|
||||
const conversation = deriveGroupConversation($page.params.nom)
|
||||
</script>
|
||||
|
||||
{nom}
|
||||
<div class="h-screen flex flex-col">
|
||||
<div class="min-h-32 bg-base-100">
|
||||
</div>
|
||||
<div class="flex-grow overflow-auto">
|
||||
</div>
|
||||
<div class="min-h-32 bg-base-100">
|
||||
</div>
|
||||
</div>
|
||||
|
||||
Reference in New Issue
Block a user