feat: Version 2

Closes #627, closes #1047
This commit is contained in:
Maksim Eltyshev
2025-05-10 02:09:06 +02:00
parent ad7fb51cfa
commit 2ee1166747
1557 changed files with 76832 additions and 47042 deletions

View File

@@ -1,3 +1,8 @@
/*!
* Copyright (c) 2024 PLANKA Software GmbH
* Licensed under the Fair Use License: https://github.com/plankanban/planka/blob/master/LICENSE.md
*/
import { attr, fk } from 'redux-orm';
import BaseModel from './BaseModel';
@@ -10,9 +15,6 @@ export default class extends BaseModel {
id: attr(),
role: attr(),
canComment: attr(),
createdAt: attr({
getDefault: () => new Date(),
}),
boardId: fk({
to: 'Board',
as: 'board',
@@ -28,6 +30,8 @@ export default class extends BaseModel {
static reducer({ type, payload }, BoardMembership) {
switch (type) {
case ActionTypes.LOCATION_CHANGE_HANDLE:
case ActionTypes.USER_UPDATE_HANDLE:
case ActionTypes.PROJECT_UPDATE_HANDLE:
case ActionTypes.PROJECT_MANAGER_CREATE_HANDLE:
if (payload.boardMemberships) {
payload.boardMemberships.forEach((boardMembership) => {
@@ -47,6 +51,7 @@ export default class extends BaseModel {
case ActionTypes.CORE_INITIALIZE:
case ActionTypes.PROJECT_CREATE_HANDLE:
case ActionTypes.BOARD_CREATE__SUCCESS:
case ActionTypes.BOARD_CREATE_HANDLE:
case ActionTypes.BOARD_FETCH__SUCCESS:
payload.boardMemberships.forEach((boardMembership) => {
BoardMembership.upsert(boardMembership);
@@ -54,6 +59,8 @@ export default class extends BaseModel {
break;
case ActionTypes.BOARD_MEMBERSHIP_CREATE:
case ActionTypes.BOARD_MEMBERSHIP_UPDATE__SUCCESS:
case ActionTypes.BOARD_MEMBERSHIP_UPDATE_HANDLE:
BoardMembership.upsert(payload.boardMembership);
break;
@@ -61,6 +68,10 @@ export default class extends BaseModel {
BoardMembership.withId(payload.localId).delete();
BoardMembership.upsert(payload.boardMembership);
break;
case ActionTypes.BOARD_MEMBERSHIP_CREATE__FAILURE:
BoardMembership.withId(payload.localId).delete();
break;
case ActionTypes.BOARD_MEMBERSHIP_CREATE_HANDLE:
BoardMembership.upsert(payload.boardMembership);
@@ -75,14 +86,9 @@ export default class extends BaseModel {
case ActionTypes.BOARD_MEMBERSHIP_UPDATE:
BoardMembership.withId(payload.id).update(payload.data);
break;
case ActionTypes.BOARD_MEMBERSHIP_UPDATE__SUCCESS:
case ActionTypes.BOARD_MEMBERSHIP_UPDATE_HANDLE:
BoardMembership.upsert(payload.boardMembership);
break;
case ActionTypes.BOARD_MEMBERSHIP_DELETE:
BoardMembership.withId(payload.id).deleteWithRelated();
BoardMembership.withId(payload.id).deleteWithRelated(payload.isCurrentUser);
break;
case ActionTypes.BOARD_MEMBERSHIP_DELETE__SUCCESS:
@@ -90,7 +96,7 @@ export default class extends BaseModel {
const boardMembershipModel = BoardMembership.withId(payload.boardMembership.id);
if (boardMembershipModel) {
boardMembershipModel.deleteWithRelated();
boardMembershipModel.deleteWithRelated(payload.isCurrentUser);
}
break;
@@ -99,20 +105,44 @@ export default class extends BaseModel {
}
}
deleteRelated() {
deleteRelated(isCurrentUser = false) {
if (isCurrentUser) {
this.board.isSubscribed = false;
}
this.board.cards.toModelArray().forEach((cardModel) => {
if (isCurrentUser) {
cardModel.update({
isSubscribed: false,
});
}
try {
cardModel.users.remove(this.userId);
} catch {} // eslint-disable-line no-empty
} catch {
/* empty */
}
cardModel.taskLists.toModelArray().forEach((taskListModel) => {
taskListModel.tasks.toModelArray().forEach((taskModel) => {
if (taskModel.assigneeUserId === this.userId) {
taskModel.update({
assigneeUserId: null,
});
}
});
});
});
try {
this.board.filterUsers.remove(this.userId);
} catch {} // eslint-disable-line no-empty
} catch {
/* empty */
}
}
deleteWithRelated() {
this.deleteRelated();
deleteWithRelated(isCurrentUser) {
this.deleteRelated(isCurrentUser);
this.delete();
}
}