Adjust styles to match the design system (#11118)

### What problem does this PR solve?

- Modify and adjust styles (CSS vars, components) to match the design
system
- Adjust file and directory structure of admin UI

### Type of change

- [x] Refactoring
This commit is contained in:
Jimmy Ben Klieve
2025-11-10 10:05:19 +08:00
committed by GitHub
parent 660386d3b5
commit 1cd54832b5
42 changed files with 685 additions and 539 deletions

View File

@ -40,8 +40,7 @@ import {
DialogHeader,
DialogTitle,
} from '@/components/ui/dialog';
import { Input } from '@/components/ui/input';
import { LoadingButton } from '@/components/ui/loading-button';
import { SearchInput } from '@/components/ui/input';
import { RAGFlowPagination } from '@/components/ui/ragflow-pagination';
import { ScrollArea } from '@/components/ui/scroll-area';
import {
@ -63,6 +62,7 @@ import {
import { EMPTY_DATA, createFuzzySearchFn, getSortIcon } from './utils';
import dayjs from 'dayjs';
import useCreateEmailForm from './forms/email-form';
import useImportExcelForm, {
ImportExcelFormData,
@ -157,18 +157,14 @@ function AdminWhitelist() {
email: item.email,
}));
const now = new Date();
const YYYY = String(now.getFullYear()).padStart(4, '0');
const MM = String(now.getMonth()).padStart(2, '0');
const dd = String(now.getDate()).padStart(2, '0');
const HH = String(now.getHours()).padStart(2, '0');
const mm = String(now.getMinutes()).padStart(2, '0');
const ss = String(now.getSeconds()).padStart(2, '0');
const worksheet = XLSX.utils.json_to_sheet(columnData);
const workbook = XLSX.utils.book_new();
XLSX.utils.book_append_sheet(workbook, worksheet, 'Sheet1');
XLSX.writeFile(workbook, `whitelist_${YYYY}${MM}${dd}${HH}${mm}${ss}.xlsx`);
XLSX.writeFile(
workbook,
`whitelist_${dayjs(new Date()).format('YYYYMMDDHHmmss')}.xlsx`,
);
};
const columnDefs = useMemo(
@ -187,11 +183,11 @@ function AdminWhitelist() {
id: 'actions',
header: t('admin.actions'),
cell: ({ row }) => (
<div className="opacity-0 group-hover:opacity-100 group-focus-within:opacity-100 transition-opacity duration-100">
<div className="opacity-0 group-hover:opacity-100 group-focus-within:opacity-100 transition-opacity">
<Button
variant="transparent"
size="icon"
className="border-0 text-text-secondary"
className="border-0"
onClick={() => {
setItemToMakeAction(row.original);
setEditModalOpen(true);
@ -200,9 +196,9 @@ function AdminWhitelist() {
<LucideUserPen />
</Button>
<Button
variant="transparent"
variant="danger"
size="icon"
className="border-0 text-text-secondary"
className="border-0"
onClick={() => {
setItemToMakeAction(row.original);
setDeleteModalOpen(true);
@ -227,11 +223,13 @@ function AdminWhitelist() {
getSortedRowModel: getSortedRowModel(),
getFilteredRowModel: getFilteredRowModel(),
getPaginationRowModel: getPaginationRowModel(),
enableSorting: false,
});
return (
<>
<Card className="!shadow-none relative h-full border border-border-button bg-transparent rounded-xl overflow-x-hidden overflow-y-auto">
<Card className="!shadow-none relative h-full border-0.5 border-border-button bg-transparent rounded-xl overflow-x-hidden overflow-y-auto">
<Spotlight />
<ScrollArea className="size-full">
@ -239,15 +237,13 @@ function AdminWhitelist() {
<CardTitle>{t('admin.whitelistManagement')}</CardTitle>
<div className="flex items-center gap-4">
<div className="relative w-56">
<LucideSearch className="absolute left-3 top-1/2 transform -translate-y-1/2 text-gray-400 h-4 w-4" />
<Input
className="pl-10 h-10 bg-bg-input border-border-button"
placeholder={t('header.search')}
value={table.getState().globalFilter}
onChange={(e) => table.setGlobalFilter(e.target.value)}
/>
</div>
<SearchInput
className="w-56 h-10 bg-bg-input border-border-button"
placeholder={t('header.search')}
value={table.getState().globalFilter}
onChange={(e) => table.setGlobalFilter(e.target.value)}
prefix={<LucideSearch className="size-3.5" />}
/>
<Button
variant="outline"
@ -272,7 +268,7 @@ function AdminWhitelist() {
onClick={() => setCreateModalOpen(true)}
>
<LucidePlus />
{t('admin.createEmail')}
{t('admin.newUser')}
</Button>
</div>
</CardHeader>
@ -360,18 +356,18 @@ function AdminWhitelist() {
}
}}
>
<DialogHeader className="p-6 border-b border-border-button">
<DialogHeader className="p-6 border-b-0.5 border-border-button">
<DialogTitle>{t('admin.deleteEmail')}</DialogTitle>
</DialogHeader>
<section className="px-12 py-4">
<DialogDescription className="text-text-primary">
{t('admin.deleteWhitelistEmailConfirmation')}
<div className="rounded-lg mt-6 p-4 border border-border-button">
{itemToMakeAction?.email}
</div>
</DialogDescription>
<div className="rounded-lg mt-6 p-4 border-0.5 border-border-button">
{itemToMakeAction?.email}
</div>
</section>
<DialogFooter className="flex justify-end gap-4 px-12 pt-4 pb-8">
@ -384,7 +380,7 @@ function AdminWhitelist() {
{t('admin.cancel')}
</Button>
<LoadingButton
<Button
className="px-4 h-10"
variant="destructive"
onClick={() => {
@ -398,7 +394,7 @@ function AdminWhitelist() {
loading={deleteWhitelistEntryMutation.isPending}
>
{t('admin.delete')}
</LoadingButton>
</Button>
</DialogFooter>
</DialogContent>
</Dialog>
@ -413,7 +409,7 @@ function AdminWhitelist() {
}
}}
>
<DialogHeader className="p-6 border-b border-border-button">
<DialogHeader className="p-6 border-b-0.5 border-border-button">
<DialogTitle>{t('admin.createEmail')}</DialogTitle>
</DialogHeader>
@ -434,7 +430,7 @@ function AdminWhitelist() {
{t('admin.cancel')}
</Button>
<LoadingButton
<Button
form={createEmailForm.id}
type="submit"
className="px-4 h-10"
@ -443,7 +439,7 @@ function AdminWhitelist() {
loading={createWhitelistEntryMutation.isPending}
>
{t('admin.confirm')}
</LoadingButton>
</Button>
</DialogFooter>
</DialogContent>
</Dialog>
@ -459,7 +455,7 @@ function AdminWhitelist() {
}
}}
>
<DialogHeader className="p-6 border-b border-border-button">
<DialogHeader className="p-6 border-b-0.5 border-border-button">
<DialogTitle>{t('admin.editEmail')}</DialogTitle>
</DialogHeader>
@ -487,7 +483,7 @@ function AdminWhitelist() {
{t('admin.cancel')}
</Button>
<LoadingButton
<Button
form={editEmailForm.id}
type="submit"
className="px-4 h-10"
@ -496,7 +492,7 @@ function AdminWhitelist() {
loading={updateWhitelistEntryMutation.isPending}
>
{t('admin.confirm')}
</LoadingButton>
</Button>
</DialogFooter>
</DialogContent>
</Dialog>
@ -511,7 +507,7 @@ function AdminWhitelist() {
}
}}
>
<DialogHeader className="p-6 border-b border-border-button">
<DialogHeader className="p-6 border-b-0.5 border-border-button">
<DialogTitle>{t('admin.importWhitelist')}</DialogTitle>
</DialogHeader>
@ -532,7 +528,7 @@ function AdminWhitelist() {
{t('admin.cancel')}
</Button>
<LoadingButton
<Button
form={importExcelForm.id}
type="submit"
className="px-4 h-10"
@ -541,7 +537,7 @@ function AdminWhitelist() {
loading={importExcelMutation.isPending}
>
{t('admin.import')}
</LoadingButton>
</Button>
</DialogFooter>
</DialogContent>
</Dialog>