1
0
Fork 0
mirror of https://github.com/plankanban/planka.git synced 2025-07-18 20:59:44 +02:00
planka/server/api/hooks/query-methods/models/CustomFieldGroup.js
Maksim Eltyshev 2ee1166747 feat: Version 2
Closes #627, closes #1047
2025-05-10 02:09:06 +02:00

72 lines
1.7 KiB
JavaScript

/*!
* Copyright (c) 2024 PLANKA Software GmbH
* Licensed under the Fair Use License: https://github.com/plankanban/planka/blob/master/LICENSE.md
*/
const defaultFind = (criteria, { exceptIdOrIds, sort = 'id' } = {}) => {
if (exceptIdOrIds) {
// eslint-disable-next-line no-param-reassign
criteria.id = {
'!=': exceptIdOrIds,
};
}
return CustomFieldGroup.find(criteria).sort(sort);
};
/* Query methods */
const create = (arrayOfValues) => CustomFieldGroup.createEach(arrayOfValues).fetch();
const createOne = (values) => CustomFieldGroup.create({ ...values }).fetch();
const getByIds = (ids) => defaultFind(ids);
const getByBoardId = (boardId, { exceptIdOrIds, sort = ['position', 'id'] } = {}) =>
defaultFind(
{
boardId,
},
{ exceptIdOrIds, sort },
);
const getByCardId = (cardId, { exceptIdOrIds, sort = ['position', 'id'] } = {}) =>
defaultFind(
{
cardId,
},
{ exceptIdOrIds, sort },
);
const getByCardIds = (cardIds, { sort = ['position', 'id'] } = {}) =>
defaultFind(
{
cardId: cardIds,
},
{ sort },
);
const getOneById = (id) => CustomFieldGroup.findOne(id);
const update = (criteria, values) => CustomFieldGroup.update(criteria).set(values).fetch();
const updateOne = (criteria, values) => CustomFieldGroup.updateOne(criteria).set({ ...values });
// eslint-disable-next-line no-underscore-dangle
const delete_ = (criteria) => CustomFieldGroup.destroy(criteria).fetch();
const deleteOne = (criteria) => CustomFieldGroup.destroyOne(criteria);
module.exports = {
create,
createOne,
getByBoardId,
getByIds,
getByCardId,
getByCardIds,
getOneById,
update,
updateOne,
deleteOne,
delete: delete_,
};