[WEB-1986] fix: remove the user favourites when archived a particular entity (#5388)
* chore: pages custom error codes * fix: project archive issue * fix: delete issue + dropdown z-index fix * fix: import issue --------- Co-authored-by: NarayanBavisetti <narayan3119@gmail.com>
This commit is contained in:
parent
f789c72cac
commit
5fc99c9ce5
8 changed files with 71 additions and 88 deletions
|
|
@ -88,7 +88,7 @@ export const MemberOptions = observer((props: Props) => {
|
||||||
return createPortal(
|
return createPortal(
|
||||||
<Combobox.Options data-prevent-outside-click static>
|
<Combobox.Options data-prevent-outside-click static>
|
||||||
<div
|
<div
|
||||||
className="my-1 w-48 rounded border-[0.5px] border-custom-border-300 bg-custom-background-100 px-2 py-2.5 text-xs shadow-custom-shadow-rg focus:outline-none z-20"
|
className="my-1 w-48 rounded border-[0.5px] border-custom-border-300 bg-custom-background-100 px-2 py-2.5 text-xs shadow-custom-shadow-rg focus:outline-none z-[19]"
|
||||||
ref={setPopperElement}
|
ref={setPopperElement}
|
||||||
style={{
|
style={{
|
||||||
...styles.popper,
|
...styles.popper,
|
||||||
|
|
|
||||||
|
|
@ -5,6 +5,7 @@ import { combine } from "@atlaskit/pragmatic-drag-and-drop/combine";
|
||||||
import { draggable, dropTargetForElements } from "@atlaskit/pragmatic-drag-and-drop/element/adapter";
|
import { draggable, dropTargetForElements } from "@atlaskit/pragmatic-drag-and-drop/element/adapter";
|
||||||
|
|
||||||
import { attachClosestEdge, extractClosestEdge } from "@atlaskit/pragmatic-drag-and-drop-hitbox/closest-edge";
|
import { attachClosestEdge, extractClosestEdge } from "@atlaskit/pragmatic-drag-and-drop-hitbox/closest-edge";
|
||||||
|
import uniqBy from "lodash/uniqBy";
|
||||||
import { useParams } from "next/navigation";
|
import { useParams } from "next/navigation";
|
||||||
import { PenSquare, Star, MoreHorizontal, ChevronRight, GripVertical } from "lucide-react";
|
import { PenSquare, Star, MoreHorizontal, ChevronRight, GripVertical } from "lucide-react";
|
||||||
import { Disclosure, Transition } from "@headlessui/react";
|
import { Disclosure, Transition } from "@headlessui/react";
|
||||||
|
|
@ -37,7 +38,7 @@ export const FavoriteFolder: React.FC<Props> = (props) => {
|
||||||
const { sidebarCollapsed: isSidebarCollapsed } = useAppTheme();
|
const { sidebarCollapsed: isSidebarCollapsed } = useAppTheme();
|
||||||
|
|
||||||
const { isMobile } = usePlatformOS();
|
const { isMobile } = usePlatformOS();
|
||||||
const { moveFavorite, getGroupedFavorites, favoriteMap, moveFavoriteFolder } = useFavorite();
|
const { moveFavorite, getGroupedFavorites, groupedFavorites, moveFavoriteFolder } = useFavorite();
|
||||||
const { workspaceSlug } = useParams();
|
const { workspaceSlug } = useParams();
|
||||||
// states
|
// states
|
||||||
const [isMenuActive, setIsMenuActive] = useState(false);
|
const [isMenuActive, setIsMenuActive] = useState(false);
|
||||||
|
|
@ -110,7 +111,9 @@ export const FavoriteFolder: React.FC<Props> = (props) => {
|
||||||
const edge = extractClosestEdge(destinationData) || undefined;
|
const edge = extractClosestEdge(destinationData) || undefined;
|
||||||
const payload = {
|
const payload = {
|
||||||
id: favorite.id,
|
id: favorite.id,
|
||||||
sequence: Math.round(getDestinationStateSequence(favoriteMap, destinationData.id as string, edge) || 0),
|
sequence: Math.round(
|
||||||
|
getDestinationStateSequence(groupedFavorites, destinationData.id as string, edge) || 0
|
||||||
|
),
|
||||||
};
|
};
|
||||||
|
|
||||||
handleOnDropFolder(payload);
|
handleOnDropFolder(payload);
|
||||||
|
|
@ -146,7 +149,7 @@ export const FavoriteFolder: React.FC<Props> = (props) => {
|
||||||
if (source.data.is_folder) return;
|
if (source.data.is_folder) return;
|
||||||
if (sourceId === destinationId) return;
|
if (sourceId === destinationId) return;
|
||||||
if (!sourceId || !destinationId) return;
|
if (!sourceId || !destinationId) return;
|
||||||
if (favoriteMap[sourceId].parent === destinationId) return;
|
if (groupedFavorites[sourceId].parent === destinationId) return;
|
||||||
handleOnDrop(sourceId, destinationId);
|
handleOnDrop(sourceId, destinationId);
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
@ -313,14 +316,14 @@ export const FavoriteFolder: React.FC<Props> = (props) => {
|
||||||
"px-2": !isSidebarCollapsed,
|
"px-2": !isSidebarCollapsed,
|
||||||
})}
|
})}
|
||||||
>
|
>
|
||||||
{favorite.children.map((child) => (
|
{uniqBy(favorite.children, "id").map((child) => (
|
||||||
<FavoriteRoot
|
<FavoriteRoot
|
||||||
key={child.id}
|
key={child.id}
|
||||||
workspaceSlug={workspaceSlug.toString()}
|
workspaceSlug={workspaceSlug.toString()}
|
||||||
favorite={child}
|
favorite={child}
|
||||||
handleRemoveFromFavorites={handleRemoveFromFavorites}
|
handleRemoveFromFavorites={handleRemoveFromFavorites}
|
||||||
handleRemoveFromFavoritesFolder={handleRemoveFromFavoritesFolder}
|
handleRemoveFromFavoritesFolder={handleRemoveFromFavoritesFolder}
|
||||||
favoriteMap={favoriteMap}
|
favoriteMap={groupedFavorites}
|
||||||
/>
|
/>
|
||||||
))}
|
))}
|
||||||
</Disclosure.Panel>
|
</Disclosure.Panel>
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,7 @@
|
||||||
import React, { useEffect, useRef, useState } from "react";
|
import React, { useEffect, useRef, useState } from "react";
|
||||||
import { combine } from "@atlaskit/pragmatic-drag-and-drop/combine";
|
import { combine } from "@atlaskit/pragmatic-drag-and-drop/combine";
|
||||||
import { dropTargetForElements } from "@atlaskit/pragmatic-drag-and-drop/element/adapter";
|
import { dropTargetForElements } from "@atlaskit/pragmatic-drag-and-drop/element/adapter";
|
||||||
import { orderBy, uniqBy } from "lodash";
|
import orderBy from "lodash/orderBy";
|
||||||
import { observer } from "mobx-react";
|
import { observer } from "mobx-react";
|
||||||
import { useParams } from "next/navigation";
|
import { useParams } from "next/navigation";
|
||||||
import { ChevronRight, FolderPlus } from "lucide-react";
|
import { ChevronRight, FolderPlus } from "lucide-react";
|
||||||
|
|
@ -33,7 +33,7 @@ export const SidebarFavoritesMenu = observer(() => {
|
||||||
|
|
||||||
// store hooks
|
// store hooks
|
||||||
const { sidebarCollapsed } = useAppTheme();
|
const { sidebarCollapsed } = useAppTheme();
|
||||||
const { favoriteIds, favoriteMap, deleteFavorite, removeFromFavoriteFolder } = useFavorite();
|
const { favoriteIds, groupedFavorites, deleteFavorite, removeFromFavoriteFolder } = useFavorite();
|
||||||
const { workspaceSlug } = useParams();
|
const { workspaceSlug } = useParams();
|
||||||
|
|
||||||
const { isMobile } = usePlatformOS();
|
const { isMobile } = usePlatformOS();
|
||||||
|
|
@ -108,7 +108,7 @@ export const SidebarFavoritesMenu = observer(() => {
|
||||||
setIsDragging(false);
|
setIsDragging(false);
|
||||||
const sourceId = source?.data?.id as string | undefined;
|
const sourceId = source?.data?.id as string | undefined;
|
||||||
console.log({ sourceId });
|
console.log({ sourceId });
|
||||||
if (!sourceId || !favoriteMap[sourceId].parent) return;
|
if (!sourceId || !groupedFavorites[sourceId].parent) return;
|
||||||
handleRemoveFromFavoritesFolder(sourceId);
|
handleRemoveFromFavoritesFolder(sourceId);
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
@ -170,14 +170,14 @@ export const SidebarFavoritesMenu = observer(() => {
|
||||||
static
|
static
|
||||||
>
|
>
|
||||||
{createNewFolder && <NewFavoriteFolder setCreateNewFolder={setCreateNewFolder} actionType="create" />}
|
{createNewFolder && <NewFavoriteFolder setCreateNewFolder={setCreateNewFolder} actionType="create" />}
|
||||||
{Object.keys(favoriteMap).length === 0 ? (
|
{Object.keys(groupedFavorites).length === 0 ? (
|
||||||
<>
|
<>
|
||||||
{!sidebarCollapsed && (
|
{!sidebarCollapsed && (
|
||||||
<span className="text-custom-text-400 text-xs text-center font-medium py-1">No favorites yet</span>
|
<span className="text-custom-text-400 text-xs text-center font-medium py-1">No favorites yet</span>
|
||||||
)}
|
)}
|
||||||
</>
|
</>
|
||||||
) : (
|
) : (
|
||||||
uniqBy(orderBy(Object.values(favoriteMap), "sequence", "desc"), "id")
|
orderBy(Object.values(groupedFavorites), "sequence", "desc")
|
||||||
.filter((fav) => !fav.parent)
|
.filter((fav) => !fav.parent)
|
||||||
.map((fav, index) => (
|
.map((fav, index) => (
|
||||||
<Tooltip
|
<Tooltip
|
||||||
|
|
@ -201,7 +201,7 @@ export const SidebarFavoritesMenu = observer(() => {
|
||||||
favorite={fav}
|
favorite={fav}
|
||||||
handleRemoveFromFavorites={handleRemoveFromFavorites}
|
handleRemoveFromFavorites={handleRemoveFromFavorites}
|
||||||
handleRemoveFromFavoritesFolder={handleRemoveFromFavoritesFolder}
|
handleRemoveFromFavoritesFolder={handleRemoveFromFavoritesFolder}
|
||||||
favoriteMap={favoriteMap}
|
favoriteMap={groupedFavorites}
|
||||||
/>
|
/>
|
||||||
)}
|
)}
|
||||||
</Tooltip>
|
</Tooltip>
|
||||||
|
|
|
||||||
|
|
@ -624,6 +624,7 @@ export class CycleStore implements ICycleStore {
|
||||||
.then((response) => {
|
.then((response) => {
|
||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
set(this.cycleMap, [cycleId, "archived_at"], response.archived_at);
|
set(this.cycleMap, [cycleId, "archived_at"], response.archived_at);
|
||||||
|
if (this.rootStore.favorite.entityMap[cycleId]) this.rootStore.favorite.removeFavoriteFromStore(cycleId);
|
||||||
});
|
});
|
||||||
})
|
})
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
|
|
|
||||||
|
|
@ -18,6 +18,7 @@ export interface IFavoriteStore {
|
||||||
};
|
};
|
||||||
// computed actions
|
// computed actions
|
||||||
existingFolders: string[];
|
existingFolders: string[];
|
||||||
|
groupedFavorites: { [favoriteId: string]: IFavorite };
|
||||||
// actions
|
// actions
|
||||||
fetchFavorite: (workspaceSlug: string) => Promise<IFavorite[]>;
|
fetchFavorite: (workspaceSlug: string) => Promise<IFavorite[]>;
|
||||||
// CRUD actions
|
// CRUD actions
|
||||||
|
|
@ -57,6 +58,7 @@ export class FavoriteStore implements IFavoriteStore {
|
||||||
favoriteIds: observable,
|
favoriteIds: observable,
|
||||||
//computed
|
//computed
|
||||||
existingFolders: computed,
|
existingFolders: computed,
|
||||||
|
groupedFavorites: computed,
|
||||||
// action
|
// action
|
||||||
fetchFavorite: action,
|
fetchFavorite: action,
|
||||||
// CRUD actions
|
// CRUD actions
|
||||||
|
|
@ -80,6 +82,23 @@ export class FavoriteStore implements IFavoriteStore {
|
||||||
return Object.values(this.favoriteMap).map((fav) => fav.name);
|
return Object.values(this.favoriteMap).map((fav) => fav.name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get groupedFavorites() {
|
||||||
|
const data: { [favoriteId: string]: IFavorite } = JSON.parse(JSON.stringify(this.favoriteMap));
|
||||||
|
|
||||||
|
Object.values(data).forEach((fav) => {
|
||||||
|
if (fav.parent && data[fav.parent]) {
|
||||||
|
if (data[fav.parent].children) {
|
||||||
|
if (!data[fav.parent].children.some((f) => f.id === fav.id)) {
|
||||||
|
data[fav.parent].children.push(fav);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
data[fav.parent].children = [fav];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a favorite in the workspace and adds it to the store
|
* Creates a favorite in the workspace and adds it to the store
|
||||||
* @param workspaceSlug
|
* @param workspaceSlug
|
||||||
|
|
@ -151,22 +170,8 @@ export class FavoriteStore implements IFavoriteStore {
|
||||||
*/
|
*/
|
||||||
moveFavorite = async (workspaceSlug: string, favoriteId: string, data: Partial<IFavorite>) => {
|
moveFavorite = async (workspaceSlug: string, favoriteId: string, data: Partial<IFavorite>) => {
|
||||||
const oldParent = this.favoriteMap[favoriteId].parent;
|
const oldParent = this.favoriteMap[favoriteId].parent;
|
||||||
const favorite = this.favoriteMap[favoriteId];
|
|
||||||
try {
|
try {
|
||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
// add the favorite to the new parent
|
|
||||||
if (!data.parent) return;
|
|
||||||
set(this.favoriteMap, [data.parent, "children"], [favorite, ...this.favoriteMap[data.parent].children]);
|
|
||||||
|
|
||||||
// remove the favorite from the old parent
|
|
||||||
if (oldParent) {
|
|
||||||
set(
|
|
||||||
this.favoriteMap,
|
|
||||||
[oldParent, "children"],
|
|
||||||
this.favoriteMap[oldParent].children.filter((child) => child.id !== favoriteId)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
// add parent of the favorite
|
// add parent of the favorite
|
||||||
set(this.favoriteMap, [favoriteId, "parent"], data.parent);
|
set(this.favoriteMap, [favoriteId, "parent"], data.parent);
|
||||||
});
|
});
|
||||||
|
|
@ -177,21 +182,6 @@ export class FavoriteStore implements IFavoriteStore {
|
||||||
// revert the changes
|
// revert the changes
|
||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
if (!data.parent) return;
|
if (!data.parent) return;
|
||||||
// remove the favorite from the new parent
|
|
||||||
set(
|
|
||||||
this.favoriteMap,
|
|
||||||
[data.parent, "children"],
|
|
||||||
this.favoriteMap[data.parent].children.filter((child) => child.id !== favoriteId)
|
|
||||||
);
|
|
||||||
|
|
||||||
// add the favorite back to the old parent
|
|
||||||
if (oldParent) {
|
|
||||||
set(
|
|
||||||
this.favoriteMap,
|
|
||||||
[oldParent, "children"],
|
|
||||||
[...this.favoriteMap[oldParent].children, this.favoriteMap[favoriteId]]
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
// revert the parent
|
// revert the parent
|
||||||
set(this.favoriteMap, [favoriteId, "parent"], oldParent);
|
set(this.favoriteMap, [favoriteId, "parent"], oldParent);
|
||||||
|
|
@ -223,28 +213,13 @@ export class FavoriteStore implements IFavoriteStore {
|
||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
//remove parent
|
//remove parent
|
||||||
set(this.favoriteMap, [favoriteId, "parent"], null);
|
set(this.favoriteMap, [favoriteId, "parent"], null);
|
||||||
|
|
||||||
//remove children from parent
|
|
||||||
if (parent) {
|
|
||||||
set(
|
|
||||||
this.favoriteMap,
|
|
||||||
[parent, "children"],
|
|
||||||
this.favoriteMap[parent].children.filter((child) => child.id !== favoriteId)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
await this.favoriteService.updateFavorite(workspaceSlug, favoriteId, data);
|
await this.favoriteService.updateFavorite(workspaceSlug, favoriteId, data);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error("Failed to move favorite");
|
console.error("Failed to move favorite");
|
||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
set(this.favoriteMap, [favoriteId, "parent"], parent);
|
set(this.favoriteMap, [favoriteId, "parent"], parent);
|
||||||
if (parent) {
|
|
||||||
set(
|
|
||||||
this.favoriteMap,
|
|
||||||
[parent, "children"],
|
|
||||||
[...this.favoriteMap[parent].children, this.favoriteMap[favoriteId]]
|
|
||||||
);
|
|
||||||
}
|
|
||||||
throw error;
|
throw error;
|
||||||
});
|
});
|
||||||
throw error;
|
throw error;
|
||||||
|
|
@ -254,15 +229,26 @@ export class FavoriteStore implements IFavoriteStore {
|
||||||
removeFavoriteEntityFromStore = (entity_identifier: string, entity_type: string) => {
|
removeFavoriteEntityFromStore = (entity_identifier: string, entity_type: string) => {
|
||||||
switch (entity_type) {
|
switch (entity_type) {
|
||||||
case "view":
|
case "view":
|
||||||
return (this.viewStore.viewMap[entity_identifier].is_favorite = false);
|
return (
|
||||||
|
this.viewStore.viewMap[entity_identifier] && (this.viewStore.viewMap[entity_identifier].is_favorite = false)
|
||||||
|
);
|
||||||
case "module":
|
case "module":
|
||||||
return (this.moduleStore.moduleMap[entity_identifier].is_favorite = false);
|
return (
|
||||||
|
this.moduleStore.moduleMap[entity_identifier] &&
|
||||||
|
(this.moduleStore.moduleMap[entity_identifier].is_favorite = false)
|
||||||
|
);
|
||||||
case "page":
|
case "page":
|
||||||
return (this.pageStore.data[entity_identifier].is_favorite = false);
|
return this.pageStore.data[entity_identifier] && (this.pageStore.data[entity_identifier].is_favorite = false);
|
||||||
case "cycle":
|
case "cycle":
|
||||||
return (this.cycleStore.cycleMap[entity_identifier].is_favorite = false);
|
return (
|
||||||
|
this.cycleStore.cycleMap[entity_identifier] &&
|
||||||
|
(this.cycleStore.cycleMap[entity_identifier].is_favorite = false)
|
||||||
|
);
|
||||||
case "project":
|
case "project":
|
||||||
return (this.projectStore.projectMap[entity_identifier].is_favorite = false);
|
return (
|
||||||
|
this.projectStore.projectMap[entity_identifier] &&
|
||||||
|
(this.projectStore.projectMap[entity_identifier].is_favorite = false)
|
||||||
|
);
|
||||||
default:
|
default:
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -276,29 +262,21 @@ export class FavoriteStore implements IFavoriteStore {
|
||||||
*/
|
*/
|
||||||
deleteFavorite = async (workspaceSlug: string, favoriteId: string) => {
|
deleteFavorite = async (workspaceSlug: string, favoriteId: string) => {
|
||||||
const parent = this.favoriteMap[favoriteId].parent;
|
const parent = this.favoriteMap[favoriteId].parent;
|
||||||
const children = this.favoriteMap[favoriteId].children;
|
const children = this.groupedFavorites[favoriteId].children;
|
||||||
const entity_identifier = this.favoriteMap[favoriteId].entity_identifier;
|
const entity_identifier = this.favoriteMap[favoriteId].entity_identifier;
|
||||||
const initialState = this.favoriteMap[favoriteId];
|
const initialState = this.favoriteMap[favoriteId];
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
await this.favoriteService.deleteFavorite(workspaceSlug, favoriteId);
|
||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
if (parent) {
|
|
||||||
set(
|
|
||||||
this.favoriteMap,
|
|
||||||
[parent, "children"],
|
|
||||||
this.favoriteMap[parent].children.filter((child) => child.id !== favoriteId)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
delete this.favoriteMap[favoriteId];
|
delete this.favoriteMap[favoriteId];
|
||||||
entity_identifier && delete this.entityMap[entity_identifier];
|
entity_identifier && delete this.entityMap[entity_identifier];
|
||||||
this.favoriteIds = this.favoriteIds.filter((id) => id !== favoriteId);
|
this.favoriteIds = this.favoriteIds.filter((id) => id !== favoriteId);
|
||||||
});
|
});
|
||||||
await this.favoriteService.deleteFavorite(workspaceSlug, favoriteId);
|
|
||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
entity_identifier && this.removeFavoriteEntityFromStore(entity_identifier, initialState.entity_type);
|
entity_identifier && this.removeFavoriteEntityFromStore(entity_identifier, initialState.entity_type);
|
||||||
if (children) {
|
if (children) {
|
||||||
children.forEach((child) => {
|
children.forEach((child) => {
|
||||||
console.log(child.entity_type);
|
|
||||||
if (!child.entity_identifier) return;
|
if (!child.entity_identifier) return;
|
||||||
this.removeFavoriteEntityFromStore(child.entity_identifier, child.entity_type);
|
this.removeFavoriteEntityFromStore(child.entity_identifier, child.entity_type);
|
||||||
});
|
});
|
||||||
|
|
@ -326,9 +304,6 @@ export class FavoriteStore implements IFavoriteStore {
|
||||||
const initialState = this.entityMap[entityId];
|
const initialState = this.entityMap[entityId];
|
||||||
try {
|
try {
|
||||||
const favoriteId = this.entityMap[entityId].id;
|
const favoriteId = this.entityMap[entityId].id;
|
||||||
runInAction(() => {
|
|
||||||
delete this.entityMap[entityId];
|
|
||||||
});
|
|
||||||
await this.deleteFavorite(workspaceSlug, favoriteId);
|
await this.deleteFavorite(workspaceSlug, favoriteId);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error("Failed to remove favorite entity from favorite store", error);
|
console.error("Failed to remove favorite entity from favorite store", error);
|
||||||
|
|
@ -341,19 +316,22 @@ export class FavoriteStore implements IFavoriteStore {
|
||||||
|
|
||||||
removeFavoriteFromStore = (entity_identifier: string) => {
|
removeFavoriteFromStore = (entity_identifier: string) => {
|
||||||
try {
|
try {
|
||||||
const favoriteId = this.entityMap[entity_identifier].id;
|
const favoriteId = this.entityMap[entity_identifier]?.id;
|
||||||
const favorite = this.favoriteMap[favoriteId];
|
const oldData = this.favoriteMap[favoriteId];
|
||||||
const parent = favorite.parent;
|
const projectData = Object.values(this.favoriteMap).filter(
|
||||||
|
(fav) => fav.project_id === entity_identifier && fav.entity_type !== "project"
|
||||||
|
);
|
||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
if (parent) {
|
projectData &&
|
||||||
set(
|
projectData.forEach(async (fav) => {
|
||||||
this.favoriteMap,
|
this.removeFavoriteFromStore(fav.entity_identifier!);
|
||||||
[parent, "children"],
|
this.removeFavoriteEntityFromStore(fav.entity_identifier!, fav.entity_type);
|
||||||
this.favoriteMap[parent].children.filter((child) => child.id !== favoriteId)
|
});
|
||||||
);
|
|
||||||
}
|
if (!favoriteId) return;
|
||||||
delete this.favoriteMap[favoriteId];
|
delete this.favoriteMap[favoriteId];
|
||||||
|
this.removeFavoriteEntityFromStore(entity_identifier!, oldData.entity_type);
|
||||||
|
|
||||||
delete this.entityMap[entity_identifier];
|
delete this.entityMap[entity_identifier];
|
||||||
this.favoriteIds = this.favoriteIds.filter((id) => id !== favoriteId);
|
this.favoriteIds = this.favoriteIds.filter((id) => id !== favoriteId);
|
||||||
});
|
});
|
||||||
|
|
@ -373,8 +351,6 @@ export class FavoriteStore implements IFavoriteStore {
|
||||||
try {
|
try {
|
||||||
const response = await this.favoriteService.getGroupedFavorites(workspaceSlug, favoriteId);
|
const response = await this.favoriteService.getGroupedFavorites(workspaceSlug, favoriteId);
|
||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
// add children to the favorite
|
|
||||||
set(this.favoriteMap, [favoriteId, "children"], response);
|
|
||||||
// add the favorites to the map
|
// add the favorites to the map
|
||||||
response.forEach((favorite) => {
|
response.forEach((favorite) => {
|
||||||
set(this.favoriteMap, [favorite.id], favorite);
|
set(this.favoriteMap, [favorite.id], favorite);
|
||||||
|
|
|
||||||
|
|
@ -557,6 +557,7 @@ export class ModulesStore implements IModuleStore {
|
||||||
.then((response) => {
|
.then((response) => {
|
||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
set(this.moduleMap, [moduleId, "archived_at"], response.archived_at);
|
set(this.moduleMap, [moduleId, "archived_at"], response.archived_at);
|
||||||
|
if (this.rootStore.favorite.entityMap[moduleId]) this.rootStore.favorite.removeFavoriteFromStore(moduleId);
|
||||||
});
|
});
|
||||||
})
|
})
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
|
|
|
||||||
|
|
@ -443,6 +443,7 @@ export class Page implements IPage {
|
||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
this.archived_at = response.archived_at;
|
this.archived_at = response.archived_at;
|
||||||
});
|
});
|
||||||
|
if (this.rootStore.favorite.entityMap[this.id]) this.rootStore.favorite.removeFavoriteFromStore(this.id);
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
||||||
|
|
@ -418,6 +418,7 @@ export class ProjectStore implements IProjectStore {
|
||||||
.then((response) => {
|
.then((response) => {
|
||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
set(this.projectMap, [projectId, "archived_at"], response.archived_at);
|
set(this.projectMap, [projectId, "archived_at"], response.archived_at);
|
||||||
|
this.rootStore.favorite.removeFavoriteFromStore(projectId);
|
||||||
});
|
});
|
||||||
})
|
})
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue