mirror of
https://github.com/plankanban/planka.git
synced 2025-07-19 05:09:43 +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
48
server/api/helpers/board-memberships/create-one.js
Normal file
48
server/api/helpers/board-memberships/create-one.js
Normal file
|
@ -0,0 +1,48 @@
|
|||
module.exports = {
|
||||
inputs: {
|
||||
user: {
|
||||
type: 'ref',
|
||||
required: true,
|
||||
},
|
||||
board: {
|
||||
type: 'ref',
|
||||
required: true,
|
||||
},
|
||||
request: {
|
||||
type: 'ref',
|
||||
},
|
||||
},
|
||||
|
||||
exits: {
|
||||
userAlreadyBoardMember: {},
|
||||
},
|
||||
|
||||
async fn(inputs) {
|
||||
const boardMembership = await BoardMembership.create({
|
||||
boardId: inputs.board.id,
|
||||
userId: inputs.user.id,
|
||||
})
|
||||
.intercept('E_UNIQUE', 'userAlreadyBoardMember')
|
||||
.fetch();
|
||||
|
||||
sails.sockets.broadcast(
|
||||
`user:${boardMembership.userId}`,
|
||||
'boardMembershipCreate',
|
||||
{
|
||||
item: boardMembership,
|
||||
},
|
||||
inputs.request,
|
||||
);
|
||||
|
||||
sails.sockets.broadcast(
|
||||
`board:${boardMembership.boardId}`,
|
||||
'boardMembershipCreate',
|
||||
{
|
||||
item: boardMembership,
|
||||
},
|
||||
inputs.request,
|
||||
);
|
||||
|
||||
return boardMembership;
|
||||
},
|
||||
};
|
71
server/api/helpers/board-memberships/delete-one.js
Normal file
71
server/api/helpers/board-memberships/delete-one.js
Normal file
|
@ -0,0 +1,71 @@
|
|||
module.exports = {
|
||||
inputs: {
|
||||
record: {
|
||||
type: 'ref',
|
||||
required: true,
|
||||
},
|
||||
project: {
|
||||
type: 'ref',
|
||||
required: true,
|
||||
},
|
||||
request: {
|
||||
type: 'ref',
|
||||
},
|
||||
},
|
||||
|
||||
async fn(inputs) {
|
||||
const cardIds = await sails.helpers.boards.getCardIds(inputs.record.boardId);
|
||||
|
||||
await CardSubscription.destroy({
|
||||
cardId: cardIds,
|
||||
userId: inputs.record.userId,
|
||||
});
|
||||
|
||||
await CardMembership.destroy({
|
||||
cardId: cardIds,
|
||||
userId: inputs.record.userId,
|
||||
});
|
||||
|
||||
const boardMembership = await BoardMembership.destroyOne(inputs.record.id);
|
||||
|
||||
if (boardMembership) {
|
||||
sails.sockets.broadcast(
|
||||
`user:${boardMembership.userId}`,
|
||||
'boardMembershipDelete',
|
||||
{
|
||||
item: boardMembership,
|
||||
},
|
||||
inputs.request,
|
||||
);
|
||||
|
||||
const notifyBoard = () => {
|
||||
sails.sockets.broadcast(
|
||||
`board:${boardMembership.boardId}`,
|
||||
'boardMembershipDelete',
|
||||
{
|
||||
item: boardMembership,
|
||||
},
|
||||
inputs.request,
|
||||
);
|
||||
};
|
||||
|
||||
const isProjectManager = await sails.helpers.users.isProjectManager(
|
||||
inputs.record.userId,
|
||||
inputs.project.id,
|
||||
);
|
||||
|
||||
if (isProjectManager) {
|
||||
notifyBoard();
|
||||
} else {
|
||||
// TODO: also remove if unsubscribed to user
|
||||
sails.sockets.removeRoomMembersFromRooms(
|
||||
`user:${boardMembership.userId}`,
|
||||
`board:${boardMembership.boardId}`,
|
||||
notifyBoard,
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
return boardMembership;
|
||||
},
|
||||
};
|
12
server/api/helpers/board-memberships/get-many.js
Normal file
12
server/api/helpers/board-memberships/get-many.js
Normal file
|
@ -0,0 +1,12 @@
|
|||
module.exports = {
|
||||
inputs: {
|
||||
criteria: {
|
||||
type: 'json',
|
||||
custom: (value) => _.isArray(value) || _.isPlainObject(value),
|
||||
},
|
||||
},
|
||||
|
||||
async fn(inputs) {
|
||||
return BoardMembership.find(inputs.criteria).sort('id');
|
||||
},
|
||||
};
|
34
server/api/helpers/board-memberships/get-project-path.js
Normal file
34
server/api/helpers/board-memberships/get-project-path.js
Normal file
|
@ -0,0 +1,34 @@
|
|||
module.exports = {
|
||||
inputs: {
|
||||
criteria: {
|
||||
type: 'json',
|
||||
required: true,
|
||||
},
|
||||
},
|
||||
|
||||
exits: {
|
||||
pathNotFound: {},
|
||||
},
|
||||
|
||||
async fn(inputs) {
|
||||
const boardMembership = await BoardMembership.findOne(inputs.criteria);
|
||||
|
||||
if (!boardMembership) {
|
||||
throw 'pathNotFound';
|
||||
}
|
||||
|
||||
const path = await sails.helpers.boards
|
||||
.getProjectPath(boardMembership.boardId)
|
||||
.intercept('pathNotFound', (nodes) => ({
|
||||
pathNotFound: {
|
||||
boardMembership,
|
||||
...nodes,
|
||||
},
|
||||
}));
|
||||
|
||||
return {
|
||||
boardMembership,
|
||||
...path,
|
||||
};
|
||||
},
|
||||
};
|
Loading…
Add table
Add a link
Reference in a new issue