mirror of https://github.com/msgbyte/tailchat
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.
94 lines
2.9 KiB
TypeScript
94 lines
2.9 KiB
TypeScript
import { AllPermission, permissionList } from 'tailchat-shared';
|
|
import { Button, Divider } from 'antd';
|
|
import React, { useCallback, useMemo } from 'react';
|
|
import { model, t } from 'tailchat-shared';
|
|
import { PermissionItem } from '../PermissionItem';
|
|
import { useModifyPermission } from '../useModifyPermission';
|
|
import { pluginPermission } from '@/plugin/common';
|
|
|
|
interface RolePermissionProps {
|
|
roleId: typeof AllPermission | string;
|
|
currentRoleInfo?: model.group.GroupRole;
|
|
fallbackPermissions: string[];
|
|
onSavePermission: (permissions: string[]) => Promise<void>;
|
|
}
|
|
export const RolePermission: React.FC<RolePermissionProps> = React.memo(
|
|
(props) => {
|
|
const currentRolePermissions: string[] = useMemo(() => {
|
|
if (props.roleId === AllPermission) {
|
|
return props.fallbackPermissions;
|
|
}
|
|
|
|
return props.currentRoleInfo?.permissions ?? [];
|
|
}, [props.roleId, props.fallbackPermissions, props.currentRoleInfo]);
|
|
|
|
const {
|
|
isEditing,
|
|
editingPermission,
|
|
setEditingPermission,
|
|
handleSwitchPermission,
|
|
} = useModifyPermission(currentRolePermissions);
|
|
|
|
const handleResetPermission = useCallback(() => {
|
|
setEditingPermission(
|
|
permissionList.filter((p) => p.default === true).map((p) => p.key)
|
|
);
|
|
}, []);
|
|
|
|
// 权限概述
|
|
return (
|
|
<div>
|
|
<div className="mb-2 space-x-2 text-right">
|
|
<Button onClick={handleResetPermission}>{t('重置为默认值')}</Button>
|
|
<Button
|
|
type="primary"
|
|
disabled={!isEditing}
|
|
onClick={() => props.onSavePermission(editingPermission)}
|
|
>
|
|
{t('保存')}
|
|
</Button>
|
|
</div>
|
|
|
|
{/* 权限详情 */}
|
|
{permissionList.map((p) => (
|
|
<PermissionItem
|
|
key={p.key}
|
|
title={p.title}
|
|
desc={p.desc}
|
|
disabled={
|
|
p.required
|
|
? !p.required.every((r) => editingPermission.includes(r))
|
|
: undefined
|
|
}
|
|
checked={editingPermission.includes(p.key)}
|
|
onChange={(checked) => handleSwitchPermission(p.key, checked)}
|
|
/>
|
|
))}
|
|
|
|
{pluginPermission.length > 0 && (
|
|
<>
|
|
<Divider>{t('以下为插件权限')}</Divider>
|
|
|
|
{/* 权限详情 */}
|
|
{pluginPermission.map((p) => (
|
|
<PermissionItem
|
|
key={p.key}
|
|
title={p.title}
|
|
desc={p.desc}
|
|
disabled={
|
|
p.required
|
|
? !p.required.every((r) => editingPermission.includes(r))
|
|
: undefined
|
|
}
|
|
checked={editingPermission.includes(p.key)}
|
|
onChange={(checked) => handleSwitchPermission(p.key, checked)}
|
|
/>
|
|
))}
|
|
</>
|
|
)}
|
|
</div>
|
|
);
|
|
}
|
|
);
|
|
RolePermission.displayName = 'RolePermission';
|