You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tailchat/server/admin/app/ra/App.tsx

97 lines
2.6 KiB
TypeScript

import {
Admin,
Resource,
fetchUtils,
ShowGuesser,
CustomRoutes,
} from 'react-admin';
import jsonServerProvider from 'ra-data-json-server';
import { authProvider, authStorageKey } from './authProvider';
import { UserList } from './resources/user';
import React from 'react';
import { GroupList } from './resources/group';
import { MessageList } from './resources/chat';
import { FileList } from './resources/file';
import PersonIcon from '@mui/icons-material/Person';
import MessageIcon from '@mui/icons-material/Message';
import GroupIcon from '@mui/icons-material/Group';
import AttachFileIcon from '@mui/icons-material/AttachFile';
import { theme } from './theme';
import { Dashboard } from './dashboard';
import { Route } from 'react-router-dom';
import { TailchatNetwork } from './network';
import { TailchatLayout } from './layout';
import polyglotI18nProvider from 'ra-i18n-polyglot';
import chineseMessages from 'ra-language-chinese';
const i18nProvider = polyglotI18nProvider(() => chineseMessages, 'ch');
const httpClient: typeof fetchUtils.fetchJson = (url, options = {}) => {
try {
if (!options.headers) {
options.headers = new Headers({ Accept: 'application/json' });
}
const { token } = JSON.parse(
window.localStorage.getItem(authStorageKey) ?? '{}'
);
(options.headers as Headers).set('Authorization', `Bearer ${token}`);
return fetchUtils.fetchJson(url, options);
} catch (err) {
return Promise.reject();
}
};
const dataProvider = jsonServerProvider(
// 'https://jsonplaceholder.typicode.com'
'/admin/api',
httpClient
);
export const App = () => (
<Admin
basename="/admin"
theme={theme}
dashboard={Dashboard}
layout={TailchatLayout}
disableTelemetry={true}
authProvider={authProvider}
dataProvider={dataProvider}
requireAuth={true}
i18nProvider={i18nProvider}
>
<Resource
icon={PersonIcon}
name="users"
options={{ label: '用户管理' }}
list={UserList}
show={ShowGuesser}
/>
<Resource
icon={MessageIcon}
name="messages"
options={{ label: '聊天信息' }}
list={MessageList}
show={ShowGuesser}
/>
<Resource
icon={GroupIcon}
name="groups"
options={{ label: '群组' }}
list={GroupList}
show={ShowGuesser}
/>
<Resource
icon={AttachFileIcon}
name="file"
options={{ label: '文件' }}
list={FileList}
show={ShowGuesser}
/>
<CustomRoutes>
<Route path="/network" element={<TailchatNetwork />} />
</CustomRoutes>
</Admin>
);