fix(ui): add onSelect compat wrapper for DropdownMenuItem Bridges Base UI DropdownMenu with Radix-style onSelect so existing consumers work without migration.
51 lines
1.3 KiB
TypeScript
Vendored
51 lines
1.3 KiB
TypeScript
Vendored
import assert from 'node:assert/strict'
|
|
import { describe, test } from 'node:test'
|
|
import { handleDropdownMenuItemSelect } from './dropdown-menu-events'
|
|
|
|
function createMenuEvent() {
|
|
let defaultPrevented = false
|
|
let baseUIHandlerPrevented = false
|
|
|
|
return {
|
|
get defaultPrevented() {
|
|
return defaultPrevented
|
|
},
|
|
preventDefault() {
|
|
defaultPrevented = true
|
|
},
|
|
preventBaseUIHandler() {
|
|
baseUIHandlerPrevented = true
|
|
},
|
|
get baseUIHandlerPrevented() {
|
|
return baseUIHandlerPrevented
|
|
},
|
|
} as unknown as Parameters<typeof handleDropdownMenuItemSelect>[0] & {
|
|
baseUIHandlerPrevented: boolean
|
|
}
|
|
}
|
|
|
|
describe('DropdownMenuItem onSelect compatibility', () => {
|
|
test('calls the Radix-style onSelect handler on item click', () => {
|
|
const event = createMenuEvent()
|
|
let selected = false
|
|
|
|
handleDropdownMenuItemSelect(event, undefined, () => {
|
|
selected = true
|
|
})
|
|
|
|
assert.equal(selected, true)
|
|
assert.equal(event.baseUIHandlerPrevented, false)
|
|
})
|
|
|
|
test('keeps the Base UI menu open when onSelect prevents default', () => {
|
|
const event = createMenuEvent()
|
|
|
|
handleDropdownMenuItemSelect(event, undefined, (selectEvent) => {
|
|
selectEvent.preventDefault()
|
|
})
|
|
|
|
assert.equal(event.defaultPrevented, true)
|
|
assert.equal(event.baseUIHandlerPrevented, true)
|
|
})
|
|
})
|