Fix Infinite loop on invite route (#2866)

This commit is contained in:
Charles Bochet
2023-12-07 19:26:07 +01:00
committed by GitHub
parent 5efc2f00b9
commit 6c83953633
5 changed files with 93 additions and 72 deletions

View File

@ -47,7 +47,9 @@ export const PageChangeEffect = () => {
} else {
return;
}
}, [location, previousLocation]);
useEffect(() => {
const isMachinOngoingUserCreationRoute =
isMatchingLocation(AppPath.SignUp) ||
isMatchingLocation(AppPath.SignIn) ||
@ -108,7 +110,16 @@ export const PageChangeEffect = () => {
},
});
}
}, [
enqueueSnackBar,
isMatchingLocation,
location.pathname,
navigate,
onboardingStatus,
workspaceFromInviteHashQuery,
]);
useEffect(() => {
switch (true) {
case isMatchingLocation(AppPath.RecordTablePage): {
setHotkeyScope(TableHotkeyScope.Table, {
@ -177,7 +188,9 @@ export const PageChangeEffect = () => {
break;
}
}
}, [isMatchingLocation, setHotkeyScope]);
useEffect(() => {
setToIntitialCommandMenu();
addToCommandMenu([
@ -190,7 +203,9 @@ export const PageChangeEffect = () => {
onCommandClick: () => openCreateActivity({ type: 'Task' }),
},
]);
}, [addToCommandMenu, setToIntitialCommandMenu, openCreateActivity]);
useEffect(() => {
setTimeout(() => {
eventTracker('pageview', {
location: {
@ -198,20 +213,7 @@ export const PageChangeEffect = () => {
},
});
}, 500);
}, [
onboardingStatus,
navigate,
isMatchingLocation,
setHotkeyScope,
location,
previousLocation,
eventTracker,
workspaceFromInviteHashQuery,
enqueueSnackBar,
addToCommandMenu,
openCreateActivity,
setToIntitialCommandMenu,
]);
}, [eventTracker, location.pathname]);
return <></>;
};

View File

@ -1,3 +1,4 @@
import { useCallback } from 'react';
import { matchPath, useLocation } from 'react-router-dom';
import { parse } from 'url';
@ -6,11 +7,14 @@ import { AppBasePath } from '@/types/AppBasePath';
export const useIsMatchingLocation = () => {
const location = useLocation();
return (path: string, basePath?: AppBasePath) => {
const constructedPath = basePath
? parse(`${basePath}/${path}`).pathname ?? ''
: path;
return useCallback(
(path: string, basePath?: AppBasePath) => {
const constructedPath = basePath
? parse(`${basePath}/${path}`).pathname ?? ''
: path;
return !!matchPath(constructedPath, location.pathname);
};
return !!matchPath(constructedPath, location.pathname);
},
[location.pathname],
);
};

View File

@ -1,3 +1,4 @@
import { useCallback } from 'react';
import { isNonEmptyString } from '@sniptt/guards';
import { useRecoilState, useRecoilValue } from 'recoil';
@ -32,47 +33,55 @@ export const useOpenCreateActivityDrawer = () => {
);
const [, setViewableActivityId] = useRecoilState(viewableActivityIdState);
return async ({
type,
targetableEntities,
assigneeId,
}: {
type: ActivityType;
targetableEntities?: ActivityTargetableEntity[];
assigneeId?: string;
}) => {
const targetableEntitiesWithRelations = targetableEntities
? getTargetableEntitiesWithParents(targetableEntities)
: [];
return useCallback(
async ({
type,
targetableEntities,
assigneeId,
}: {
type: ActivityType;
targetableEntities?: ActivityTargetableEntity[];
assigneeId?: string;
}) => {
const targetableEntitiesWithRelations = targetableEntities
? getTargetableEntitiesWithParents(targetableEntities)
: [];
const createdActivity = await createOneActivity?.({
authorId: currentWorkspaceMember?.id,
assigneeId:
assigneeId ?? isNonEmptyString(currentWorkspaceMember?.id)
? currentWorkspaceMember?.id
: undefined,
type: type,
});
const createdActivity = await createOneActivity?.({
authorId: currentWorkspaceMember?.id,
assigneeId:
assigneeId ?? isNonEmptyString(currentWorkspaceMember?.id)
? currentWorkspaceMember?.id
: undefined,
type: type,
});
if (!createdActivity) {
return;
}
if (!createdActivity) {
return;
}
await Promise.all(
targetableEntitiesWithRelations.map(async (targetableEntity) => {
await createOneActivityTarget?.({
companyId:
targetableEntity.type === 'Company' ? targetableEntity.id : null,
personId:
targetableEntity.type === 'Person' ? targetableEntity.id : null,
activityId: createdActivity.id,
});
}),
);
await Promise.all(
targetableEntitiesWithRelations.map(async (targetableEntity) => {
await createOneActivityTarget?.({
companyId:
targetableEntity.type === 'Company' ? targetableEntity.id : null,
personId:
targetableEntity.type === 'Person' ? targetableEntity.id : null,
activityId: createdActivity.id,
});
}),
);
setHotkeyScope(RightDrawerHotkeyScope.RightDrawer, { goto: false });
setViewableActivityId(createdActivity.id);
setActivityTargetableEntityArray(targetableEntities ?? []);
openRightDrawer(RightDrawerPages.CreateActivity);
};
setHotkeyScope(RightDrawerHotkeyScope.RightDrawer, { goto: false });
setViewableActivityId(createdActivity.id);
setActivityTargetableEntityArray(targetableEntities ?? []);
openRightDrawer(RightDrawerPages.CreateActivity);
},
[
openRightDrawer,
setActivityTargetableEntityArray,
setHotkeyScope,
setViewableActivityId,
],
);
};

View File

@ -1,3 +1,4 @@
import { useCallback } from 'react';
import { useRecoilCallback, useSetRecoilState } from 'recoil';
import { usePreviousHotkeyScope } from '@/ui/utilities/hotkey/hooks/usePreviousHotkeyScope';
@ -38,9 +39,12 @@ export const useCommandMenu = () => {
}
});
const addToCommandMenu = (addCommand: Command[]) => {
setCommands((prev) => [...prev, ...addCommand]);
};
const addToCommandMenu = useCallback(
(addCommand: Command[]) => {
setCommands((prev) => [...prev, ...addCommand]);
},
[setCommands],
);
const setToIntitialCommandMenu = () => {
setCommands(commandMenuCommands);

View File

@ -1,3 +1,4 @@
import { useCallback } from 'react';
import { useRecoilCallback } from 'recoil';
import { v4 as uuidv4 } from 'uuid';
@ -36,18 +37,19 @@ export const useSnackBar = () => {
queue: [...prev.queue, newValue] as SnackBarOptions[],
};
}),
[scopeId],
);
const enqueueSnackBar = (
message: string,
options?: Omit<SnackBarOptions, 'message' | 'id'>,
) => {
setSnackBarQueue({
id: uuidv4(),
message,
...options,
});
};
const enqueueSnackBar = useCallback(
(message: string, options?: Omit<SnackBarOptions, 'message' | 'id'>) => {
setSnackBarQueue({
id: uuidv4(),
message,
...options,
});
},
[setSnackBarQueue],
);
return { handleSnackBarClose, enqueueSnackBar };
};