From 73fa8099d55b1c490e9d64c1fa280b76018d2d3c Mon Sep 17 00:00:00 2001 From: Innei Date: Thu, 15 Feb 2024 12:03:23 +0800 Subject: [PATCH] fix: float popover position calculation Signed-off-by: Innei --- src/components/layout/footer/GatewayCount.tsx | 84 +++++++++---------- .../modules/note/NoteActionAside.tsx | 2 +- .../ui/float-popover/FloatPopover.tsx | 17 +++- .../ui/theme-switcher/ThemeSwitcher.tsx | 2 +- 4 files changed, 57 insertions(+), 48 deletions(-) diff --git a/src/components/layout/footer/GatewayCount.tsx b/src/components/layout/footer/GatewayCount.tsx index df6c40cdb8..021247cd31 100644 --- a/src/components/layout/footer/GatewayCount.tsx +++ b/src/components/layout/footer/GatewayCount.tsx @@ -1,6 +1,7 @@ 'use client' import { useQuery } from '@tanstack/react-query' +import { sleep } from 'openai/core' import { useOnlineCount } from '~/atoms' import { useSocketIsConnect } from '~/atoms/hooks' @@ -115,51 +116,46 @@ const RoomsInfo = () => { const { data } = useQuery({ queryKey: ['rooms'], refetchOnMount: true, - queryFn: () => { - return apiClient.activity - .getRoomsInfo() - .then((res) => res.$serialized) - .then((data) => { - const result = [] as { - path: string - title: string - count: number - }[] - - const morphArticleIdToRoomName = (id: string) => `article_${id}` - data.objects.notes.forEach((note) => { - result.push({ - path: routeBuilder(Routes.Note, { - id: note.nid, - }), - title: note.title, - count: data.roomCount[morphArticleIdToRoomName(note.id)], - }) - }) - - data.objects.posts.forEach((post) => { - result.push({ - path: routeBuilder(Routes.Post, { - category: post.category.slug, - slug: post.slug, - }), - title: post.title, - count: data.roomCount[morphArticleIdToRoomName(post.id)], - }) - }) - - data.objects.pages.forEach((page) => { - result.push({ - path: routeBuilder(Routes.Page, { - slug: page.slug, - }), - title: page.title, - count: data.roomCount[morphArticleIdToRoomName(page.id)], - }) - }) - - return result.sort((a, b) => b.count - a.count) + staleTime: 1000 * 10, + queryFn: async () => { + await sleep(1000) + const res = await apiClient.activity.getRoomsInfo() + const data = res.$serialized + const result = [] as { + path: string + title: string + count: number + }[] + const morphArticleIdToRoomName = (id: string) => `article_${id}` + data.objects.notes.forEach((note) => { + result.push({ + path: routeBuilder(Routes.Note, { + id: note.nid, + }), + title: note.title, + count: data.roomCount[morphArticleIdToRoomName(note.id)], + }) + }) + data.objects.posts.forEach((post) => { + result.push({ + path: routeBuilder(Routes.Post, { + category: post.category.slug, + slug: post.slug, + }), + title: post.title, + count: data.roomCount[morphArticleIdToRoomName(post.id)], + }) + }) + data.objects.pages.forEach((page) => { + result.push({ + path: routeBuilder(Routes.Page, { + slug: page.slug, + }), + title: page.title, + count: data.roomCount[morphArticleIdToRoomName(page.id)], }) + }) + return result.sort((a, b) => b.count - a.count) }, }) diff --git a/src/components/modules/note/NoteActionAside.tsx b/src/components/modules/note/NoteActionAside.tsx index 21e8c5e0a5..32939d0839 100644 --- a/src/components/modules/note/NoteActionAside.tsx +++ b/src/components/modules/note/NoteActionAside.tsx @@ -35,7 +35,7 @@ export const NoteBottomBarAction: Component = () => { const isMobile = useIsMobile() if (!isMobile) return null return ( -
+
diff --git a/src/components/ui/float-popover/FloatPopover.tsx b/src/components/ui/float-popover/FloatPopover.tsx index a475572c89..14380d0f52 100644 --- a/src/components/ui/float-popover/FloatPopover.tsx +++ b/src/components/ui/float-popover/FloatPopover.tsx @@ -1,6 +1,12 @@ 'use client' -import { flip, offset, shift, useFloating } from '@floating-ui/react-dom' +import { + autoUpdate, + flip, + offset, + shift, + useFloating, +} from '@floating-ui/react-dom' import React, { createContext, createElement, @@ -92,7 +98,7 @@ export const FloatPopover = function FloatPopover( } = props const [open, setOpen] = useState(false) - const { x, y, refs, strategy, isPositioned } = useFloating({ + const { x, y, refs, strategy, isPositioned, elements, update } = useFloating({ middleware: floatingProps.middleware ?? [ flip({ padding: padding ?? 20 }), offset(offsetValue ?? 10), @@ -103,6 +109,13 @@ export const FloatPopover = function FloatPopover( whileElementsMounted: floatingProps.whileElementsMounted, }) + useEffect(() => { + if (open && elements.reference && elements.floating) { + const cleanup = autoUpdate(elements.reference, elements.floating, update) + return cleanup + } + }, [open, elements, update]) + const containerRef = useRef(null) useClickAway(containerRef, () => { diff --git a/src/components/ui/theme-switcher/ThemeSwitcher.tsx b/src/components/ui/theme-switcher/ThemeSwitcher.tsx index cb79f3e199..1df8750c71 100644 --- a/src/components/ui/theme-switcher/ThemeSwitcher.tsx +++ b/src/components/ui/theme-switcher/ThemeSwitcher.tsx @@ -121,7 +121,7 @@ const ButtonGroup = () => { } return ( -
+