new-api/web/default/src/components/ui/dropdown-menu.test.tsx
Li Duoyang 2b89989f62
fix(default): support DropdownMenuItem onSelect (#4787)
fix(ui): add onSelect compat wrapper for DropdownMenuItem

Bridges Base UI DropdownMenu with Radix-style onSelect so existing consumers work without migration.
2026-05-12 16:23:24 +08:00

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)
})
})