Skip to content

Commit

Permalink
Merge pull request #1721 from adevinta/sync-dropdown-value-multiselect
Browse files Browse the repository at this point in the history
feat(dropdown): display number of selected items in cta
  • Loading branch information
Powerplex authored Dec 5, 2023
2 parents e2fd654 + bf6ceec commit e9ae232
Show file tree
Hide file tree
Showing 3 changed files with 7 additions and 4 deletions.
1 change: 1 addition & 0 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 4 additions & 2 deletions packages/components/dropdown/src/Dropdown.test.tsx
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
/* eslint-disable max-lines */
import { render, screen } from '@testing-library/react'
import userEvent from '@testing-library/user-event'
import { useState } from 'react'
Expand Down Expand Up @@ -367,8 +368,8 @@ describe('Dropdown', () => {
await user.click(getItem('1984'))
await user.click(getItem('Pride and Prejudice'))

// Then placeholder is replaced by the selected value
expect(getTrigger('Book')).toHaveTextContent('1984')
// Then placeholder is replaced by the selected value and suffix indicating remaining items
expect(getTrigger('Book')).toHaveTextContent('1984, +1')

// Then the proper items are selected
expect(getItem('War and Peace')).toHaveAttribute('aria-selected', 'false')
Expand Down Expand Up @@ -405,6 +406,7 @@ describe('Dropdown', () => {
await user.keyboard('[ArrowDown][Enter]')

// Then all items are selected
expect(getTrigger('Book')).toHaveTextContent('War and Peace, +2')
expect(getItem('War and Peace')).toHaveAttribute('aria-selected', 'true')
expect(getItem('1984')).toHaveAttribute('aria-selected', 'true')
expect(getItem('Pride and Prejudice')).toHaveAttribute('aria-selected', 'true')
Expand Down
4 changes: 2 additions & 2 deletions packages/components/dropdown/src/DropdownValue.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,12 +13,12 @@ export const Value = ({ children, className, placeholder }: ValueProps) => {
const { selectedItem, multiple, selectedItems } = useDropdownContext()

const hasSelectedItems = !!(multiple ? selectedItems.length : selectedItem)

const text = multiple ? selectedItems[0]?.text : selectedItem?.text
const suffix = selectedItems.length > 1 ? `, +${selectedItems.length - 1}` : ''

return (
<span className={cx('text-neutral', className)}>
{!hasSelectedItems ? placeholder : children || text}
{!hasSelectedItems ? placeholder : children || text + suffix}
</span>
)
}
Expand Down

0 comments on commit e9ae232

Please sign in to comment.