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

377 lines
8.8 KiB
JavaScript
Raw Normal View History

2022-12-26 21:10:50 +01:00
import { attr } from 'redux-orm';
2019-08-31 04:07:25 +05:00
2022-12-26 21:10:50 +01:00
import BaseModel from './BaseModel';
2019-08-31 04:07:25 +05:00
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,
};
2022-12-26 21:10:50 +01:00
export default class extends BaseModel {
2019-08-31 04:07:25 +05:00
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(),
2023-10-17 19:18:19 +02:00
isAdmin: attr(),
isLocked: attr(),
isRoleLocked: attr(),
isUsernameLocked: attr(),
isDeletionLocked: attr(),
2023-10-17 19:18:19 +02:00
deletedAt: attr(),
createdAt: attr({
getDefault: () => new Date(),
}),
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('createdAt');
2019-08-31 04:07:25 +05:00
}
getOrderedProjectManagersQuerySet() {
return this.projectManagers.orderBy('createdAt');
}
getOrderedBoardMembershipsQuerySet() {
return this.boardMemberships.orderBy('createdAt');
2019-08-31 04:07:25 +05:00
}
getOrderedUnreadNotificationsQuerySet() {
return this.notifications
.filter({
isRead: false,
})
.orderBy('createdAt', 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(),
},
);
}
static findUsersFromText(filterText, users) {
const selectUser = filterText.toLocaleLowerCase();
const matchingUsers = users.filter(
(user) =>
user.name.toLocaleLowerCase().startsWith(selectUser) ||
user.username.toLocaleLowerCase().startsWith(selectUser),
);
if (matchingUsers.length === 1) {
// Appens the user to the filter
return matchingUsers[0].id;
}
return null;
}
2019-08-31 04:07:25 +05:00
}