useEditorCommands
useEditorCommands() legt eine befehlsorientierte Schicht über Editor-Aktionen.
Es ist nützlich beim Erstellen von:
- App-Menüs
- Kontextmenüs
- Toolbars
- Tastaturbefehl-Adaptern
- Seiten-Verschiebe-Untermenüs
Verwendung
ts
import { useEditorCommands } from '@open-pencil/vue'
const { commands, menuItem, runCommand, moveSelectionToPage, otherPages } = useEditorCommands()Einfaches Beispiel
ts
const { menuItem } = useEditorCommands()
const editMenu = [
menuItem('edit.undo', '⌘Z'),
menuItem('edit.redo', '⇧⌘Z'),
{ separator: true },
menuItem('selection.delete'),
]Praktische Beispiele
Einen Befehl direkt ausführen
ts
const { runCommand } = useEditorCommands()
runCommand('selection.duplicate')Ein „Auf Seite verschieben"-Untermenü erstellen
ts
const { otherPages, moveSelectionToPage } = useEditorCommands()
const items = otherPages.value.map(page => ({
label: page.name,
action: () => moveSelectionToPage(page.id),
}))Verwandte APIs
Wichtigste Typen
ts
type EditorCommandId =
| 'edit.undo'
| 'edit.redo'
| 'selection.selectAll'
| 'selection.duplicate'
| 'selection.delete'
| 'selection.group'
| 'selection.ungroup'
| 'selection.createComponent'
| 'selection.createComponentSet'
| 'selection.createInstance'
| 'selection.detachInstance'
| 'selection.goToMainComponent'
| 'selection.wrapInAutoLayout'
| 'selection.bringToFront'
| 'selection.sendToBack'
| 'selection.toggleVisibility'
| 'selection.toggleLock'
| 'selection.moveToPage'
| 'view.zoom100'
| 'view.zoomFit'
| 'view.zoomSelection'