Move EditChannel and EditTagModal from standalone pages to modal components within the channels module structure for consistency with other table modules. Changes: - Move EditChannel.js → components/table/channels/modals/EditChannelModal.jsx - Move EditTagModal.js → components/table/channels/modals/EditTagModal.jsx - Update import paths in channels/index.jsx - Remove standalone routes for EditChannel from App.js - Delete original files from pages/Channel/ This change aligns the channels module with the established modular pattern used by tokens, users, redemptions, and other table modules, centralizing all channel management functionality within integrated modal components instead of separate page routes. BREAKING CHANGE: EditChannel standalone routes (/console/channel/edit/:id and /console/channel/add) have been removed. All channel editing is now handled through modal components within the main channels page.
265 lines
7.3 KiB
JavaScript
265 lines
7.3 KiB
JavaScript
import React, { lazy, Suspense } from 'react';
|
|
import { Route, Routes, useLocation } from 'react-router-dom';
|
|
import Loading from './components/common/ui/Loading.js';
|
|
import User from './pages/User';
|
|
import { AuthRedirect, PrivateRoute } from './helpers';
|
|
import RegisterForm from './components/auth/RegisterForm.js';
|
|
import LoginForm from './components/auth/LoginForm.js';
|
|
import NotFound from './pages/NotFound';
|
|
import Setting from './pages/Setting';
|
|
|
|
import PasswordResetForm from './components/auth/PasswordResetForm.js';
|
|
import PasswordResetConfirm from './components/auth/PasswordResetConfirm.js';
|
|
import Channel from './pages/Channel';
|
|
import Token from './pages/Token';
|
|
import Redemption from './pages/Redemption';
|
|
import TopUp from './pages/TopUp';
|
|
import Log from './pages/Log';
|
|
import Chat from './pages/Chat';
|
|
import Chat2Link from './pages/Chat2Link';
|
|
import Midjourney from './pages/Midjourney';
|
|
import Pricing from './pages/Pricing/index.js';
|
|
import Task from './pages/Task/index.js';
|
|
import Playground from './pages/Playground/index.js';
|
|
import OAuth2Callback from './components/auth/OAuth2Callback.js';
|
|
import PersonalSetting from './components/settings/PersonalSetting.js';
|
|
import Setup from './pages/Setup/index.js';
|
|
import SetupCheck from './components/layout/SetupCheck.js';
|
|
|
|
const Home = lazy(() => import('./pages/Home'));
|
|
const Detail = lazy(() => import('./pages/Detail'));
|
|
const About = lazy(() => import('./pages/About'));
|
|
|
|
function App() {
|
|
const location = useLocation();
|
|
|
|
return (
|
|
<SetupCheck>
|
|
<Routes>
|
|
<Route
|
|
path='/'
|
|
element={
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<Home />
|
|
</Suspense>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/setup'
|
|
element={
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<Setup />
|
|
</Suspense>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/console/channel'
|
|
element={
|
|
<PrivateRoute>
|
|
<Channel />
|
|
</PrivateRoute>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/console/token'
|
|
element={
|
|
<PrivateRoute>
|
|
<Token />
|
|
</PrivateRoute>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/console/playground'
|
|
element={
|
|
<PrivateRoute>
|
|
<Playground />
|
|
</PrivateRoute>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/console/redemption'
|
|
element={
|
|
<PrivateRoute>
|
|
<Redemption />
|
|
</PrivateRoute>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/console/user'
|
|
element={
|
|
<PrivateRoute>
|
|
<User />
|
|
</PrivateRoute>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/user/reset'
|
|
element={
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<PasswordResetConfirm />
|
|
</Suspense>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/login'
|
|
element={
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<AuthRedirect>
|
|
<LoginForm />
|
|
</AuthRedirect>
|
|
</Suspense>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/register'
|
|
element={
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<AuthRedirect>
|
|
<RegisterForm />
|
|
</AuthRedirect>
|
|
</Suspense>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/reset'
|
|
element={
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<PasswordResetForm />
|
|
</Suspense>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/oauth/github'
|
|
element={
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<OAuth2Callback type='github'></OAuth2Callback>
|
|
</Suspense>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/oauth/oidc'
|
|
element={
|
|
<Suspense fallback={<Loading></Loading>}>
|
|
<OAuth2Callback type='oidc'></OAuth2Callback>
|
|
</Suspense>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/oauth/linuxdo'
|
|
element={
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<OAuth2Callback type='linuxdo'></OAuth2Callback>
|
|
</Suspense>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/console/setting'
|
|
element={
|
|
<PrivateRoute>
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<Setting />
|
|
</Suspense>
|
|
</PrivateRoute>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/console/personal'
|
|
element={
|
|
<PrivateRoute>
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<PersonalSetting />
|
|
</Suspense>
|
|
</PrivateRoute>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/console/topup'
|
|
element={
|
|
<PrivateRoute>
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<TopUp />
|
|
</Suspense>
|
|
</PrivateRoute>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/console/log'
|
|
element={
|
|
<PrivateRoute>
|
|
<Log />
|
|
</PrivateRoute>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/console'
|
|
element={
|
|
<PrivateRoute>
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<Detail />
|
|
</Suspense>
|
|
</PrivateRoute>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/console/midjourney'
|
|
element={
|
|
<PrivateRoute>
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<Midjourney />
|
|
</Suspense>
|
|
</PrivateRoute>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/console/task'
|
|
element={
|
|
<PrivateRoute>
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<Task />
|
|
</Suspense>
|
|
</PrivateRoute>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/pricing'
|
|
element={
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<Pricing />
|
|
</Suspense>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/about'
|
|
element={
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<About />
|
|
</Suspense>
|
|
}
|
|
/>
|
|
<Route
|
|
path='/console/chat/:id?'
|
|
element={
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<Chat />
|
|
</Suspense>
|
|
}
|
|
/>
|
|
{/* 方便使用chat2link直接跳转聊天... */}
|
|
<Route
|
|
path='/chat2link'
|
|
element={
|
|
<PrivateRoute>
|
|
<Suspense fallback={<Loading></Loading>} key={location.pathname}>
|
|
<Chat2Link />
|
|
</Suspense>
|
|
</PrivateRoute>
|
|
}
|
|
/>
|
|
<Route path='*' element={<NotFound />} />
|
|
</Routes>
|
|
</SetupCheck>
|
|
);
|
|
}
|
|
|
|
export default App;
|