mirror of
https://github.com/twentyhq/twenty
synced 2026-04-21 21:47:38 +00:00
## Summary This PR upgrades Apollo Client from v3.10.0 to v4 and refactors error handling patterns across the codebase to use a new centralized `useSnackBarOnQueryError` hook. ## Key Changes - **Dependency Update**: Upgraded `@apollo/client` from `^3.10.0` to `^3.11.0` in root package.json - **New Hook**: Added `useSnackBarOnQueryError` hook for centralized Apollo query error handling with snack bar notifications - **Error Handling Refactor**: Updated 100+ files to use the new error handling pattern: - Removed direct `ApolloError` imports where no longer needed - Replaced manual error handling logic with `useSnackBarOnQueryError` hook - Simplified error handling in hooks and components across multiple modules - **GraphQL Codegen**: Updated codegen configuration files to work with Apollo Client v3.11.0 - **Type Definitions**: Added TypeScript declaration file for `apollo-upload-client` module - **Test Updates**: Updated test files to reflect new error handling patterns ## Notable Implementation Details - The new `useSnackBarOnQueryError` hook provides a consistent way to handle Apollo query errors with automatic snack bar notifications - Changes span across multiple feature areas: auth, object records, settings, workflows, billing, and more - All changes maintain backward compatibility while improving code maintainability and reducing duplication - Jest configuration updated to work with the new Apollo Client version https://claude.ai/code/session_019WGZ6Rd7sEHuBg9sTrXRqJ --------- Co-authored-by: Claude <noreply@anthropic.com>
24 lines
738 B
TypeScript
24 lines
738 B
TypeScript
import { GET_LOGIC_FUNCTION_SOURCE_CODE } from '@/logic-functions/graphql/queries/getLogicFunctionSourceCode';
|
|
import { useQuery } from '@apollo/client/react';
|
|
import {
|
|
type GetLogicFunctionSourceCodeQuery,
|
|
type GetLogicFunctionSourceCodeQueryVariables,
|
|
} from '~/generated-metadata/graphql';
|
|
|
|
export const useGetLogicFunctionSourceCode = ({
|
|
logicFunctionId,
|
|
}: {
|
|
logicFunctionId: string;
|
|
}) => {
|
|
const { data, loading } = useQuery<
|
|
GetLogicFunctionSourceCodeQuery,
|
|
GetLogicFunctionSourceCodeQueryVariables
|
|
>(GET_LOGIC_FUNCTION_SOURCE_CODE, {
|
|
variables: {
|
|
input: { id: logicFunctionId },
|
|
},
|
|
skip: !logicFunctionId,
|
|
});
|
|
|
|
return { sourceHandlerCode: data?.getLogicFunctionSourceCode, loading };
|
|
};
|