测试路由对话框

This commit is contained in:
CrescentLeaf
2025-12-13 00:46:37 +08:00
parent 1a8df07c3b
commit de028556af

View File

@@ -3,7 +3,7 @@ import useEventListener from "../utils/useEventListener.ts"
import AvatarMySelf from "./AvatarMySelf.tsx" import AvatarMySelf from "./AvatarMySelf.tsx"
import MainSharedContext from './MainSharedContext.ts' import MainSharedContext from './MainSharedContext.ts'
import * as React from 'react' import * as React from 'react'
import { BrowserRouter, Link, Outlet, Route, Routes } from "react-router" import { BrowserRouter, Link, Outlet, Route, Routes, useNavigate } from "react-router"
import LoginDialog from "./main-page/LoginDialog.tsx" import LoginDialog from "./main-page/LoginDialog.tsx"
import useAsyncEffect from "../utils/useAsyncEffect.ts" import useAsyncEffect from "../utils/useAsyncEffect.ts"
import performAuth from "../performAuth.ts" import performAuth from "../performAuth.ts"
@@ -11,7 +11,7 @@ import { CallbackError, Chat, UserMySelf } from "lingchair-client-protocol"
import showCircleProgressDialog from "./showCircleProgressDialog.ts" import showCircleProgressDialog from "./showCircleProgressDialog.ts"
import RegisterDialog from "./main-page/RegisterDialog.tsx" import RegisterDialog from "./main-page/RegisterDialog.tsx"
import sleep from "../utils/sleep.ts" import sleep from "../utils/sleep.ts"
import { $, NavigationDrawer } from "mdui" import { $, Dialog, NavigationDrawer } from "mdui"
import getClient from "../getClient.ts" import getClient from "../getClient.ts"
import showSnackbar from "../utils/showSnackbar.ts" import showSnackbar from "../utils/showSnackbar.ts"
import AllChatsList from "./main-page/AllChatsList.tsx" import AllChatsList from "./main-page/AllChatsList.tsx"
@@ -20,6 +20,23 @@ import AddFavourtieChatDialog from "./main-page/AddFavourtieChatDialog.tsx"
import RecentChatsList from "./main-page/RecentChatsList.tsx" import RecentChatsList from "./main-page/RecentChatsList.tsx"
import ChatInfoDialog from "./routers/ChatInfoDialog.tsx" import ChatInfoDialog from "./routers/ChatInfoDialog.tsx"
function Test() {
const nav = useNavigate()
const dialogRef = React.useRef<Dialog>()
useAsyncEffect(async () => {
await sleep(10)
dialogRef.current!.open = true
dialogRef.current!.addEventListener('overlay-click', () => {
dialogRef.current!.open = false
})
dialogRef.current!.addEventListener('closed', async () => {
await sleep(100)
nav(-1)
})
}, [])
return <mdui-dialog ref={dialogRef}></mdui-dialog>
}
export default function Main() { export default function Main() {
const [myProfileCache, setMyProfileCache] = React.useState<UserMySelf>() const [myProfileCache, setMyProfileCache] = React.useState<UserMySelf>()
@@ -69,7 +86,6 @@ export default function Main() {
setCurrentSelectedChatId, setCurrentSelectedChatId,
myProfileCache, myProfileCache,
} }
useAsyncEffect(async () => { useAsyncEffect(async () => {
@@ -95,16 +111,9 @@ export default function Main() {
waitingForAuth.open = false waitingForAuth.open = false
}) })
const subRoutes = <>
<Route path="/info">
<Route path="chat" element={<ChatInfoDialog />} />
<Route path="user" element={<ChatInfoDialog />} />
</Route>
</>
return ( return (
<MainSharedContext.Provider value={sharedContext}> <BrowserRouter>
<BrowserRouter> <MainSharedContext.Provider value={sharedContext}>
<Routes> <Routes>
<Route path="/" element={( <Route path="/" element={(
<div style={{ <div style={{
@@ -222,10 +231,13 @@ export default function Main() {
} }
</div> </div>
)}> )}>
{subRoutes} <Route path="info">
<Route path="chat" element={<Test />} />
<Route path="user" element={<ChatInfoDialog />} />
</Route>
</Route> </Route>
</Routes> </Routes>
</BrowserRouter> </MainSharedContext.Provider>
</MainSharedContext.Provider> </BrowserRouter>
) )
} }