mirror of
https://github.com/plankanban/planka.git
synced 2025-12-26 09:15:01 +03:00
@@ -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();
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user