platform/plugins/board-resources/src/utils/CardUtils.ts
Denis Bykhov b1268d6c17
UBERF-5339 (#4566)
Signed-off-by: Denis Bykhov <bykhov.denis@gmail.com>
2024-02-07 22:27:24 +07:00

119 lines
3.7 KiB
TypeScript

import { type Card } from '@hcengineering/board'
import { type Employee, type PersonAccount } from '@hcengineering/contact'
import {
type TxOperations as Client,
type TxResult,
getCurrentAccount,
type Ref,
type Space,
type AttachedData,
SortingOrder,
type Status
} from '@hcengineering/core'
import { showPanel } from '@hcengineering/ui'
import task, { calcRank } from '@hcengineering/task'
import board from '../plugin'
export async function createCard (
client: Client,
space: Ref<Space>,
status: Ref<Status>,
attribues: Partial<AttachedData<Card>> & { kind: Card['kind'] }
): Promise<Ref<Card>> {
const sequence = await client.findOne(task.class.Sequence, { attachedTo: board.class.Card })
if (sequence === undefined) {
throw new Error('sequence object not found')
}
const lastOne = await client.findOne(board.class.Card, {}, { sort: { rank: SortingOrder.Descending } })
const incResult = await client.update(sequence, { $inc: { sequence: 1 } }, true)
const number = (incResult as any).object.sequence
const value: AttachedData<Card> = {
title: '',
status,
startDate: null,
dueDate: null,
number,
rank: calcRank(lastOne, undefined),
assignee: null,
identifier: `CARD-${number}`,
description: '',
...attribues
}
return await client.addCollection(board.class.Card, space, space, board.class.Board, 'cards', value)
}
export function updateCard (client: Client, card: Card, field: string, value: any): Promise<TxResult> | undefined {
if (card === undefined) {
return
}
return client.update(card, { [field]: value })
}
export function openCardPanel (card: Card): boolean {
if (card === undefined) {
return false
}
showPanel(board.component.EditCard, card._id, card._class, 'content')
return true
}
export async function deleteCard (card: Card, client: Client): Promise<TxResult> {
return await client.remove(card)
}
export function isArchived (card: Card): boolean {
return card.isArchived !== undefined && card.isArchived
}
export function isUnarchived (card: Card): boolean {
return card.isArchived === undefined || !card.isArchived
}
export function canAddCurrentUser (card: Card): boolean {
if (card.members == null) {
return true
}
const employee = (getCurrentAccount() as PersonAccount).person
return !card.members.includes(employee as Ref<Employee>)
}
export function hasCover (card: Card): boolean {
return card.cover != null
}
export function hasDate (card: Card): boolean {
return card.dueDate !== undefined || card.startDate !== undefined
}
export function addCurrentUser (card: Card, client: Client): Promise<TxResult> | undefined {
const employee = (getCurrentAccount() as PersonAccount).person
if (card.members?.includes(employee as Ref<Employee>) === true) {
return
}
return client.update(card, { $push: { members: employee as Ref<Employee> } })
}
export function archiveCard (card: Card, client: Client): Promise<TxResult> | undefined {
return updateCard(client, card, 'isArchived', true)
}
export function unarchiveCard (card: Card, client: Client): Promise<TxResult> | undefined {
return updateCard(client, card, 'isArchived', false)
}
export function updateCardMembers (card: Card, client: Client, users: Array<Ref<Employee>>): void {
if (card?.members == null) return
const { members } = card
const membersToPull = members.filter((member) => !users.includes(member))
const usersToPush = users.filter((member) => !members.includes(member))
if (membersToPull.length > 0) void updateCard(client, card, '$pull', { members: { $in: membersToPull } })
if (usersToPush.length > 0) void updateCard(client, card, '$push', { members: { $each: usersToPush, $position: 0 } })
}