mirror of
https://github.com/plankanban/planka.git
synced 2025-07-25 16:19:47 +02:00
Project managers, board members, auto-update after reconnection, refactoring
This commit is contained in:
parent
7956503a46
commit
fe91b5241e
478 changed files with 21226 additions and 19495 deletions
103
client/src/models/BoardMembership.js
Normal file
103
client/src/models/BoardMembership.js
Normal file
|
@ -0,0 +1,103 @@
|
|||
import { Model, attr, fk } from 'redux-orm';
|
||||
|
||||
import ActionTypes from '../constants/ActionTypes';
|
||||
|
||||
export default class extends Model {
|
||||
static modelName = 'BoardMembership';
|
||||
|
||||
static fields = {
|
||||
id: attr(),
|
||||
boardId: fk({
|
||||
to: 'Board',
|
||||
as: 'board',
|
||||
relatedName: 'memberships',
|
||||
}),
|
||||
userId: fk({
|
||||
to: 'User',
|
||||
as: 'user',
|
||||
relatedName: 'boardMemberships',
|
||||
}),
|
||||
};
|
||||
|
||||
static reducer({ type, payload }, BoardMembership) {
|
||||
switch (type) {
|
||||
case ActionTypes.LOCATION_CHANGE_HANDLE:
|
||||
case ActionTypes.PROJECT_MANAGER_CREATE_HANDLE:
|
||||
if (payload.boardMemberships) {
|
||||
payload.boardMemberships.forEach((boardMembership) => {
|
||||
BoardMembership.upsert(boardMembership);
|
||||
});
|
||||
}
|
||||
|
||||
break;
|
||||
case ActionTypes.SOCKET_RECONNECT_HANDLE:
|
||||
BoardMembership.all().delete();
|
||||
|
||||
payload.boardMemberships.forEach((boardMembership) => {
|
||||
BoardMembership.upsert(boardMembership);
|
||||
});
|
||||
|
||||
break;
|
||||
case ActionTypes.CORE_INITIALIZE:
|
||||
case ActionTypes.PROJECT_CREATE_HANDLE:
|
||||
case ActionTypes.BOARD_CREATE__SUCCESS:
|
||||
case ActionTypes.BOARD_FETCH__SUCCESS:
|
||||
payload.boardMemberships.forEach((boardMembership) => {
|
||||
BoardMembership.upsert(boardMembership);
|
||||
});
|
||||
|
||||
break;
|
||||
case ActionTypes.BOARD_MEMBERSHIP_CREATE:
|
||||
BoardMembership.upsert(payload.boardMembership);
|
||||
|
||||
break;
|
||||
case ActionTypes.BOARD_MEMBERSHIP_CREATE__SUCCESS:
|
||||
BoardMembership.withId(payload.localId).delete();
|
||||
BoardMembership.upsert(payload.boardMembership);
|
||||
|
||||
break;
|
||||
case ActionTypes.BOARD_MEMBERSHIP_CREATE_HANDLE:
|
||||
BoardMembership.upsert(payload.boardMembership);
|
||||
|
||||
if (payload.boardMemberships) {
|
||||
payload.boardMemberships.forEach((boardMembership) => {
|
||||
BoardMembership.upsert(boardMembership);
|
||||
});
|
||||
}
|
||||
|
||||
break;
|
||||
case ActionTypes.BOARD_MEMBERSHIP_DELETE:
|
||||
BoardMembership.withId(payload.id).deleteWithRelated();
|
||||
|
||||
break;
|
||||
case ActionTypes.BOARD_MEMBERSHIP_DELETE__SUCCESS:
|
||||
case ActionTypes.BOARD_MEMBERSHIP_DELETE_HANDLE: {
|
||||
const boardMembershipModel = BoardMembership.withId(payload.boardMembership.id);
|
||||
|
||||
if (boardMembershipModel) {
|
||||
boardMembershipModel.deleteWithRelated();
|
||||
}
|
||||
|
||||
break;
|
||||
}
|
||||
default:
|
||||
}
|
||||
}
|
||||
|
||||
deleteRelated() {
|
||||
this.board.cards.toModelArray().forEach((cardModel) => {
|
||||
try {
|
||||
cardModel.users.remove(this.userId);
|
||||
} catch {} // eslint-disable-line no-empty
|
||||
});
|
||||
|
||||
try {
|
||||
this.board.filterUsers.remove(this.userId);
|
||||
} catch {} // eslint-disable-line no-empty
|
||||
}
|
||||
|
||||
deleteWithRelated() {
|
||||
this.deleteRelated();
|
||||
this.delete();
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue