Replace state when opening a modal from a drawer

This commit is contained in:
Jon Staab
2024-10-24 14:18:32 -07:00
parent ceb7f3340d
commit 058f1d09d2
4 changed files with 99 additions and 87 deletions
+15 -5
View File
@@ -38,15 +38,19 @@
} }
const showMembers = () => const showMembers = () =>
pushModal(ProfileList, {pubkeys: members, title: `Members of`, subtitle: displayRelayUrl(url)}) pushModal(
ProfileList,
{pubkeys: members, title: `Members of`, subtitle: displayRelayUrl(url)},
{replaceState}
)
const createInvite = () => pushModal(SpaceInvite, {url}) const createInvite = () => pushModal(SpaceInvite, {url}, {replaceState})
const leaveSpace = () => pushModal(SpaceExit, {url}) const leaveSpace = () => pushModal(SpaceExit, {url}, {replaceState})
const joinSpace = () => pushModal(SpaceJoin, {url}) const joinSpace = () => pushModal(SpaceJoin, {url}, {replaceState})
const addRoom = () => pushModal(RoomCreate, {url}) const addRoom = () => pushModal(RoomCreate, {url}, {replaceState})
const getDelay = (reset = false) => { const getDelay = (reset = false) => {
if (reset) { if (reset) {
@@ -60,12 +64,16 @@
let delay = 0 let delay = 0
let showMenu = false let showMenu = false
let replaceState = false
let element: Element
$: rooms = getMembershipRoomsByUrl(url, $userMembership) $: rooms = getMembershipRoomsByUrl(url, $userMembership)
$: otherRooms = ($roomsByUrl.get(url) || []).filter(room => !rooms.concat(GENERAL).includes(room)) $: otherRooms = ($roomsByUrl.get(url) || []).filter(room => !rooms.concat(GENERAL).includes(room))
$: members = $memberships.filter(l => hasMembershipUrl(l, url)).map(l => l.event.pubkey) $: members = $memberships.filter(l => hasMembershipUrl(l, url)).map(l => l.event.pubkey)
onMount(async () => { onMount(async () => {
replaceState = Boolean(element.closest('.drawer'))
const error = (await checkRelayConnection(url)) || (await checkRelayAuth(url)) const error = (await checkRelayConnection(url)) || (await checkRelayAuth(url))
if (error) { if (error) {
@@ -74,6 +82,7 @@
}) })
</script> </script>
<div bind:this={element}>
<SecondaryNavSection> <SecondaryNavSection>
<div> <div>
<SecondaryNavItem class="w-full !justify-between" on:click={openMenu}> <SecondaryNavItem class="w-full !justify-between" on:click={openMenu}>
@@ -164,3 +173,4 @@
</SecondaryNavItem> </SecondaryNavItem>
</div> </div>
</SecondaryNavSection> </SecondaryNavSection>
</div>
+2 -1
View File
@@ -8,7 +8,8 @@ export const getKey = <T>(key: string) => state.get(key) as T | undefined
export const popKey = <T>(key: string) => { export const popKey = <T>(key: string) => {
const value: T | undefined = state.get(key) const value: T | undefined = state.get(key)
state.delete(key) // Goofy hack due to sveltekit's double-rendering
setTimeout(() => state.delete(key), 300)
return value return value
} }
+2 -1
View File
@@ -6,6 +6,7 @@ import {goto} from "$app/navigation"
export type ModalOptions = { export type ModalOptions = {
drawer?: boolean drawer?: boolean
fullscreen?: boolean fullscreen?: boolean
replaceState?: boolean
} }
export type Modal = { export type Modal = {
@@ -28,7 +29,7 @@ export const pushModal = (
modals.update(assoc(id, {id, component, props, options})) modals.update(assoc(id, {id, component, props, options}))
goto("#" + id) goto("#" + id, {replaceState: options.replaceState})
return id return id
} }
+1 -1
View File
@@ -4,7 +4,7 @@
export let onClose export let onClose
</script> </script>
<div class="fixed inset-0 z-modal"> <div class="fixed inset-0 z-modal drawer">
<button <button
class="absolute inset-0 cursor-pointer bg-black opacity-50" class="absolute inset-0 cursor-pointer bg-black opacity-50"
transition:fade transition:fade