1
0
mirror of https://github.com/mattermost/focalboard.git synced 2025-01-23 18:34:02 +02:00

Fixed bug causing select prooperty options to vanish on rename (#797)

* Fixed bug causing select prooperty options to vanish on rename

* Fixed bug causing select prooperty options to vanish on rename
This commit is contained in:
Harshil Sharma 2021-07-30 13:32:27 +05:30 committed by GitHub
parent c3dba863c1
commit 926c4628c6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 181 additions and 8 deletions

View File

@ -0,0 +1,52 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP
exports[`components/cardDetail/CardDetailProperties should match snapshot 1`] = `
<div>
<div
class="octo-propertylist CardDetailProperties"
>
<div
class="octo-propertyrow"
>
<div
class="MenuWrapper"
>
<div
class="octo-propertyname"
>
<button
class="Button "
type="button"
>
<span>
Owner
</span>
</button>
</div>
</div>
<div
class="octo-propertyvalue"
tabindex="0"
>
<span
class="Label propColorDefault "
>
Jean-Luc Picard
</span>
</div>
</div>
<div
class="octo-propertyname add-property"
>
<button
class="Button "
type="button"
>
<span>
+ Add a property
</span>
</button>
</div>
</div>
</div>
`;

View File

@ -0,0 +1,121 @@
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import React from 'react'
import {fireEvent, render} from '@testing-library/react'
import {IntlProvider} from 'react-intl'
import userEvent from '@testing-library/user-event'
import {MutableBoardTree} from '../../viewModel/boardTree'
import {TestBlockFactory} from '../../test/testBlockFactory'
import {FetchMock} from '../../test/fetchMock'
import 'isomorphic-fetch'
import {MutableCardTree} from '../../viewModel/cardTree'
import CardDetailProperties from './cardDetailProperties'
global.fetch = FetchMock.fn
beforeEach(() => {
FetchMock.fn.mockReset()
})
const wrapIntl = (children: any) => <IntlProvider locale='en'>{children}</IntlProvider>
describe('components/cardDetail/CardDetailProperties', () => {
const board = TestBlockFactory.createBoard()
board.cardProperties = [
{
id: 'property_id_1',
name: 'Owner',
type: 'select',
options: [
{
color: 'propColorDefault',
id: 'property_value_id_1',
value: 'Jean-Luc Picard',
},
{
color: 'propColorDefault',
id: 'property_value_id_2',
value: 'William Riker',
},
{
color: 'propColorDefault',
id: 'property_value_id_3',
value: 'Deanna Troi',
},
],
},
]
const view = TestBlockFactory.createBoardView(board)
view.sortOptions = []
view.groupById = undefined
view.hiddenOptionIds = []
const card = TestBlockFactory.createCard(board)
card.properties.property_id_1 = 'property_value_id_1'
const cardTemplate = TestBlockFactory.createCard(board)
cardTemplate.isTemplate = true
const cardTree = new MutableCardTree(card)
test('should match snapshot', async () => {
FetchMock.fn.mockReturnValueOnce(FetchMock.jsonResponse(JSON.stringify([board, view, card, cardTemplate])))
const boardTree = await MutableBoardTree.sync(board.id, view.id, {})
expect(boardTree).not.toBeUndefined()
const componet = wrapIntl((
<CardDetailProperties
boardTree={boardTree!}
cardTree={cardTree}
readonly={false}
/>
))
const {container} = render(componet)
expect(container).toMatchSnapshot()
})
test('rename select property', async () => {
FetchMock.fn.mockReturnValueOnce(FetchMock.jsonResponse(JSON.stringify([board, view, card, cardTemplate])))
const boardTree = await MutableBoardTree.sync(board.id, view.id, {})
expect(boardTree).not.toBeUndefined()
const component = wrapIntl((
<CardDetailProperties
boardTree={boardTree!}
cardTree={cardTree}
readonly={false}
/>
))
const {container} = render(component)
const propertyLabel = container.querySelector('.MenuWrapper')
expect(propertyLabel).toBeDefined()
fireEvent.click(propertyLabel!)
const propertyNameInput = container.querySelector('.PropertyMenu.menu-textbox')
expect(propertyNameInput).toBeDefined()
userEvent.type(propertyNameInput!, 'Owner - Renamed{enter}')
fireEvent.click(propertyLabel!)
// should be called twice,
// one to sync card tree,
// and once on renaming the property
expect(FetchMock.fn).toBeCalledTimes(2)
// Verify API call was made with renamed property
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
const lastAPICallPayload = JSON.parse(FetchMock.fn.mock.calls[1][1].body)
expect(lastAPICallPayload[0].fields.cardProperties[0].name).toBe('Owner - Renamed')
expect(lastAPICallPayload[0].fields.cardProperties[0].options.length).toBe(3)
expect(lastAPICallPayload[0].fields.cardProperties[0].options[0].value).toBe('Jean-Luc Picard')
expect(lastAPICallPayload[0].fields.cardProperties[0].options[1].value).toBe('William Riker')
expect(lastAPICallPayload[0].fields.cardProperties[0].options[2].value).toBe('Deanna Troi')
})
})

View File

@ -25,7 +25,7 @@ const CardDetailProperties = React.memo((props: Props) => {
const {card} = cardTree const {card} = cardTree
return ( return (
<div className='octo-propertylist'> <div className='octo-propertylist CardDetailProperties'>
{board.cardProperties.map((propertyTemplate) => { {board.cardProperties.map((propertyTemplate) => {
const propertyValue = card.properties[propertyTemplate.id] const propertyValue = card.properties[propertyTemplate.id]
return ( return (

View File

@ -377,7 +377,11 @@ class Mutator {
const newBoard = new MutableBoard(board) const newBoard = new MutableBoard(board)
const newTemplate = newBoard.cardProperties.find((o) => o.id === propertyTemplate.id)! const newTemplate = newBoard.cardProperties.find((o) => o.id === propertyTemplate.id)!
if (propertyTemplate.type !== newType) {
newTemplate.options = [] newTemplate.options = []
}
newTemplate.type = newType newTemplate.type = newType
newTemplate.name = newName newTemplate.name = newName
@ -389,14 +393,10 @@ class Mutator {
const isNewTypeSelectOrMulti = newType === 'select' || newType === 'multiSelect' const isNewTypeSelectOrMulti = newType === 'select' || newType === 'multiSelect'
for (const card of boardTree.allCards) { for (const card of boardTree.allCards) {
const oldValue = Array.isArray(card.properties[propertyTemplate.id]) ? const oldValue = Array.isArray(card.properties[propertyTemplate.id]) ? (card.properties[propertyTemplate.id].length > 0 && card.properties[propertyTemplate.id][0]) : card.properties[propertyTemplate.id]
(card.properties[propertyTemplate.id].length > 0 && card.properties[propertyTemplate.id][0]) :
card.properties[propertyTemplate.id]
if (oldValue) { if (oldValue) {
const newValue = isNewTypeSelectOrMulti ? const newValue = isNewTypeSelectOrMulti ? propertyTemplate.options.find((o) => o.id === oldValue)?.id : propertyTemplate.options.find((o) => o.id === oldValue)?.value
propertyTemplate.options.find((o) => o.id === oldValue)?.id :
propertyTemplate.options.find((o) => o.id === oldValue)?.value
const newCard = new MutableCard(card) const newCard = new MutableCard(card)
if (newValue) { if (newValue) {