Skip to content

Commit

Permalink
misc: implemened more review comments
Browse files Browse the repository at this point in the history
  • Loading branch information
sheensantoscapadngan committed Jul 1, 2024
1 parent 7d7612a commit 1eb9ea9
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 26 deletions.
20 changes: 12 additions & 8 deletions frontend/src/layouts/AppLayout/AppLayout.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,7 @@ import {
useRegisterUserAction,
useSelectOrganization
} from "@app/hooks/api";
import { Workspace } from "@app/hooks/api/types";
import { useUpdateUserProjectFavorites } from "@app/hooks/api/users/mutation";
import { useGetUserProjectFavorites } from "@app/hooks/api/users/queries";
import { navigateUserToOrg } from "@app/views/Login/Login.utils";
Expand Down Expand Up @@ -129,11 +130,14 @@ export const AppLayout = ({ children }: LayoutProps) => {
const { data: projectFavorites } = useGetUserProjectFavorites(currentOrg?.id!);
const { mutateAsync: updateUserProjectFavorites } = useUpdateUserProjectFavorites();

const workspaceList = useMemo(
() => [
...workspaces.filter((w) => projectFavorites?.includes(w.id)),
...workspaces.filter((w) => !projectFavorites?.includes(w.id))
],
const workspacesWithFaveProp = useMemo(
() =>
workspaces
.map((w): Workspace & { isFavorite: boolean } => ({
...w,
isFavorite: Boolean(projectFavorites?.includes(w.id))
}))
.sort((a, b) => Number(b.isFavorite) - Number(a.isFavorite)),
[workspaces, projectFavorites]
);

Expand Down Expand Up @@ -498,9 +502,9 @@ export const AppLayout = ({ children }: LayoutProps) => {
dropdownContainerClassName="text-bunker-200 bg-mineshaft-800 border border-mineshaft-600 z-50 max-h-96 border-gray-700"
>
<div className="no-scrollbar::-webkit-scrollbar h-full no-scrollbar">
{workspaceList
{workspacesWithFaveProp
.filter((ws) => ws.orgId === currentOrg?.id)
.map(({ id, name }) => (
.map(({ id, name, isFavorite }) => (
<div
className={twMerge(
"mb-1 grid grid-cols-7 rounded-md hover:bg-mineshaft-500",
Expand All @@ -518,7 +522,7 @@ export const AppLayout = ({ children }: LayoutProps) => {
</SelectItem>
</div>
<div className="col-span-1 flex items-center">
{projectFavorites?.includes(id) ? (
{isFavorite ? (
<FontAwesomeIcon
icon={faSolidStar}
className="text-sm text-mineshaft-300 hover:text-mineshaft-400"
Expand Down
39 changes: 21 additions & 18 deletions frontend/src/pages/org/[id]/overview/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -493,6 +493,7 @@ const OrganizationPage = withPermission(
useGetUserProjectFavorites(currentOrg?.id!);
const { mutateAsync: updateUserProjectFavorites } = useUpdateUserProjectFavorites();

const isProjectViewLoading = isWorkspaceLoading || isProjectFavoritesLoading;
const addUsersToProject = useAddUserToWsNonE2EE();

const { popUp, handlePopUpOpen, handlePopUpClose, handlePopUpToggle } = usePopUp([
Expand Down Expand Up @@ -577,19 +578,23 @@ const OrganizationPage = withPermission(
ws?.name?.toLowerCase().includes(searchFilter.toLowerCase())
);

const workspacesWithFaveProp = useMemo(
() =>
filteredWorkspaces
.map((w): Workspace & { isFavorite: boolean } => ({
...w,
isFavorite: Boolean(projectFavorites?.includes(w.id))
}))
.sort((a, b) => Number(b.isFavorite) - Number(a.isFavorite)),
[filteredWorkspaces, projectFavorites]
);
const { workspacesWithFaveProp, favoriteWorkspaces, nonFavoriteWorkspaces } = useMemo(() => {
const workspacesWithFav = filteredWorkspaces
.map((w): Workspace & { isFavorite: boolean } => ({
...w,
isFavorite: Boolean(projectFavorites?.includes(w.id))
}))
.sort((a, b) => Number(b.isFavorite) - Number(a.isFavorite));

const favWorkspaces = workspacesWithFav.filter((w) => w.isFavorite);
const nonFavWorkspaces = workspacesWithFav.filter((w) => !w.isFavorite);

const favoriteWorkspaces = workspacesWithFaveProp.filter((w) => w.isFavorite);
const nonFavoriteWorkspaces = workspacesWithFaveProp.filter((w) => !w.isFavorite);
return {
workspacesWithFaveProp: workspacesWithFav,
favoriteWorkspaces: favWorkspaces,
nonFavoriteWorkspaces: nonFavWorkspaces
};
}, [filteredWorkspaces, projectFavorites]);

const addProjectToFavorites = async (projectId: string) => {
try {
Expand Down Expand Up @@ -728,7 +733,7 @@ const OrganizationPage = withPermission(
</>
)}
<div className="mt-4 grid w-full grid-cols-1 gap-4 lg:grid-cols-2 xl:grid-cols-3 2xl:grid-cols-4">
{(isWorkspaceLoading || isProjectFavoritesLoading) &&
{isProjectViewLoading &&
Array.apply(0, Array(3)).map((_x, i) => (
<div
key={`workspace-cards-loading-${i + 1}`}
Expand All @@ -745,16 +750,15 @@ const OrganizationPage = withPermission(
</div>
</div>
))}
{!isProjectFavoritesLoading &&
!isWorkspaceLoading &&
{!isProjectViewLoading &&
nonFavoriteWorkspaces.map((workspace) => renderProjectGridItem(workspace, false))}
</div>
</>
);

const projectsListView = (
<div className="mt-4 w-full rounded-md">
{(isWorkspaceLoading || isProjectFavoritesLoading) &&
{isProjectViewLoading &&
Array.apply(0, Array(3)).map((_x, i) => (
<div
key={`workspace-cards-loading-${i + 1}`}
Expand All @@ -765,8 +769,7 @@ const OrganizationPage = withPermission(
<Skeleton className="w-full bg-mineshaft-600" />
</div>
))}
{!isProjectFavoritesLoading &&
!isWorkspaceLoading &&
{!isProjectViewLoading &&
workspacesWithFaveProp.map((workspace, ind) =>
renderProjectListItem(workspace, workspace.isFavorite, ind)
)}
Expand Down

0 comments on commit 1eb9ea9

Please sign in to comment.