import * as _ from "lodash";
-import { Project } from "../../models/project";
import actions, { ProjectAction } from "./project-action";
import { TreeItem, TreeItemStatus } from "../../components/tree/tree";
+import { ProjectResource } from "../../models/project";
export type ProjectState = {
- items: Array<TreeItem<Project>>,
+ items: Array<TreeItem<ProjectResource>>,
currentItemId: string,
creator: ProjectCreator
};
}
}
-function updateProjectTree(tree: Array<TreeItem<Project>>, projects: Project[], parentItemId?: string): Array<TreeItem<Project>> {
+function updateProjectTree(tree: Array<TreeItem<ProjectResource>>, projects: ProjectResource[], parentItemId?: string): Array<TreeItem<ProjectResource>> {
let treeItem;
if (parentItemId) {
treeItem = findTreeItem(tree, parentItemId);
status: TreeItemStatus.Initial,
data: p,
items: []
- } as TreeItem<Project>));
+ } as TreeItem<ProjectResource>));
if (treeItem) {
treeItem.items = items;
item.status = TreeItemStatus.Pending;
state.items = items;
}
- return state;
+ return { ...state, items };
},
PROJECTS_SUCCESS: ({ projects, parentItemId }) => {
+ const items = _.cloneDeep(state.items);
return {
...state,
- items: updateProjectTree(state.items, projects, parentItemId)
+ items: updateProjectTree(items, projects, parentItemId)
};
},
TOGGLE_PROJECT_TREE_ITEM_OPEN: itemId => {