1
0
Fork 0
mirror of https://github.com/plankanban/planka.git synced 2025-07-19 05:09:43 +02:00
planka/client/src/models/User.js

357 lines
8.2 KiB
JavaScript
Raw Normal View History

2019-08-31 04:07:25 +05:00
import { Model, attr } from 'redux-orm';
import ActionTypes from '../constants/ActionTypes';
const DEFAULT_EMAIL_UPDATE_FORM = {
data: {
email: '',
currentPassword: '',
},
isSubmitting: false,
error: null,
};
const DEFAULT_PASSWORD_UPDATE_FORM = {
data: {
password: '',
currentPassword: '',
},
isSubmitting: false,
error: null,
};
2020-04-03 00:35:25 +05:00
const DEFAULT_USERNAME_UPDATE_FORM = {
data: {
username: '',
currentPassword: '',
},
isSubmitting: false,
error: null,
};
2019-08-31 04:07:25 +05:00
export default class extends Model {
static modelName = 'User';
static fields = {
id: attr(),
email: attr(),
username: attr(),
2019-08-31 04:07:25 +05:00
name: attr(),
2020-04-21 05:04:34 +05:00
avatarUrl: attr(),
phone: attr(),
organization: attr(),
language: attr(),
subscribeToOwnCards: attr(),
2019-08-31 04:07:25 +05:00
deletedAt: attr(),
isAdmin: attr({
getDefault: () => false,
}),
2020-04-21 05:04:34 +05:00
isAvatarUpdating: attr({
2019-08-31 04:07:25 +05:00
getDefault: () => false,
}),
emailUpdateForm: attr({
getDefault: () => DEFAULT_EMAIL_UPDATE_FORM,
}),
passwordUpdateForm: attr({
getDefault: () => DEFAULT_PASSWORD_UPDATE_FORM,
}),
2020-04-03 00:35:25 +05:00
usernameUpdateForm: attr({
getDefault: () => DEFAULT_USERNAME_UPDATE_FORM,
}),
2019-08-31 04:07:25 +05:00
};
static reducer({ type, payload }, User) {
switch (type) {
case ActionTypes.LOCATION_CHANGE_HANDLE:
if (payload.users) {
payload.users.forEach((user) => {
User.upsert(user);
});
}
2019-08-31 04:07:25 +05:00
break;
case ActionTypes.SOCKET_RECONNECT_HANDLE:
User.all().delete();
User.upsert(payload.user);
2020-03-25 00:15:47 +05:00
payload.users.forEach((user) => {
2019-08-31 04:07:25 +05:00
User.upsert(user);
});
break;
case ActionTypes.CORE_INITIALIZE:
User.upsert(payload.user);
payload.users.forEach((user) => {
User.upsert(user);
});
break;
case ActionTypes.USER_CREATE__SUCCESS:
case ActionTypes.USER_CREATE_HANDLE:
case ActionTypes.USER_UPDATE__SUCCESS:
User.upsert(payload.user);
break;
case ActionTypes.USER_UPDATE:
User.withId(payload.id).update(payload.data);
2020-04-03 00:35:25 +05:00
break;
case ActionTypes.USER_UPDATE_HANDLE:
User.upsert(payload.user);
2019-08-31 04:07:25 +05:00
if (payload.users) {
payload.users.forEach((user) => {
User.upsert(user);
});
}
2019-08-31 04:07:25 +05:00
break;
case ActionTypes.USER_EMAIL_UPDATE: {
const userModel = User.withId(payload.id);
userModel.update({
emailUpdateForm: {
...userModel.emailUpdateForm,
data: payload.data,
isSubmitting: true,
},
});
break;
}
case ActionTypes.USER_EMAIL_UPDATE__SUCCESS: {
2020-05-26 00:46:04 +05:00
User.withId(payload.user.id).update({
...payload.user,
emailUpdateForm: DEFAULT_EMAIL_UPDATE_FORM,
});
break;
}
case ActionTypes.USER_EMAIL_UPDATE__FAILURE: {
const userModel = User.withId(payload.id);
userModel.update({
emailUpdateForm: {
...userModel.emailUpdateForm,
isSubmitting: false,
error: payload.error,
},
});
break;
}
case ActionTypes.USER_EMAIL_UPDATE_ERROR_CLEAR: {
const userModel = User.withId(payload.id);
userModel.update({
emailUpdateForm: {
...userModel.emailUpdateForm,
error: null,
},
});
break;
}
case ActionTypes.USER_PASSWORD_UPDATE: {
const userModel = User.withId(payload.id);
userModel.update({
passwordUpdateForm: {
...userModel.passwordUpdateForm,
data: payload.data,
isSubmitting: true,
},
});
break;
}
case ActionTypes.USER_PASSWORD_UPDATE__SUCCESS: {
2020-05-26 00:46:04 +05:00
User.withId(payload.user.id).update({
...payload.user,
passwordUpdateForm: DEFAULT_PASSWORD_UPDATE_FORM,
});
break;
}
case ActionTypes.USER_PASSWORD_UPDATE__FAILURE: {
const userModel = User.withId(payload.id);
userModel.update({
passwordUpdateForm: {
...userModel.passwordUpdateForm,
isSubmitting: false,
error: payload.error,
},
});
break;
}
case ActionTypes.USER_PASSWORD_UPDATE_ERROR_CLEAR: {
const userModel = User.withId(payload.id);
userModel.update({
passwordUpdateForm: {
...userModel.passwordUpdateForm,
error: null,
},
});
break;
}
case ActionTypes.USER_USERNAME_UPDATE: {
2020-04-03 00:35:25 +05:00
const userModel = User.withId(payload.id);
userModel.update({
usernameUpdateForm: {
...userModel.usernameUpdateForm,
data: payload.data,
isSubmitting: true,
},
});
break;
}
case ActionTypes.USER_USERNAME_UPDATE__SUCCESS: {
2020-05-26 00:46:04 +05:00
User.withId(payload.user.id).update({
...payload.user,
2020-04-03 00:35:25 +05:00
usernameUpdateForm: DEFAULT_USERNAME_UPDATE_FORM,
});
break;
}
case ActionTypes.USER_USERNAME_UPDATE__FAILURE: {
2020-04-03 00:35:25 +05:00
const userModel = User.withId(payload.id);
userModel.update({
usernameUpdateForm: {
...userModel.usernameUpdateForm,
isSubmitting: false,
error: payload.error,
},
});
break;
}
case ActionTypes.USER_USERNAME_UPDATE_ERROR_CLEAR: {
const userModel = User.withId(payload.id);
userModel.update({
usernameUpdateForm: {
...userModel.usernameUpdateForm,
error: null,
},
});
break;
}
case ActionTypes.USER_AVATAR_UPDATE:
2019-08-31 04:07:25 +05:00
User.withId(payload.id).update({
2020-04-21 05:04:34 +05:00
isAvatarUpdating: true,
2019-08-31 04:07:25 +05:00
});
break;
case ActionTypes.USER_AVATAR_UPDATE__SUCCESS:
2020-05-26 00:46:04 +05:00
User.withId(payload.user.id).update({
...payload.user,
2020-04-21 05:04:34 +05:00
isAvatarUpdating: false,
2019-08-31 04:07:25 +05:00
});
break;
case ActionTypes.USER_AVATAR_UPDATE__FAILURE:
2019-08-31 04:07:25 +05:00
User.withId(payload.id).update({
2020-04-21 05:04:34 +05:00
isAvatarUpdating: false,
2019-08-31 04:07:25 +05:00
});
break;
case ActionTypes.USER_DELETE:
User.withId(payload.id).deleteWithRelated();
break;
case ActionTypes.USER_DELETE__SUCCESS:
case ActionTypes.USER_DELETE_HANDLE:
2019-08-31 04:07:25 +05:00
User.withId(payload.user.id).deleteWithRelated(payload.user);
break;
case ActionTypes.PROJECT_CREATE_HANDLE:
case ActionTypes.PROJECT_MANAGER_CREATE_HANDLE:
case ActionTypes.BOARD_FETCH__SUCCESS:
case ActionTypes.BOARD_MEMBERSHIP_CREATE_HANDLE:
2022-08-04 13:31:14 +02:00
case ActionTypes.ACTIVITIES_FETCH__SUCCESS:
case ActionTypes.NOTIFICATION_CREATE_HANDLE:
payload.users.forEach((user) => {
User.upsert(user);
});
2019-08-31 04:07:25 +05:00
break;
default:
}
}
static getOrderedUndeletedQuerySet() {
return this.filter({
deletedAt: null,
}).orderBy('id');
}
getOrderedProjectManagersQuerySet() {
return this.projectManagers.orderBy('id');
}
getOrderedBoardMembershipsQuerySet() {
return this.boardMemberships.orderBy('id');
2019-08-31 04:07:25 +05:00
}
getOrderedUnreadNotificationsQuerySet() {
return this.notifications
.filter({
isRead: false,
})
.orderBy('id', false);
2019-08-31 04:07:25 +05:00
}
getOrderedAvailableProjectsModelArray() {
const projectIds = [];
const projectModels = this.getOrderedProjectManagersQuerySet()
.toModelArray()
.map(({ project: projectModel }) => {
projectIds.push(projectModel.id);
return projectModel;
});
this.getOrderedBoardMembershipsQuerySet()
.toModelArray()
.forEach(({ board: { project: projectModel } }) => {
if (projectIds.includes(projectModel.id)) {
return;
}
projectIds.push(projectModel.id);
projectModels.push(projectModel);
});
return projectModels;
}
deleteRelated() {
this.projectManagers.delete();
this.boardMemberships.toModelArray().forEach((boardMembershipModel) => {
boardMembershipModel.deleteWithRelated();
2019-08-31 04:07:25 +05:00
});
}
deleteWithRelated(user) {
this.deleteRelated();
2019-08-31 04:07:25 +05:00
this.update(
user || {
deletedAt: new Date(),
},
);
}
}