mirror of
https://github.com/mattermost/focalboard.git
synced 2025-01-02 14:47:55 +02:00
Change dragged cards order in the active view when they are dropped to column. (#671)
This commit is contained in:
parent
f01add651c
commit
f6746d8b32
@ -190,6 +190,23 @@ class Kanban extends React.Component<Props, State> {
|
|||||||
await mutator.insertPropertyOption(boardTree, boardTree.groupByProperty!, option, 'add group')
|
await mutator.insertPropertyOption(boardTree, boardTree.groupByProperty!, option, 'add group')
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private orderAfterMoveToColumn(cardIds: string[], columnId?: string): string[] {
|
||||||
|
const {boardTree} = this.props
|
||||||
|
const {activeView} = boardTree
|
||||||
|
let cardOrder = activeView.cardOrder.slice()
|
||||||
|
const columnGroup = boardTree.visibleGroups.find((g) => g.option.id === columnId)
|
||||||
|
const columnCards = columnGroup?.cards
|
||||||
|
if (!columnCards || columnCards.length === 0) {
|
||||||
|
return cardOrder
|
||||||
|
}
|
||||||
|
const lastCardId = columnCards[columnCards.length - 1].id
|
||||||
|
const setOfIds = new Set(cardIds)
|
||||||
|
cardOrder = cardOrder.filter((id) => !setOfIds.has(id))
|
||||||
|
const lastCardIndex = cardOrder.indexOf(lastCardId)
|
||||||
|
cardOrder.splice(lastCardIndex + 1, 0, ...cardIds)
|
||||||
|
return cardOrder
|
||||||
|
}
|
||||||
|
|
||||||
private onDropToColumn = async (option: IPropertyOption, card?: Card, dstOption?: IPropertyOption) => {
|
private onDropToColumn = async (option: IPropertyOption, card?: Card, dstOption?: IPropertyOption) => {
|
||||||
const {boardTree, selectedCardIds} = this.props
|
const {boardTree, selectedCardIds} = this.props
|
||||||
const optionId = option ? option.id : undefined
|
const optionId = option ? option.id : undefined
|
||||||
@ -218,6 +235,8 @@ class Kanban extends React.Component<Props, State> {
|
|||||||
awaits.push(mutator.changePropertyValue(draggedCard, boardTree.groupByProperty!.id, optionId, description))
|
awaits.push(mutator.changePropertyValue(draggedCard, boardTree.groupByProperty!.id, optionId, description))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
const newOrder = this.orderAfterMoveToColumn(draggedCardIds, optionId)
|
||||||
|
awaits.push(mutator.changeViewCardOrder(boardTree.activeView, newOrder, description))
|
||||||
await Promise.all(awaits)
|
await Promise.all(awaits)
|
||||||
})
|
})
|
||||||
} else if (dstOption) {
|
} else if (dstOption) {
|
||||||
|
Loading…
Reference in New Issue
Block a user