1
0
Fork 0
mirror of https://github.com/plankanban/planka.git synced 2025-07-19 21:29:43 +02:00
planka/server/api/helpers/boards/create-one.js

132 lines
3.1 KiB
JavaScript
Raw Normal View History

/*!
* Copyright (c) 2024 PLANKA Software GmbH
* Licensed under the Fair Use License: https://github.com/plankanban/planka/blob/master/LICENSE.md
*/
2022-12-26 21:10:50 +01:00
2019-08-31 04:07:25 +05:00
module.exports = {
inputs: {
values: {
2022-12-26 21:10:50 +01:00
type: 'ref',
required: true,
2019-08-31 04:07:25 +05:00
},
import: {
type: 'json',
},
actorUser: {
type: 'ref',
required: true,
},
requestId: {
type: 'string',
},
2019-08-31 04:07:25 +05:00
request: {
type: 'ref',
},
2019-08-31 04:07:25 +05:00
},
async fn(inputs) {
2022-12-26 21:10:50 +01:00
const { values } = inputs;
const scoper = sails.helpers.projects.makeScoper.with({
record: values.project,
});
const boards = await Board.qm.getByProjectId(values.project.id);
2019-08-31 04:07:25 +05:00
const { position, repositions } = sails.helpers.utils.insertToPositionables(
2022-12-26 21:10:50 +01:00
values.position,
boards,
2019-08-31 04:07:25 +05:00
);
values.position = position;
if (repositions.length > 0) {
await scoper.getUserIdsWithFullProjectVisibility();
const clonedScoper = scoper.clone();
// eslint-disable-next-line no-restricted-syntax
for (const reposition of repositions) {
// eslint-disable-next-line no-await-in-loop
await Board.qm.updateOne(
{
id: reposition.record.id,
projectId: reposition.record.projectId,
},
{
position: reposition.position,
},
);
clonedScoper.replaceBoard(reposition.record);
// eslint-disable-next-line no-await-in-loop
const boardRelatedUserIds = await clonedScoper.getBoardRelatedUserIds();
boardRelatedUserIds.forEach((userId) => {
sails.sockets.broadcast(`user:${userId}`, 'boardUpdate', {
item: {
id: reposition.record.id,
position: reposition.position,
},
});
2019-08-31 04:07:25 +05:00
});
// TODO: send webhooks
}
}
2019-08-31 04:07:25 +05:00
const { board, boardMembership, lists } = await Board.qm.createOne(
{
...values,
projectId: values.project.id,
},
{
user: inputs.actorUser,
},
);
2019-08-31 04:07:25 +05:00
if (inputs.import && inputs.import.type === Board.ImportTypes.TRELLO) {
await sails.helpers.boards.importFromTrello(board, lists, inputs.import.board);
}
scoper.board = board;
scoper.boardMemberships = [boardMembership];
const boardRelatedUserIds = await scoper.getBoardRelatedUserIds();
boardRelatedUserIds.forEach((userId) => {
2019-08-31 04:07:25 +05:00
sails.sockets.broadcast(
`user:${userId}`,
'boardCreate',
{
item: board,
included: {
boardMemberships: userId === boardMembership.userId ? [boardMembership] : [],
},
requestId: inputs.requestId,
2019-08-31 04:07:25 +05:00
},
inputs.request,
2019-08-31 04:07:25 +05:00
);
});
const webhooks = await Webhook.qm.getAll();
sails.helpers.utils.sendWebhooks.with({
webhooks,
event: Webhook.Events.BOARD_CREATE,
buildData: () => ({
item: board,
included: {
projects: [values.project],
boardMemberships: [boardMembership],
},
}),
user: inputs.actorUser,
});
return {
board,
boardMembership,
};
},
2019-08-31 04:07:25 +05:00
};