plane/apps/space/store/user.ts

76 lines
1.8 KiB
TypeScript
Raw Normal View History

// mobx
import { observable, action, computed, makeObservable, runInAction } from "mobx";
// service
import UserService from "services/user.service";
2023-08-31 11:05:26 +00:00
export interface IUserStore {
currentUser: any | null;
fetchCurrentUser: () => void;
}
class UserStore implements IUserStore {
currentUser: any | null = null;
// root store
rootStore;
// service
userService;
constructor(_rootStore: any) {
makeObservable(this, {
// observable
currentUser: observable,
// actions
setCurrentUser: action,
// computed
});
this.rootStore = _rootStore;
this.userService = new UserService();
}
setCurrentUser = (user: any) => {
// TODO: destructure user object
this.currentUser = user;
};
/**
*
* @param callback
* @description A wrapper function to check user authentication; it redirects to the login page if not authenticated, otherwise, it executes a callback.
* @example this.requiredLogin(() => { // do something });
*/
requiredLogin = (callback: () => void) => {
if (this.currentUser) {
callback();
return;
}
2023-08-31 11:05:26 +00:00
this.fetchCurrentUser()
.then(() => {
if (!this.currentUser) {
const currentPath = window.location.pathname;
window.location.href = `/?next_path=${currentPath}`;
} else callback();
})
.catch(() => {
const currentPath = window.location.pathname;
window.location.href = `/?next_path=${currentPath}`;
});
};
2023-08-31 11:05:26 +00:00
fetchCurrentUser = async () => {
try {
const response = await this.userService.currentUser();
if (response) {
runInAction(() => {
this.currentUser = response;
});
}
} catch (error) {
2023-08-31 11:05:26 +00:00
console.error("Failed to fetch current user", error);
}
};
}
export default UserStore;