tldraw
Version:
A tiny little drawing editor.
42 lines (34 loc) • 1.13 kB
text/typescript
import { StateNode, TLKeyboardEventInfo, TLPointerEventInfo } from '@tldraw/editor'
import { updateHoveredShapeId } from '../../../tools/selection-logic/updateHoveredShapeId'
import { startEditingShapeWithRichText } from '../../../tools/SelectTool/selectHelpers'
export class Idle extends StateNode {
static override id = 'idle'
override onPointerMove(info: TLPointerEventInfo) {
switch (info.target) {
case 'shape':
case 'canvas': {
updateHoveredShapeId(this.editor)
}
}
}
override onPointerDown(info: TLPointerEventInfo) {
this.parent.transition('pointing', info)
}
override onEnter() {
this.editor.setCursor({ type: 'cross', rotation: 0 })
}
override onExit() {
updateHoveredShapeId.cancel()
}
override onKeyDown(info: TLKeyboardEventInfo) {
if (info.key === 'Enter') {
const onlySelectedShape = this.editor.getOnlySelectedShape()
if (!this.editor.canEditShape(onlySelectedShape)) return
this.editor.setCurrentTool('select')
startEditingShapeWithRichText(this.editor, onlySelectedShape.id, { info })
}
}
override onCancel() {
this.editor.setCurrentTool('select')
}
}