fix: disable add connection button for unauthorized users

This commit is contained in:
kasia.oczkowska
2024-04-12 13:12:22 +01:00
parent f482c2422c
commit d49bb4c52d
2 changed files with 32 additions and 4 deletions

View File

@@ -19,6 +19,7 @@ import AddIcon from '@mui/icons-material/Add';
import useFormatMessage from 'hooks/useFormatMessage';
import useAppConfig from 'hooks/useAppConfig.ee';
import useCurrentUserAbility from 'hooks/useCurrentUserAbility';
import * as URLS from 'config/urls';
import SplitButton from 'components/SplitButton';
import ConditionalIconButton from 'components/ConditionalIconButton';
@@ -62,6 +63,8 @@ export default function Application() {
const { data: appConfig } = useAppConfig(appKey);
const connectionId = searchParams.get('connectionId') || undefined;
const currentUserAbility = useCurrentUserAbility();
const goToApplicationPage = () => navigate('connections');
const connectionOptions = React.useMemo(() => {
@@ -74,6 +77,7 @@ export default function Application() {
key: 'addConnection',
'data-test': 'add-connection-button',
to: URLS.APP_ADD_CONNECTION(appKey, appConfig?.data?.canConnect),
disabled: !currentUserAbility.can('create', 'Connection'),
},
];
@@ -83,11 +87,12 @@ export default function Application() {
key: 'addCustomConnection',
'data-test': 'add-custom-connection-button',
to: URLS.APP_ADD_CONNECTION(appKey),
disabled: !currentUserAbility.can('create', 'Connection'),
});
}
return options;
}, [appKey, appConfig?.data]);
}, [appKey, appConfig?.data, currentUserAbility]);
if (loading) return null;
@@ -136,9 +141,10 @@ export default function Application() {
element={
<SplitButton
disabled={
appConfig?.data &&
!appConfig?.data?.canConnect &&
!appConfig?.data?.canCustomConnect
(appConfig?.data &&
!appConfig?.data?.canConnect &&
!appConfig?.data?.canCustomConnect) ||
connectionOptions.every(({ disabled }) => disabled)
}
options={connectionOptions}
/>