mirror of
https://github.com/SigNoz/signoz.git
synced 2025-12-27 15:18:08 +00:00
* chore: add constants for AWS Integration UI event names * chore: log event for account viewed and account connection attempt started * chore: log telemetry event on successful account connection * chore: log telemetry event when an account connection attempt times out * chore: log telemetry event on redirecting to AWS for account connection * chore: log telemetry event on opening account settings * chore: log telemetry event on saving account settings * chore: log telemetry event on removing account * chore: log telemetry event on viewing details of a service * chore: log telemetry event on opening service settings * chore: log telemetry event on saving service settings * chore: some cleanup * chore: address PR comment * chore: minor cleanup
148 lines
3.9 KiB
TypeScript
148 lines
3.9 KiB
TypeScript
import { Form } from 'antd';
|
|
import { FormInstance } from 'antd/lib';
|
|
import { CloudAccount } from 'container/CloudIntegrationPage/ServicesSection/types';
|
|
import { useUpdateAccountConfig } from 'hooks/integration/aws/useUpdateAccountConfig';
|
|
import { isEqual } from 'lodash-es';
|
|
import {
|
|
Dispatch,
|
|
SetStateAction,
|
|
useCallback,
|
|
useEffect,
|
|
useMemo,
|
|
useState,
|
|
} from 'react';
|
|
import { AccountConfigPayload } from 'types/api/integrations/aws';
|
|
import { regions } from 'utils/regions';
|
|
|
|
import logEvent from '../../../api/common/logEvent';
|
|
|
|
interface UseAccountSettingsModalProps {
|
|
onClose: () => void;
|
|
account: CloudAccount;
|
|
setActiveAccount: Dispatch<SetStateAction<CloudAccount | null>>;
|
|
}
|
|
|
|
interface UseAccountSettingsModal {
|
|
form: FormInstance;
|
|
isLoading: boolean;
|
|
selectedRegions: string[];
|
|
includeAllRegions: boolean;
|
|
isRegionSelectOpen: boolean;
|
|
isSaveDisabled: boolean;
|
|
setSelectedRegions: Dispatch<SetStateAction<string[]>>;
|
|
setIncludeAllRegions: Dispatch<SetStateAction<boolean>>;
|
|
setIsRegionSelectOpen: Dispatch<SetStateAction<boolean>>;
|
|
handleIncludeAllRegionsChange: (checked: boolean) => void;
|
|
handleSubmit: () => Promise<void>;
|
|
handleClose: () => void;
|
|
}
|
|
|
|
const allRegions = (): string[] =>
|
|
regions.flatMap((r) => r.subRegions.map((sr) => sr.name));
|
|
|
|
const getRegionPreviewText = (regions: string[] | undefined): string[] => {
|
|
if (!regions) return [];
|
|
if (regions.includes('all')) {
|
|
return allRegions();
|
|
}
|
|
return regions;
|
|
};
|
|
|
|
export function useAccountSettingsModal({
|
|
onClose,
|
|
account,
|
|
setActiveAccount,
|
|
}: UseAccountSettingsModalProps): UseAccountSettingsModal {
|
|
const [form] = Form.useForm();
|
|
const { mutate: updateConfig, isLoading } = useUpdateAccountConfig();
|
|
const accountRegions = useMemo(() => account?.config?.regions || [], [
|
|
account?.config?.regions,
|
|
]);
|
|
const [isInitialRegionsSet, setIsInitialRegionsSet] = useState(false);
|
|
|
|
const [selectedRegions, setSelectedRegions] = useState<string[]>([]);
|
|
const [includeAllRegions, setIncludeAllRegions] = useState(false);
|
|
const [isRegionSelectOpen, setIsRegionSelectOpen] = useState(false);
|
|
|
|
// Initialize regions from account when modal opens
|
|
useEffect(() => {
|
|
if (accountRegions.length > 0 && !isInitialRegionsSet) {
|
|
setSelectedRegions(accountRegions);
|
|
setIsInitialRegionsSet(true);
|
|
setIncludeAllRegions(accountRegions.includes('all'));
|
|
}
|
|
}, [accountRegions, isInitialRegionsSet]);
|
|
|
|
const handleSubmit = useCallback(async (): Promise<void> => {
|
|
try {
|
|
await form.validateFields();
|
|
const payload: AccountConfigPayload = {
|
|
config: {
|
|
regions: selectedRegions,
|
|
},
|
|
};
|
|
|
|
updateConfig(
|
|
{ accountId: account?.id, payload },
|
|
{
|
|
onSuccess: (response) => {
|
|
const newActiveAccount = response?.data;
|
|
setActiveAccount(newActiveAccount);
|
|
onClose();
|
|
|
|
logEvent('AWS Integration: Account settings Updated', {
|
|
cloudAccountId: newActiveAccount?.cloud_account_id,
|
|
enabledRegions: newActiveAccount?.config?.regions,
|
|
});
|
|
},
|
|
},
|
|
);
|
|
} catch (error) {
|
|
console.error('Form submission failed:', error);
|
|
}
|
|
}, [
|
|
form,
|
|
selectedRegions,
|
|
updateConfig,
|
|
account?.id,
|
|
setActiveAccount,
|
|
onClose,
|
|
]);
|
|
|
|
const isSaveDisabled = useMemo(
|
|
() => isEqual(selectedRegions.sort(), accountRegions.sort()),
|
|
[selectedRegions, accountRegions],
|
|
);
|
|
|
|
const handleIncludeAllRegionsChange = useCallback((checked: boolean): void => {
|
|
setIncludeAllRegions(checked);
|
|
if (checked) {
|
|
setSelectedRegions(['all']);
|
|
} else {
|
|
setSelectedRegions([]);
|
|
}
|
|
}, []);
|
|
|
|
const handleClose = useCallback(() => {
|
|
setIsRegionSelectOpen(false);
|
|
onClose();
|
|
}, [onClose]);
|
|
|
|
return {
|
|
form,
|
|
isLoading,
|
|
selectedRegions,
|
|
includeAllRegions,
|
|
isRegionSelectOpen,
|
|
isSaveDisabled,
|
|
setSelectedRegions,
|
|
setIncludeAllRegions,
|
|
setIsRegionSelectOpen,
|
|
handleIncludeAllRegionsChange,
|
|
handleSubmit,
|
|
handleClose,
|
|
};
|
|
}
|
|
|
|
export { getRegionPreviewText };
|