Use the auto-imported extractShortcuts utility to define keyboard shortcuts from menu items. It extracts shortcuts from components like DropdownMenu, ContextMenu or CommandPalette where items have kbds defined.
<script setup lang="ts">
const items = [{
label: 'Save',
icon: 'i-lucide-file-down',
kbds: ['meta', 'S'],
onSelect() {
save()
}
}, {
label: 'Copy',
icon: 'i-lucide-copy',
kbds: ['meta', 'C'],
onSelect() {
copy()
}
}]
defineShortcuts(extractShortcuts(items))
</script>
extractShortcuts(items: any[] | any[][], separator?: '_' | '-'): ShortcutsConfig
Extracts keyboard shortcuts from an array of menu items and returns a configuration object compatible with defineShortcuts.
['meta', 'S']).onSelect is not defined).'_' for key combinations (e.g., meta_k) or '-' for key sequences (e.g., g-d). Defaults to '_'.Returns: A ShortcutsConfig object that can be passed directly to defineShortcuts.
The utility recursively traverses children and items properties to extract shortcuts from nested menu structures.
<script setup lang="ts">
import type { DropdownMenuItem } from '@nuxt/ui'
const items: DropdownMenuItem[][] = [[{
label: 'Edit',
icon: 'i-lucide-pencil',
kbds: ['E'],
onSelect() {
edit()
}
}, {
label: 'Duplicate',
icon: 'i-lucide-copy',
kbds: ['D'],
onSelect() {
duplicate()
}
}], [{
label: 'Invite users',
icon: 'i-lucide-user-plus',
children: [[{
label: 'Invite by email',
icon: 'i-lucide-send-horizontal',
kbds: ['meta', 'E'],
onSelect() {
inviteByEmail()
}
}, {
label: 'Invite by link',
icon: 'i-lucide-link',
kbds: ['meta', 'I'],
onSelect() {
inviteByLink()
}
}]]
}], [{
label: 'Delete',
icon: 'i-lucide-trash',
kbds: ['meta', 'backspace'],
onSelect() {
remove()
}
}]]
defineShortcuts(extractShortcuts(items))
</script>
<template>
<UDropdownMenu :items="items">
<UButton label="Actions" />
</UDropdownMenu>
</template>
Use the separator parameter to create key sequences instead of key combinations.
<script setup lang="ts">
const items = [{
label: 'Go to Dashboard',
kbds: ['G', 'D'],
onSelect() {
navigateTo('/dashboard')
}
}, {
label: 'Go to Settings',
kbds: ['G', 'S'],
onSelect() {
navigateTo('/settings')
}
}]
// Using '-' creates key sequences: 'g-d', 'g-s'
defineShortcuts(extractShortcuts(items, '-'))
</script>