forked from Yadro/time-tracker
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathProjectStore.ts
More file actions
110 lines (92 loc) · 3.02 KB
/
ProjectStore.ts
File metadata and controls
110 lines (92 loc) · 3.02 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
import { autorun, makeAutoObservable } from 'mobx';
import ProjectModel from './models/ProjectModel';
import ProjectService from './ProjectService';
import TreeModelHelper from '../../base/TreeModelHelper';
import { Undefined } from '../../types/CommonTypes';
import { RootStore } from '../RootStore';
import GaService from '../../services/gaService/GaService';
import {
EEventCategory,
EProjectEvents,
} from '../../services/gaService/EEvents';
export default class ProjectStore {
projects: ProjectModel[] = [];
activeProject: string = '';
editProject: Undefined<ProjectModel>;
private projectService = new ProjectService();
constructor(private rootStore: RootStore) {
makeAutoObservable(this);
autorun(() => {
const profile = this.rootStore.settingsStore.settings.currentProfile;
if (profile) {
this.projectService.setProfile(profile);
}
});
}
set(projects: ProjectModel[]) {
this.projects = projects;
this.projectService.save(this.projects);
}
setEditableProject(project?: ProjectModel) {
this.editProject = project;
}
setActiveProject(projectId: string) {
this.activeProject = projectId;
this.projects = this.projects.slice(); // trigger to update view
}
setProjectProps(
project: ProjectModel,
title: string,
color: string | undefined
) {
project.title = title;
project.color = color || '';
this.projects = this.projects.slice();
this.projectService.save(this.projects);
GaService.event(EEventCategory.Projects, EProjectEvents.Update);
}
get(projectKey: string): ProjectModel | undefined {
function compare(project: ProjectModel) {
return project.key === projectKey;
}
return TreeModelHelper.getItemRecursive(this.projects, compare);
}
getExpandedKeys(): string[] {
const condition = (project: ProjectModel) => project.expanded;
return TreeModelHelper.getFlatItemsRecursive(this.projects, condition).map(
(task) => task.key
);
}
markExpanded(ids: string[]) {
const markExpanded = (project: ProjectModel, ids: string[]) => {
project.expanded = ids.includes(project.key);
};
TreeModelHelper.modifyItemsWithIdsRecursive<ProjectModel>(
this.projects,
ids,
markExpanded
);
this.set(this.projects.slice());
}
add(project: ProjectModel) {
const newProjects = this.projects.slice();
newProjects.push(project);
this.projects = newProjects;
this.projectService.save(this.projects);
GaService.event(EEventCategory.Projects, EProjectEvents.Create);
}
delete(project: ProjectModel) {
function condition(_project: ProjectModel) {
return _project.key === project.key;
}
this.projects = TreeModelHelper.deleteItems(this.projects, condition);
this.projectService.save(this.projects);
GaService.event(EEventCategory.Projects, EProjectEvents.Delete);
}
restore() {
this.projects = this.projectService.getAll();
if (this.projects.length > 0) {
this.activeProject = this.projects[0].key;
}
}
}