fix webUI tabs (underline)

This commit is contained in:
proddy
2024-12-31 12:15:59 +01:00
parent 43d3c28e16
commit 397f3f546e
4 changed files with 39 additions and 23 deletions

View File

@@ -1,9 +1,16 @@
import { useCallback, useState } from 'react'; import { useCallback, useState } from 'react';
import { Navigate, Route, Routes, useNavigate } from 'react-router'; import {
Navigate,
Route,
Routes,
matchRoutes,
useLocation,
useNavigate
} from 'react-router';
import { Tab } from '@mui/material'; import { Tab } from '@mui/material';
import { RouterTabs, useLayoutTitle, useRouterTab } from 'components'; import { RouterTabs, useLayoutTitle } from 'components';
import { useI18nContext } from 'i18n/i18n-react'; import { useI18nContext } from 'i18n/i18n-react';
import type { WiFiNetwork } from 'types'; import type { WiFiNetwork } from 'types';
@@ -15,7 +22,13 @@ const Network = () => {
const { LL } = useI18nContext(); const { LL } = useI18nContext();
useLayoutTitle(LL.NETWORK(0)); useLayoutTitle(LL.NETWORK(0));
const { routerTab } = useRouterTab(); // this also works!
// const routerTab = useMatch(`settings/network/:path/*`)?.pathname || false;
const matchedRoutes = matchRoutes( [
{ path: '/settings/network/settings', element: <NetworkSettings />, dog: 'woof' },
{ path: '/settings/network/scan', element: <WiFiNetworkScanner /> }
], useLocation());
const routerTab = matchedRoutes?.[0].route.path || false;
const navigate = useNavigate(); const navigate = useNavigate();
@@ -24,7 +37,7 @@ const Network = () => {
const selectNetwork = useCallback( const selectNetwork = useCallback(
(network: WiFiNetwork) => { (network: WiFiNetwork) => {
setSelectedNetwork(network); setSelectedNetwork(network);
void navigate('/settings'); void navigate('/settings/network/settings');
}, },
[navigate] [navigate]
); );
@@ -42,16 +55,16 @@ const Network = () => {
}} }}
> >
<RouterTabs value={routerTab}> <RouterTabs value={routerTab}>
<Tab <Tab value="/settings/network/settings" label={LL.SETTINGS_OF(LL.NETWORK(1))} />
value="/settings/network/settings"
label={LL.SETTINGS_OF(LL.NETWORK(1))}
/>
<Tab value="/settings/network/scan" label={LL.NETWORK_SCAN()} /> <Tab value="/settings/network/scan" label={LL.NETWORK_SCAN()} />
</RouterTabs> </RouterTabs>
<Routes> <Routes>
<Route path="scan" element={<WiFiNetworkScanner />} /> <Route path="scan" element={<WiFiNetworkScanner />} />
<Route path="settings" element={<NetworkSettings />} /> <Route path="settings" element={<NetworkSettings />} />
<Route path="*" element={<Navigate replace to="settings" />} /> <Route
path="*"
element={<Navigate replace to="/settings/network/settings" />}
/>
</Routes> </Routes>
</WiFiConnectionContext.Provider> </WiFiConnectionContext.Provider>
); );

View File

@@ -1,8 +1,14 @@
import { Navigate, Route, Routes } from 'react-router'; import {
Navigate,
Route,
Routes,
matchRoutes,
useLocation
} from 'react-router';
import { Tab } from '@mui/material'; import { Tab } from '@mui/material';
import { RouterTabs, useLayoutTitle, useRouterTab } from 'components'; import { RouterTabs, useLayoutTitle } from 'components';
import { useI18nContext } from 'i18n/i18n-react'; import { useI18nContext } from 'i18n/i18n-react';
import ManageUsers from './ManageUsers'; import ManageUsers from './ManageUsers';
@@ -12,7 +18,14 @@ const Security = () => {
const { LL } = useI18nContext(); const { LL } = useI18nContext();
useLayoutTitle(LL.SECURITY(0)); useLayoutTitle(LL.SECURITY(0));
const { routerTab } = useRouterTab(); const matchedRoutes = matchRoutes(
[
{ path: '/settings/security/settings', element: <ManageUsers />, dog: 'woof' },
{ path: '/settings/security/users', element: <SecuritySettings /> }
],
useLocation()
);
const routerTab = matchedRoutes?.[0].route.path || false;
return ( return (
<> <>
@@ -26,7 +39,7 @@ const Security = () => {
<Routes> <Routes>
<Route path="users" element={<ManageUsers />} /> <Route path="users" element={<ManageUsers />} />
<Route path="settings" element={<SecuritySettings />} /> <Route path="settings" element={<SecuritySettings />} />
<Route path="*" element={<Navigate replace to="settings" />} /> <Route path="*" element={<Navigate replace to="/settings/security/settings" />} />
</Routes> </Routes>
</> </>
); );

View File

@@ -2,5 +2,3 @@ export { default as RouterTabs } from './RouterTabs';
export { default as RequireAdmin } from './RequireAdmin'; export { default as RequireAdmin } from './RequireAdmin';
export { default as RequireAuthenticated } from './RequireAuthenticated'; export { default as RequireAuthenticated } from './RequireAuthenticated';
export { default as RequireUnauthenticated } from './RequireUnauthenticated'; export { default as RequireUnauthenticated } from './RequireUnauthenticated';
export * from './useRouterTab';

View File

@@ -1,8 +0,0 @@
import { useMatch, useResolvedPath } from 'react-router';
export const useRouterTab = () => {
const routerTabPathMatch = useMatch(useResolvedPath(':tab').pathname);
const routerTab = routerTabPathMatch?.params?.tab || false;
return { routerTab } as const;
};