From d1f1682bce87f6a86b40ecb3c6dbe57e88ad097b Mon Sep 17 00:00:00 2001 From: thislight Date: Tue, 13 Aug 2024 15:39:05 +0800 Subject: [PATCH] TootBottomSheet: basic layout --- src/App.css | 2 +- src/timelines/TootBottomSheet.tsx | 78 +++++++++++++++++++++++++------ 2 files changed, 64 insertions(+), 16 deletions(-) diff --git a/src/App.css b/src/App.css index b912c3a..e2c7ce3 100644 --- a/src/App.css +++ b/src/App.css @@ -8,5 +8,5 @@ } .custom-emoji { - width: 1.25em; + width: 1em; } diff --git a/src/timelines/TootBottomSheet.tsx b/src/timelines/TootBottomSheet.tsx index b51bf7c..22b0946 100644 --- a/src/timelines/TootBottomSheet.tsx +++ b/src/timelines/TootBottomSheet.tsx @@ -1,45 +1,57 @@ import { useNavigate, useParams } from "@solidjs/router"; -import { createEffect, createResource, Show, type Component } from "solid-js"; +import { + createEffect, + createRenderEffect, + createResource, + Show, + type Component, +} from "solid-js"; import Scaffold from "../material/Scaffold"; import TootThread from "./TootThread"; -import { AppBar, IconButton, Toolbar } from "@suid/material"; +import { AppBar, Avatar, IconButton, Toolbar } from "@suid/material"; import { Title } from "../material/typography"; -import { Close as CloseIcon } from "@suid/icons-material"; +import { Close as CloseIcon, Send } from "@suid/icons-material"; import { isiOS } from "../platform/host"; import { createUnauthorizedClient, useSessions } from "../masto/clients"; import { resolveCustomEmoji } from "../masto/toot"; import RegularToot from "./RegularToot"; import type { mastodon } from "masto"; +import cards from "../material/cards.module.css"; +import { css } from "solid-styled"; let cachedEntry: [string, mastodon.v1.Status] | undefined; export function setCache(acct: string, status: mastodon.v1.Status) { - cachedEntry = [acct, status] + cachedEntry = [acct, status]; } function getCache(acct: string, id: string) { if (acct === cachedEntry?.[0] && id === cachedEntry?.[1].id) { - return cachedEntry[1] + return cachedEntry[1]; } } - const TootBottomSheet: Component = (props) => { const params = useParams<{ acct: string; id: string }>(); const navigate = useNavigate(); const allSession = useSessions(); - const acctText = () => decodeURIComponent(params.acct) + const acctText = () => decodeURIComponent(params.acct); const session = () => { - const [inputUsername, inputSite] = acctText().split( - "@", - 2, - ); + const [inputUsername, inputSite] = acctText().split("@", 2); const authedSession = allSession().find( (x) => x.account.site === inputSite && x.account.inf?.username === inputUsername, ); - return authedSession ?? { client: createUnauthorizedClient(inputSite) }; + return ( + authedSession ?? { + client: createUnauthorizedClient(inputSite), + account: undefined, + } + ); + }; + const profile = () => { + return session().account; }; const [remoteToot] = createResource( @@ -60,6 +72,17 @@ const TootBottomSheet: Component = (props) => { return "A toot"; }; + css` + .bottom-dock { + position: sticky; + bottom: 0; + } + + .name :global(img) { + max-height: 1em; + } + `; + return ( { - {tootTitle} + + createRenderEffect(() => (e.innerHTML = tootTitle())) + } + > } > -
+
- + + +
+ +
+ +
+ + + + + +