From 77b41636258d720f020b8ef0e090a859417b3670 Mon Sep 17 00:00:00 2001 From: thislight Date: Wed, 25 Sep 2024 21:24:39 +0800 Subject: [PATCH] ReplyEditor: promote the blur condition up --- src/timelines/ReplyEditor.tsx | 27 ++++++++++++++------------- src/timelines/TootBottomSheet.tsx | 17 +++++++++-------- 2 files changed, 23 insertions(+), 21 deletions(-) diff --git a/src/timelines/ReplyEditor.tsx b/src/timelines/ReplyEditor.tsx index d40ac77..0f146c4 100644 --- a/src/timelines/ReplyEditor.tsx +++ b/src/timelines/ReplyEditor.tsx @@ -1,4 +1,5 @@ import { + batch, createSignal, createUniqueId, onMount, @@ -57,14 +58,12 @@ const TootVisibilityPickerDialog: Component<{ const discoverable = () => { return props.visibility === "public"; - } - - const setDiscoverable = (setter: (v: boolean) => boolean) => { - const nval = setter(discoverable()) - props.onVisibilityChange(nval ? "public" : "unlisted"); // trigger change }; - + const setDiscoverable = (setter: (v: boolean) => boolean) => { + const nval = setter(discoverable()); + props.onVisibilityChange(nval ? "public" : "unlisted"); // trigger change + }; return ( @@ -83,7 +82,7 @@ const TootVisibilityPickerDialog: Component<{ } > - + @@ -155,27 +154,29 @@ const TootVisibilityPickerDialog: Component<{ const ReplyEditor: Component<{ profile: Account; replyToDisplayName: string; + isTyping?: boolean + onTypingChange: (value: boolean) => void }> = (props) => { let inputRef: HTMLTextAreaElement; const buttonId = createUniqueId(); const menuId = createUniqueId(); - const [typing, setTyping] = createSignal(false); + const typing = () => props.isTyping + const setTyping = (v: boolean) => props.onTypingChange(v) const [visibility, setVisibility] = createSignal("public"); const [permPicker, setPermPicker] = createSignal(false); onMount(() => { makeEventListener(inputRef, "focus", () => setTyping(true)); - makeEventListener(inputRef, "blur", () => setTyping(false)); }); const containerStyle = () => - typing() + typing() || permPicker() ? { position: "sticky" as const, top: "var(--scaffold-topbar-height, 0)", bottom: "var(--safe-area-inset-bottom, 0)", - "z-index": 1, + "z-index": 2, } : undefined; @@ -196,7 +197,7 @@ const ReplyEditor: Component<{
setTyping(true)} + onClick={(e) => inputRef.focus()} >
@@ -219,7 +220,7 @@ const ReplyEditor: Component<{ >
diff --git a/src/timelines/TootBottomSheet.tsx b/src/timelines/TootBottomSheet.tsx index 71f6119..4e86928 100644 --- a/src/timelines/TootBottomSheet.tsx +++ b/src/timelines/TootBottomSheet.tsx @@ -3,17 +3,13 @@ import { createEffect, createRenderEffect, createResource, + createSignal, For, Show, type Component, } from "solid-js"; import Scaffold from "../material/Scaffold"; -import { - AppBar, - CircularProgress, - IconButton, - Toolbar, -} from "@suid/material"; +import { AppBar, CircularProgress, IconButton, Toolbar } from "@suid/material"; import { Title } from "../material/typography"; import { ArrowBack as BackIcon, @@ -41,14 +37,13 @@ function getCache(acct: string, id: string) { } } - - const TootBottomSheet: Component = (props) => { const params = useParams<{ acct: string; id: string }>(); const location = useLocation<{ tootBottomSheetPushedCount?: number }>(); const navigate = useNavigate(); const allSession = useSessions(); const time = createTimeSource(); + const [isInTyping, setInTyping] = createSignal(false); const acctText = () => decodeURIComponent(params.acct); const session = () => { const [inputUsername, inputSite] = acctText().split("@", 2); @@ -164,6 +159,10 @@ const TootBottomSheet: Component = (props) => { }; const switchContext = (status: mastodon.v1.Status) => { + if (isInTyping()) { + setInTyping(false); + return; + } setCache(params.acct, status); navigate(`/${params.acct}/${status.id}`, { state: { @@ -240,6 +239,8 @@ const TootBottomSheet: Component = (props) => {