|
|
@@ -1,13 +1,13 @@
|
|
1
|
|
-import { createSelectorHook, createState } from "@state-designer/react"
|
|
2
|
|
-import * as vec from "utils/vec"
|
|
3
|
|
-import inputs from "./inputs"
|
|
4
|
|
-import { defaultDocument } from "./data"
|
|
5
|
|
-import { shades } from "lib/colors"
|
|
6
|
|
-import { createShape, getShapeUtils } from "lib/shape-utils"
|
|
7
|
|
-import history from "state/history"
|
|
8
|
|
-import * as Sessions from "./sessions"
|
|
9
|
|
-import commands from "./commands"
|
|
10
|
|
-import { updateFromCode } from "lib/code/generate"
|
|
|
1
|
+import { createSelectorHook, createState } from '@state-designer/react'
|
|
|
2
|
+import * as vec from 'utils/vec'
|
|
|
3
|
+import inputs from './inputs'
|
|
|
4
|
+import { defaultDocument } from './data'
|
|
|
5
|
+import { shades } from 'lib/colors'
|
|
|
6
|
+import { createShape, getShapeUtils } from 'lib/shape-utils'
|
|
|
7
|
+import history from 'state/history'
|
|
|
8
|
+import * as Sessions from './sessions'
|
|
|
9
|
+import commands from './commands'
|
|
|
10
|
+import { updateFromCode } from 'lib/code/generate'
|
|
11
|
11
|
import {
|
|
12
|
12
|
clamp,
|
|
13
|
13
|
getChildren,
|
|
|
@@ -18,7 +18,7 @@ import {
|
|
18
|
18
|
getShape,
|
|
19
|
19
|
screenToWorld,
|
|
20
|
20
|
setZoomCSS,
|
|
21
|
|
-} from "utils/utils"
|
|
|
21
|
+} from 'utils/utils'
|
|
22
|
22
|
import {
|
|
23
|
23
|
Data,
|
|
24
|
24
|
PointerInfo,
|
|
|
@@ -32,7 +32,7 @@ import {
|
|
32
|
32
|
DistributeType,
|
|
33
|
33
|
AlignType,
|
|
34
|
34
|
StretchType,
|
|
35
|
|
-} from "types"
|
|
|
35
|
+} from 'types'
|
|
36
|
36
|
|
|
37
|
37
|
const initialData: Data = {
|
|
38
|
38
|
isReadOnly: false,
|
|
|
@@ -55,8 +55,8 @@ const initialData: Data = {
|
|
55
|
55
|
pointedId: null,
|
|
56
|
56
|
hoveredId: null,
|
|
57
|
57
|
selectedIds: new Set([]),
|
|
58
|
|
- currentPageId: "page0",
|
|
59
|
|
- currentCodeFileId: "file0",
|
|
|
58
|
+ currentPageId: 'page0',
|
|
|
59
|
+ currentCodeFileId: 'file0',
|
|
60
|
60
|
codeControls: {},
|
|
61
|
61
|
document: defaultDocument,
|
|
62
|
62
|
}
|
|
|
@@ -65,109 +65,116 @@ const state = createState({
|
|
65
|
65
|
data: initialData,
|
|
66
|
66
|
on: {
|
|
67
|
67
|
ZOOMED_CAMERA: {
|
|
68
|
|
- do: "zoomCamera",
|
|
|
68
|
+ do: 'zoomCamera',
|
|
69
|
69
|
},
|
|
70
|
70
|
PANNED_CAMERA: {
|
|
71
|
|
- do: "panCamera",
|
|
72
|
|
- },
|
|
73
|
|
- SELECTED_SELECT_TOOL: { to: "selecting" },
|
|
74
|
|
- SELECTED_DRAW_TOOL: { unless: "isReadOnly", to: "draw" },
|
|
75
|
|
- SELECTED_DOT_TOOL: { unless: "isReadOnly", to: "dot" },
|
|
76
|
|
- SELECTED_CIRCLE_TOOL: { unless: "isReadOnly", to: "circle" },
|
|
77
|
|
- SELECTED_ELLIPSE_TOOL: { unless: "isReadOnly", to: "ellipse" },
|
|
78
|
|
- SELECTED_RAY_TOOL: { unless: "isReadOnly", to: "ray" },
|
|
79
|
|
- SELECTED_LINE_TOOL: { unless: "isReadOnly", to: "line" },
|
|
80
|
|
- SELECTED_POLYLINE_TOOL: { unless: "isReadOnly", to: "polyline" },
|
|
81
|
|
- SELECTED_RECTANGLE_TOOL: { unless: "isReadOnly", to: "rectangle" },
|
|
82
|
|
- TOGGLED_CODE_PANEL_OPEN: "toggleCodePanel",
|
|
83
|
|
- TOGGLED_STYLE_PANEL_OPEN: "toggleStylePanel",
|
|
84
|
|
- CHANGED_STYLE: ["updateStyles", "applyStylesToSelection"],
|
|
85
|
|
- RESET_CAMERA: "resetCamera",
|
|
86
|
|
- ZOOMED_TO_FIT: "zoomCameraToFit",
|
|
|
71
|
+ do: 'panCamera',
|
|
|
72
|
+ },
|
|
|
73
|
+ SELECTED_SELECT_TOOL: { to: 'selecting' },
|
|
|
74
|
+ SELECTED_DRAW_TOOL: { unless: 'isReadOnly', to: 'draw' },
|
|
|
75
|
+ SELECTED_DOT_TOOL: { unless: 'isReadOnly', to: 'dot' },
|
|
|
76
|
+ SELECTED_CIRCLE_TOOL: { unless: 'isReadOnly', to: 'circle' },
|
|
|
77
|
+ SELECTED_ELLIPSE_TOOL: { unless: 'isReadOnly', to: 'ellipse' },
|
|
|
78
|
+ SELECTED_RAY_TOOL: { unless: 'isReadOnly', to: 'ray' },
|
|
|
79
|
+ SELECTED_LINE_TOOL: { unless: 'isReadOnly', to: 'line' },
|
|
|
80
|
+ SELECTED_POLYLINE_TOOL: { unless: 'isReadOnly', to: 'polyline' },
|
|
|
81
|
+ SELECTED_RECTANGLE_TOOL: { unless: 'isReadOnly', to: 'rectangle' },
|
|
|
82
|
+ TOGGLED_CODE_PANEL_OPEN: 'toggleCodePanel',
|
|
|
83
|
+ TOGGLED_STYLE_PANEL_OPEN: 'toggleStylePanel',
|
|
|
84
|
+ CHANGED_STYLE: ['updateStyles', 'applyStylesToSelection'],
|
|
|
85
|
+ RESET_CAMERA: 'resetCamera',
|
|
|
86
|
+ ZOOMED_TO_FIT: 'zoomCameraToFit',
|
|
87
|
87
|
ZOOMED_TO_SELECTION: {
|
|
88
|
|
- if: "hasSelection",
|
|
89
|
|
- do: "zoomCameraToSelection",
|
|
|
88
|
+ if: 'hasSelection',
|
|
|
89
|
+ do: 'zoomCameraToSelection',
|
|
90
|
90
|
},
|
|
91
|
91
|
ZOOMED_TO_ACTUAL: {
|
|
92
|
|
- if: "hasSelection",
|
|
93
|
|
- do: "zoomCameraToSelectionActual",
|
|
94
|
|
- else: "zoomCameraToActual",
|
|
|
92
|
+ if: 'hasSelection',
|
|
|
93
|
+ do: 'zoomCameraToSelectionActual',
|
|
|
94
|
+ else: 'zoomCameraToActual',
|
|
95
|
95
|
},
|
|
96
|
|
- SELECTED_ALL: { to: "selecting", do: "selectAll" },
|
|
|
96
|
+ SELECTED_ALL: { to: 'selecting', do: 'selectAll' },
|
|
97
|
97
|
},
|
|
98
|
|
- initial: "loading",
|
|
|
98
|
+ initial: 'loading',
|
|
99
|
99
|
states: {
|
|
100
|
100
|
loading: {
|
|
101
|
101
|
on: {
|
|
102
|
|
- MOUNTED: {
|
|
103
|
|
- do: ["restoreSavedData", "zoomCameraToFit"],
|
|
104
|
|
- to: "ready",
|
|
105
|
|
- },
|
|
|
102
|
+ MOUNTED: [
|
|
|
103
|
+ 'restoreSavedData',
|
|
|
104
|
+ {
|
|
|
105
|
+ if: 'hasSelection',
|
|
|
106
|
+ do: 'zoomCameraToSelectionActual',
|
|
|
107
|
+ else: ['zoomCameraToFit', 'zoomCameraToActual'],
|
|
|
108
|
+ },
|
|
|
109
|
+ {
|
|
|
110
|
+ to: 'ready',
|
|
|
111
|
+ },
|
|
|
112
|
+ ],
|
|
106
|
113
|
},
|
|
107
|
114
|
},
|
|
108
|
115
|
ready: {
|
|
109
|
116
|
on: {
|
|
110
|
117
|
UNMOUNTED: [
|
|
111
|
|
- { unless: "isReadOnly", do: "forceSave" },
|
|
112
|
|
- { to: "loading" },
|
|
|
118
|
+ { unless: 'isReadOnly', do: 'forceSave' },
|
|
|
119
|
+ { to: 'loading' },
|
|
113
|
120
|
],
|
|
114
|
121
|
},
|
|
115
|
|
- initial: "selecting",
|
|
|
122
|
+ initial: 'selecting',
|
|
116
|
123
|
states: {
|
|
117
|
124
|
selecting: {
|
|
118
|
125
|
on: {
|
|
119
|
|
- SAVED: "forceSave",
|
|
120
|
|
- UNDO: { do: "undo" },
|
|
121
|
|
- REDO: { do: "redo" },
|
|
122
|
|
- CANCELLED: { do: "clearSelectedIds" },
|
|
123
|
|
- DELETED: { do: "deleteSelectedIds" },
|
|
124
|
|
- SAVED_CODE: "saveCode",
|
|
125
|
|
- GENERATED_FROM_CODE: ["setCodeControls", "setGeneratedShapes"],
|
|
126
|
|
- INCREASED_CODE_FONT_SIZE: "increaseCodeFontSize",
|
|
127
|
|
- DECREASED_CODE_FONT_SIZE: "decreaseCodeFontSize",
|
|
128
|
|
- CHANGED_CODE_CONTROL: "updateControls",
|
|
129
|
|
- ALIGNED: "alignSelection",
|
|
130
|
|
- STRETCHED: "stretchSelection",
|
|
131
|
|
- DISTRIBUTED: "distributeSelection",
|
|
132
|
|
- MOVED: "moveSelection",
|
|
133
|
|
- STARTED_PINCHING: { to: "pinching" },
|
|
|
126
|
+ SAVED: 'forceSave',
|
|
|
127
|
+ UNDO: { do: 'undo' },
|
|
|
128
|
+ REDO: { do: 'redo' },
|
|
|
129
|
+ CANCELLED: { do: 'clearSelectedIds' },
|
|
|
130
|
+ DELETED: { do: 'deleteSelectedIds' },
|
|
|
131
|
+ SAVED_CODE: 'saveCode',
|
|
|
132
|
+ GENERATED_FROM_CODE: ['setCodeControls', 'setGeneratedShapes'],
|
|
|
133
|
+ INCREASED_CODE_FONT_SIZE: 'increaseCodeFontSize',
|
|
|
134
|
+ DECREASED_CODE_FONT_SIZE: 'decreaseCodeFontSize',
|
|
|
135
|
+ CHANGED_CODE_CONTROL: 'updateControls',
|
|
|
136
|
+ ALIGNED: 'alignSelection',
|
|
|
137
|
+ STRETCHED: 'stretchSelection',
|
|
|
138
|
+ DISTRIBUTED: 'distributeSelection',
|
|
|
139
|
+ MOVED: 'moveSelection',
|
|
|
140
|
+ STARTED_PINCHING: { to: 'pinching' },
|
|
134
|
141
|
},
|
|
135
|
|
- initial: "notPointing",
|
|
|
142
|
+ initial: 'notPointing',
|
|
136
|
143
|
states: {
|
|
137
|
144
|
notPointing: {
|
|
138
|
145
|
on: {
|
|
139
|
|
- POINTED_CANVAS: { to: "brushSelecting" },
|
|
140
|
|
- POINTED_BOUNDS: { to: "pointingBounds" },
|
|
|
146
|
+ POINTED_CANVAS: { to: 'brushSelecting' },
|
|
|
147
|
+ POINTED_BOUNDS: { to: 'pointingBounds' },
|
|
141
|
148
|
POINTED_BOUNDS_HANDLE: {
|
|
142
|
|
- if: "isPointingRotationHandle",
|
|
143
|
|
- to: "rotatingSelection",
|
|
144
|
|
- else: { to: "transformingSelection" },
|
|
|
149
|
+ if: 'isPointingRotationHandle',
|
|
|
150
|
+ to: 'rotatingSelection',
|
|
|
151
|
+ else: { to: 'transformingSelection' },
|
|
145
|
152
|
},
|
|
146
|
153
|
MOVED_OVER_SHAPE: {
|
|
147
|
|
- if: "pointHitsShape",
|
|
|
154
|
+ if: 'pointHitsShape',
|
|
148
|
155
|
then: {
|
|
149
|
|
- unless: "shapeIsHovered",
|
|
150
|
|
- do: "setHoveredId",
|
|
|
156
|
+ unless: 'shapeIsHovered',
|
|
|
157
|
+ do: 'setHoveredId',
|
|
151
|
158
|
},
|
|
152
|
|
- else: { if: "shapeIsHovered", do: "clearHoveredId" },
|
|
|
159
|
+ else: { if: 'shapeIsHovered', do: 'clearHoveredId' },
|
|
153
|
160
|
},
|
|
154
|
|
- UNHOVERED_SHAPE: "clearHoveredId",
|
|
|
161
|
+ UNHOVERED_SHAPE: 'clearHoveredId',
|
|
155
|
162
|
POINTED_SHAPE: [
|
|
156
|
163
|
{
|
|
157
|
|
- if: "isPressingMetaKey",
|
|
158
|
|
- to: "brushSelecting",
|
|
|
164
|
+ if: 'isPressingMetaKey',
|
|
|
165
|
+ to: 'brushSelecting',
|
|
159
|
166
|
},
|
|
160
|
|
- "setPointedId",
|
|
|
167
|
+ 'setPointedId',
|
|
161
|
168
|
{
|
|
162
|
|
- unless: "isPointedShapeSelected",
|
|
|
169
|
+ unless: 'isPointedShapeSelected',
|
|
163
|
170
|
then: {
|
|
164
|
|
- if: "isPressingShiftKey",
|
|
165
|
|
- do: ["pushPointedIdToSelectedIds", "clearPointedId"],
|
|
166
|
|
- else: ["clearSelectedIds", "pushPointedIdToSelectedIds"],
|
|
|
171
|
+ if: 'isPressingShiftKey',
|
|
|
172
|
+ do: ['pushPointedIdToSelectedIds', 'clearPointedId'],
|
|
|
173
|
+ else: ['clearSelectedIds', 'pushPointedIdToSelectedIds'],
|
|
167
|
174
|
},
|
|
168
|
175
|
},
|
|
169
|
176
|
{
|
|
170
|
|
- to: "pointingBounds",
|
|
|
177
|
+ to: 'pointingBounds',
|
|
171
|
178
|
},
|
|
172
|
179
|
],
|
|
173
|
180
|
},
|
|
|
@@ -176,151 +183,153 @@ const state = createState({
|
|
176
|
183
|
on: {
|
|
177
|
184
|
STOPPED_POINTING: [
|
|
178
|
185
|
{
|
|
179
|
|
- if: "isPressingShiftKey",
|
|
|
186
|
+ if: 'isPressingShiftKey',
|
|
180
|
187
|
then: {
|
|
181
|
|
- if: "isPointedShapeSelected",
|
|
182
|
|
- do: "pullPointedIdFromSelectedIds",
|
|
|
188
|
+ if: 'isPointedShapeSelected',
|
|
|
189
|
+ do: 'pullPointedIdFromSelectedIds',
|
|
183
|
190
|
},
|
|
184
|
191
|
else: {
|
|
185
|
|
- unless: "isPointingBounds",
|
|
186
|
|
- do: ["clearSelectedIds", "pushPointedIdToSelectedIds"],
|
|
|
192
|
+ unless: 'isPointingBounds',
|
|
|
193
|
+ do: ['clearSelectedIds', 'pushPointedIdToSelectedIds'],
|
|
187
|
194
|
},
|
|
188
|
195
|
},
|
|
189
|
|
- { to: "notPointing" },
|
|
|
196
|
+ { to: 'notPointing' },
|
|
190
|
197
|
],
|
|
191
|
198
|
MOVED_POINTER: {
|
|
192
|
|
- unless: "isReadOnly",
|
|
193
|
|
- if: "distanceImpliesDrag",
|
|
194
|
|
- to: "draggingSelection",
|
|
|
199
|
+ unless: 'isReadOnly',
|
|
|
200
|
+ if: 'distanceImpliesDrag',
|
|
|
201
|
+ to: 'draggingSelection',
|
|
195
|
202
|
},
|
|
196
|
203
|
},
|
|
197
|
204
|
},
|
|
198
|
205
|
rotatingSelection: {
|
|
199
|
|
- onEnter: "startRotateSession",
|
|
200
|
|
- onExit: "clearBoundsRotation",
|
|
|
206
|
+ onEnter: 'startRotateSession',
|
|
|
207
|
+ onExit: 'clearBoundsRotation',
|
|
201
|
208
|
on: {
|
|
202
|
|
- MOVED_POINTER: "updateRotateSession",
|
|
203
|
|
- PANNED_CAMERA: "updateRotateSession",
|
|
204
|
|
- PRESSED_SHIFT_KEY: "keyUpdateRotateSession",
|
|
205
|
|
- RELEASED_SHIFT_KEY: "keyUpdateRotateSession",
|
|
206
|
|
- STOPPED_POINTING: { do: "completeSession", to: "selecting" },
|
|
207
|
|
- CANCELLED: { do: "cancelSession", to: "selecting" },
|
|
|
209
|
+ MOVED_POINTER: 'updateRotateSession',
|
|
|
210
|
+ PANNED_CAMERA: 'updateRotateSession',
|
|
|
211
|
+ PRESSED_SHIFT_KEY: 'keyUpdateRotateSession',
|
|
|
212
|
+ RELEASED_SHIFT_KEY: 'keyUpdateRotateSession',
|
|
|
213
|
+ STOPPED_POINTING: { do: 'completeSession', to: 'selecting' },
|
|
|
214
|
+ CANCELLED: { do: 'cancelSession', to: 'selecting' },
|
|
208
|
215
|
},
|
|
209
|
216
|
},
|
|
210
|
217
|
transformingSelection: {
|
|
211
|
|
- onEnter: "startTransformSession",
|
|
|
218
|
+ onEnter: 'startTransformSession',
|
|
212
|
219
|
on: {
|
|
213
|
|
- MOVED_POINTER: "updateTransformSession",
|
|
214
|
|
- PANNED_CAMERA: "updateTransformSession",
|
|
215
|
|
- PRESSED_SHIFT_KEY: "keyUpdateTransformSession",
|
|
216
|
|
- RELEASED_SHIFT_KEY: "keyUpdateTransformSession",
|
|
217
|
|
- STOPPED_POINTING: { do: "completeSession", to: "selecting" },
|
|
218
|
|
- CANCELLED: { do: "cancelSession", to: "selecting" },
|
|
|
220
|
+ MOVED_POINTER: 'updateTransformSession',
|
|
|
221
|
+ PANNED_CAMERA: 'updateTransformSession',
|
|
|
222
|
+ PRESSED_SHIFT_KEY: 'keyUpdateTransformSession',
|
|
|
223
|
+ RELEASED_SHIFT_KEY: 'keyUpdateTransformSession',
|
|
|
224
|
+ STOPPED_POINTING: { do: 'completeSession', to: 'selecting' },
|
|
|
225
|
+ CANCELLED: { do: 'cancelSession', to: 'selecting' },
|
|
219
|
226
|
},
|
|
220
|
227
|
},
|
|
221
|
228
|
draggingSelection: {
|
|
222
|
|
- onEnter: "startTranslateSession",
|
|
|
229
|
+ onEnter: 'startTranslateSession',
|
|
223
|
230
|
on: {
|
|
224
|
|
- MOVED_POINTER: "updateTranslateSession",
|
|
225
|
|
- PANNED_CAMERA: "updateTranslateSession",
|
|
226
|
|
- PRESSED_SHIFT_KEY: "keyUpdateTranslateSession",
|
|
227
|
|
- RELEASED_SHIFT_KEY: "keyUpdateTranslateSession",
|
|
228
|
|
- PRESSED_ALT_KEY: "keyUpdateTranslateSession",
|
|
229
|
|
- RELEASED_ALT_KEY: "keyUpdateTranslateSession",
|
|
230
|
|
- STOPPED_POINTING: { do: "completeSession", to: "selecting" },
|
|
231
|
|
- CANCELLED: { do: "cancelSession", to: "selecting" },
|
|
|
231
|
+ MOVED_POINTER: 'updateTranslateSession',
|
|
|
232
|
+ PANNED_CAMERA: 'updateTranslateSession',
|
|
|
233
|
+ PRESSED_SHIFT_KEY: 'keyUpdateTranslateSession',
|
|
|
234
|
+ RELEASED_SHIFT_KEY: 'keyUpdateTranslateSession',
|
|
|
235
|
+ PRESSED_ALT_KEY: 'keyUpdateTranslateSession',
|
|
|
236
|
+ RELEASED_ALT_KEY: 'keyUpdateTranslateSession',
|
|
|
237
|
+ STOPPED_POINTING: { do: 'completeSession', to: 'selecting' },
|
|
|
238
|
+ CANCELLED: { do: 'cancelSession', to: 'selecting' },
|
|
232
|
239
|
},
|
|
233
|
240
|
},
|
|
234
|
241
|
brushSelecting: {
|
|
235
|
242
|
onEnter: [
|
|
236
|
243
|
{
|
|
237
|
|
- unless: ["isPressingMetaKey", "isPressingShiftKey"],
|
|
238
|
|
- do: "clearSelectedIds",
|
|
|
244
|
+ unless: ['isPressingMetaKey', 'isPressingShiftKey'],
|
|
|
245
|
+ do: 'clearSelectedIds',
|
|
239
|
246
|
},
|
|
240
|
|
- "clearBoundsRotation",
|
|
241
|
|
- "startBrushSession",
|
|
|
247
|
+ 'clearBoundsRotation',
|
|
|
248
|
+ 'startBrushSession',
|
|
242
|
249
|
],
|
|
243
|
250
|
on: {
|
|
244
|
|
- MOVED_POINTER: "updateBrushSession",
|
|
245
|
|
- PANNED_CAMERA: "updateBrushSession",
|
|
246
|
|
- STOPPED_POINTING: { do: "completeSession", to: "selecting" },
|
|
247
|
|
- CANCELLED: { do: "cancelSession", to: "selecting" },
|
|
|
251
|
+ MOVED_POINTER: 'updateBrushSession',
|
|
|
252
|
+ PANNED_CAMERA: 'updateBrushSession',
|
|
|
253
|
+ STOPPED_POINTING: { do: 'completeSession', to: 'selecting' },
|
|
|
254
|
+ CANCELLED: { do: 'cancelSession', to: 'selecting' },
|
|
248
|
255
|
},
|
|
249
|
256
|
},
|
|
250
|
257
|
},
|
|
251
|
258
|
},
|
|
252
|
259
|
pinching: {
|
|
253
|
260
|
on: {
|
|
254
|
|
- STOPPED_PINCHING: { to: "selecting" },
|
|
255
|
|
- PINCHED: { do: "pinchCamera" },
|
|
|
261
|
+ STOPPED_PINCHING: { to: 'selecting' },
|
|
|
262
|
+ PINCHED: { do: 'pinchCamera' },
|
|
256
|
263
|
},
|
|
257
|
264
|
},
|
|
258
|
265
|
draw: {
|
|
259
|
|
- initial: "creating",
|
|
|
266
|
+ initial: 'creating',
|
|
260
|
267
|
states: {
|
|
261
|
268
|
creating: {
|
|
262
|
269
|
on: {
|
|
|
270
|
+ CANCELLED: { to: 'selecting' },
|
|
263
|
271
|
POINTED_CANVAS: {
|
|
264
|
|
- get: "newDraw",
|
|
265
|
|
- do: "createShape",
|
|
266
|
|
- to: "draw.editing",
|
|
|
272
|
+ get: 'newDraw',
|
|
|
273
|
+ do: 'createShape',
|
|
|
274
|
+ to: 'draw.editing',
|
|
267
|
275
|
},
|
|
268
|
|
- UNDO: { do: "undo" },
|
|
269
|
|
- REDO: { do: "redo" },
|
|
|
276
|
+ UNDO: { do: 'undo' },
|
|
|
277
|
+ REDO: { do: 'redo' },
|
|
270
|
278
|
},
|
|
271
|
279
|
},
|
|
272
|
280
|
editing: {
|
|
273
|
|
- onEnter: "startDrawSession",
|
|
|
281
|
+ onEnter: 'startDrawSession',
|
|
274
|
282
|
on: {
|
|
275
|
283
|
STOPPED_POINTING: {
|
|
276
|
|
- do: "completeSession",
|
|
277
|
|
- to: "draw.creating",
|
|
|
284
|
+ do: 'completeSession',
|
|
|
285
|
+ to: 'draw.creating',
|
|
278
|
286
|
},
|
|
279
|
287
|
CANCELLED: {
|
|
280
|
|
- do: ["cancelSession", "deleteSelectedIds"],
|
|
281
|
|
- to: "selecting",
|
|
|
288
|
+ do: ['cancelSession', 'deleteSelectedIds'],
|
|
|
289
|
+ to: 'selecting',
|
|
282
|
290
|
},
|
|
283
|
|
- MOVED_POINTER: "updateDrawSession",
|
|
284
|
|
- PANNED_CAMERA: "updateDrawSession",
|
|
|
291
|
+ MOVED_POINTER: 'updateDrawSession',
|
|
|
292
|
+ PANNED_CAMERA: 'updateDrawSession',
|
|
285
|
293
|
},
|
|
286
|
294
|
},
|
|
287
|
295
|
},
|
|
288
|
296
|
},
|
|
289
|
297
|
dot: {
|
|
290
|
|
- initial: "creating",
|
|
|
298
|
+ initial: 'creating',
|
|
291
|
299
|
states: {
|
|
292
|
300
|
creating: {
|
|
293
|
301
|
on: {
|
|
|
302
|
+ CANCELLED: { to: 'selecting' },
|
|
294
|
303
|
POINTED_CANVAS: {
|
|
295
|
|
- get: "newDot",
|
|
296
|
|
- do: "createShape",
|
|
297
|
|
- to: "dot.editing",
|
|
|
304
|
+ get: 'newDot',
|
|
|
305
|
+ do: 'createShape',
|
|
|
306
|
+ to: 'dot.editing',
|
|
298
|
307
|
},
|
|
299
|
308
|
},
|
|
300
|
309
|
},
|
|
301
|
310
|
editing: {
|
|
302
|
311
|
on: {
|
|
303
|
|
- STOPPED_POINTING: { do: "completeSession", to: "selecting" },
|
|
|
312
|
+ STOPPED_POINTING: { do: 'completeSession', to: 'selecting' },
|
|
304
|
313
|
CANCELLED: {
|
|
305
|
|
- do: ["cancelSession", "deleteSelectedIds"],
|
|
306
|
|
- to: "selecting",
|
|
|
314
|
+ do: ['cancelSession', 'deleteSelectedIds'],
|
|
|
315
|
+ to: 'selecting',
|
|
307
|
316
|
},
|
|
308
|
317
|
},
|
|
309
|
|
- initial: "inactive",
|
|
|
318
|
+ initial: 'inactive',
|
|
310
|
319
|
states: {
|
|
311
|
320
|
inactive: {
|
|
312
|
321
|
on: {
|
|
313
|
322
|
MOVED_POINTER: {
|
|
314
|
|
- if: "distanceImpliesDrag",
|
|
315
|
|
- to: "dot.editing.active",
|
|
|
323
|
+ if: 'distanceImpliesDrag',
|
|
|
324
|
+ to: 'dot.editing.active',
|
|
316
|
325
|
},
|
|
317
|
326
|
},
|
|
318
|
327
|
},
|
|
319
|
328
|
active: {
|
|
320
|
|
- onEnter: "startTranslateSession",
|
|
|
329
|
+ onEnter: 'startTranslateSession',
|
|
321
|
330
|
on: {
|
|
322
|
|
- MOVED_POINTER: "updateTranslateSession",
|
|
323
|
|
- PANNED_CAMERA: "updateTranslateSession",
|
|
|
331
|
+ MOVED_POINTER: 'updateTranslateSession',
|
|
|
332
|
+ PANNED_CAMERA: 'updateTranslateSession',
|
|
324
|
333
|
},
|
|
325
|
334
|
},
|
|
326
|
335
|
},
|
|
|
@@ -328,25 +337,26 @@ const state = createState({
|
|
328
|
337
|
},
|
|
329
|
338
|
},
|
|
330
|
339
|
circle: {
|
|
331
|
|
- initial: "creating",
|
|
|
340
|
+ initial: 'creating',
|
|
332
|
341
|
states: {
|
|
333
|
342
|
creating: {
|
|
334
|
343
|
on: {
|
|
|
344
|
+ CANCELLED: { to: 'selecting' },
|
|
335
|
345
|
POINTED_CANVAS: {
|
|
336
|
|
- to: "circle.editing",
|
|
|
346
|
+ to: 'circle.editing',
|
|
337
|
347
|
},
|
|
338
|
348
|
},
|
|
339
|
349
|
},
|
|
340
|
350
|
editing: {
|
|
341
|
351
|
on: {
|
|
342
|
|
- STOPPED_POINTING: { to: "selecting" },
|
|
343
|
|
- CANCELLED: { to: "selecting" },
|
|
|
352
|
+ STOPPED_POINTING: { to: 'selecting' },
|
|
|
353
|
+ CANCELLED: { to: 'selecting' },
|
|
344
|
354
|
MOVED_POINTER: {
|
|
345
|
|
- if: "distanceImpliesDrag",
|
|
|
355
|
+ if: 'distanceImpliesDrag',
|
|
346
|
356
|
then: {
|
|
347
|
|
- get: "newCircle",
|
|
348
|
|
- do: "createShape",
|
|
349
|
|
- to: "drawingShape.bounds",
|
|
|
357
|
+ get: 'newCircle',
|
|
|
358
|
+ do: 'createShape',
|
|
|
359
|
+ to: 'drawingShape.bounds',
|
|
350
|
360
|
},
|
|
351
|
361
|
},
|
|
352
|
362
|
},
|
|
|
@@ -354,26 +364,26 @@ const state = createState({
|
|
354
|
364
|
},
|
|
355
|
365
|
},
|
|
356
|
366
|
ellipse: {
|
|
357
|
|
- initial: "creating",
|
|
|
367
|
+ initial: 'creating',
|
|
358
|
368
|
states: {
|
|
359
|
369
|
creating: {
|
|
360
|
370
|
on: {
|
|
361
|
|
- CANCELLED: { to: "selecting" },
|
|
|
371
|
+ CANCELLED: { to: 'selecting' },
|
|
362
|
372
|
POINTED_CANVAS: {
|
|
363
|
|
- to: "ellipse.editing",
|
|
|
373
|
+ to: 'ellipse.editing',
|
|
364
|
374
|
},
|
|
365
|
375
|
},
|
|
366
|
376
|
},
|
|
367
|
377
|
editing: {
|
|
368
|
378
|
on: {
|
|
369
|
|
- STOPPED_POINTING: { to: "selecting" },
|
|
370
|
|
- CANCELLED: { to: "selecting" },
|
|
|
379
|
+ STOPPED_POINTING: { to: 'selecting' },
|
|
|
380
|
+ CANCELLED: { to: 'selecting' },
|
|
371
|
381
|
MOVED_POINTER: {
|
|
372
|
|
- if: "distanceImpliesDrag",
|
|
|
382
|
+ if: 'distanceImpliesDrag',
|
|
373
|
383
|
then: {
|
|
374
|
|
- get: "newEllipse",
|
|
375
|
|
- do: "createShape",
|
|
376
|
|
- to: "drawingShape.bounds",
|
|
|
384
|
+ get: 'newEllipse',
|
|
|
385
|
+ do: 'createShape',
|
|
|
386
|
+ to: 'drawingShape.bounds',
|
|
377
|
387
|
},
|
|
378
|
388
|
},
|
|
379
|
389
|
},
|
|
|
@@ -381,26 +391,26 @@ const state = createState({
|
|
381
|
391
|
},
|
|
382
|
392
|
},
|
|
383
|
393
|
rectangle: {
|
|
384
|
|
- initial: "creating",
|
|
|
394
|
+ initial: 'creating',
|
|
385
|
395
|
states: {
|
|
386
|
396
|
creating: {
|
|
387
|
397
|
on: {
|
|
388
|
|
- CANCELLED: { to: "selecting" },
|
|
|
398
|
+ CANCELLED: { to: 'selecting' },
|
|
389
|
399
|
POINTED_CANVAS: {
|
|
390
|
|
- to: "rectangle.editing",
|
|
|
400
|
+ to: 'rectangle.editing',
|
|
391
|
401
|
},
|
|
392
|
402
|
},
|
|
393
|
403
|
},
|
|
394
|
404
|
editing: {
|
|
395
|
405
|
on: {
|
|
396
|
|
- STOPPED_POINTING: { to: "selecting" },
|
|
397
|
|
- CANCELLED: { to: "selecting" },
|
|
|
406
|
+ STOPPED_POINTING: { to: 'selecting' },
|
|
|
407
|
+ CANCELLED: { to: 'selecting' },
|
|
398
|
408
|
MOVED_POINTER: {
|
|
399
|
|
- if: "distanceImpliesDrag",
|
|
|
409
|
+ if: 'distanceImpliesDrag',
|
|
400
|
410
|
then: {
|
|
401
|
|
- get: "newRectangle",
|
|
402
|
|
- do: "createShape",
|
|
403
|
|
- to: "drawingShape.bounds",
|
|
|
411
|
+ get: 'newRectangle',
|
|
|
412
|
+ do: 'createShape',
|
|
|
413
|
+ to: 'drawingShape.bounds',
|
|
404
|
414
|
},
|
|
405
|
415
|
},
|
|
406
|
416
|
},
|
|
|
@@ -408,50 +418,50 @@ const state = createState({
|
|
408
|
418
|
},
|
|
409
|
419
|
},
|
|
410
|
420
|
ray: {
|
|
411
|
|
- initial: "creating",
|
|
|
421
|
+ initial: 'creating',
|
|
412
|
422
|
states: {
|
|
413
|
423
|
creating: {
|
|
414
|
424
|
on: {
|
|
415
|
|
- CANCELLED: { to: "selecting" },
|
|
|
425
|
+ CANCELLED: { to: 'selecting' },
|
|
416
|
426
|
POINTED_CANVAS: {
|
|
417
|
|
- get: "newRay",
|
|
418
|
|
- do: "createShape",
|
|
419
|
|
- to: "ray.editing",
|
|
|
427
|
+ get: 'newRay',
|
|
|
428
|
+ do: 'createShape',
|
|
|
429
|
+ to: 'ray.editing',
|
|
420
|
430
|
},
|
|
421
|
431
|
},
|
|
422
|
432
|
},
|
|
423
|
433
|
editing: {
|
|
424
|
434
|
on: {
|
|
425
|
|
- STOPPED_POINTING: { to: "selecting" },
|
|
426
|
|
- CANCELLED: { to: "selecting" },
|
|
|
435
|
+ STOPPED_POINTING: { to: 'selecting' },
|
|
|
436
|
+ CANCELLED: { to: 'selecting' },
|
|
427
|
437
|
MOVED_POINTER: {
|
|
428
|
|
- if: "distanceImpliesDrag",
|
|
429
|
|
- to: "drawingShape.direction",
|
|
|
438
|
+ if: 'distanceImpliesDrag',
|
|
|
439
|
+ to: 'drawingShape.direction',
|
|
430
|
440
|
},
|
|
431
|
441
|
},
|
|
432
|
442
|
},
|
|
433
|
443
|
},
|
|
434
|
444
|
},
|
|
435
|
445
|
line: {
|
|
436
|
|
- initial: "creating",
|
|
|
446
|
+ initial: 'creating',
|
|
437
|
447
|
states: {
|
|
438
|
448
|
creating: {
|
|
439
|
449
|
on: {
|
|
440
|
|
- CANCELLED: { to: "selecting" },
|
|
|
450
|
+ CANCELLED: { to: 'selecting' },
|
|
441
|
451
|
POINTED_CANVAS: {
|
|
442
|
|
- get: "newLine",
|
|
443
|
|
- do: "createShape",
|
|
444
|
|
- to: "line.editing",
|
|
|
452
|
+ get: 'newLine',
|
|
|
453
|
+ do: 'createShape',
|
|
|
454
|
+ to: 'line.editing',
|
|
445
|
455
|
},
|
|
446
|
456
|
},
|
|
447
|
457
|
},
|
|
448
|
458
|
editing: {
|
|
449
|
459
|
on: {
|
|
450
|
|
- STOPPED_POINTING: { to: "selecting" },
|
|
451
|
|
- CANCELLED: { to: "selecting" },
|
|
|
460
|
+ STOPPED_POINTING: { to: 'selecting' },
|
|
|
461
|
+ CANCELLED: { to: 'selecting' },
|
|
452
|
462
|
MOVED_POINTER: {
|
|
453
|
|
- if: "distanceImpliesDrag",
|
|
454
|
|
- to: "drawingShape.direction",
|
|
|
463
|
+ if: 'distanceImpliesDrag',
|
|
|
464
|
+ to: 'drawingShape.direction',
|
|
455
|
465
|
},
|
|
456
|
466
|
},
|
|
457
|
467
|
},
|
|
|
@@ -463,28 +473,28 @@ const state = createState({
|
|
463
|
473
|
drawingShape: {
|
|
464
|
474
|
on: {
|
|
465
|
475
|
STOPPED_POINTING: {
|
|
466
|
|
- do: "completeSession",
|
|
467
|
|
- to: "selecting",
|
|
|
476
|
+ do: 'completeSession',
|
|
|
477
|
+ to: 'selecting',
|
|
468
|
478
|
},
|
|
469
|
479
|
CANCELLED: {
|
|
470
|
|
- do: ["cancelSession", "deleteSelectedIds"],
|
|
471
|
|
- to: "selecting",
|
|
|
480
|
+ do: ['cancelSession', 'deleteSelectedIds'],
|
|
|
481
|
+ to: 'selecting',
|
|
472
|
482
|
},
|
|
473
|
483
|
},
|
|
474
|
|
- initial: "drawingShapeBounds",
|
|
|
484
|
+ initial: 'drawingShapeBounds',
|
|
475
|
485
|
states: {
|
|
476
|
486
|
bounds: {
|
|
477
|
|
- onEnter: "startDrawTransformSession",
|
|
|
487
|
+ onEnter: 'startDrawTransformSession',
|
|
478
|
488
|
on: {
|
|
479
|
|
- MOVED_POINTER: "updateTransformSession",
|
|
480
|
|
- PANNED_CAMERA: "updateTransformSession",
|
|
|
489
|
+ MOVED_POINTER: 'updateTransformSession',
|
|
|
490
|
+ PANNED_CAMERA: 'updateTransformSession',
|
|
481
|
491
|
},
|
|
482
|
492
|
},
|
|
483
|
493
|
direction: {
|
|
484
|
|
- onEnter: "startDirectionSession",
|
|
|
494
|
+ onEnter: 'startDirectionSession',
|
|
485
|
495
|
on: {
|
|
486
|
|
- MOVED_POINTER: "updateDirectionSession",
|
|
487
|
|
- PANNED_CAMERA: "updateDirectionSession",
|
|
|
496
|
+ MOVED_POINTER: 'updateDirectionSession',
|
|
|
497
|
+ PANNED_CAMERA: 'updateDirectionSession',
|
|
488
|
498
|
},
|
|
489
|
499
|
},
|
|
490
|
500
|
},
|
|
|
@@ -515,7 +525,7 @@ const state = createState({
|
|
515
|
525
|
},
|
|
516
|
526
|
conditions: {
|
|
517
|
527
|
isPointingBounds(data, payload: PointerInfo) {
|
|
518
|
|
- return payload.target === "bounds"
|
|
|
528
|
+ return payload.target === 'bounds'
|
|
519
|
529
|
},
|
|
520
|
530
|
isReadOnly(data) {
|
|
521
|
531
|
return data.isReadOnly
|
|
|
@@ -545,9 +555,9 @@ const state = createState({
|
|
545
|
555
|
},
|
|
546
|
556
|
isPointingRotationHandle(
|
|
547
|
557
|
data,
|
|
548
|
|
- payload: { target: Edge | Corner | "rotate" }
|
|
|
558
|
+ payload: { target: Edge | Corner | 'rotate' }
|
|
549
|
559
|
) {
|
|
550
|
|
- return payload.target === "rotate"
|
|
|
560
|
+ return payload.target === 'rotate'
|
|
551
|
561
|
},
|
|
552
|
562
|
hasSelection(data) {
|
|
553
|
563
|
return data.selectedIds.size > 0
|
|
|
@@ -753,7 +763,7 @@ const state = createState({
|
|
753
|
763
|
data.camera.zoom = 1
|
|
754
|
764
|
data.camera.point = [window.innerWidth / 2, window.innerHeight / 2]
|
|
755
|
765
|
|
|
756
|
|
- document.documentElement.style.setProperty("--camera-zoom", "1")
|
|
|
766
|
+ document.documentElement.style.setProperty('--camera-zoom', '1')
|
|
757
|
767
|
},
|
|
758
|
768
|
zoomCameraToActual(data) {
|
|
759
|
769
|
const { camera } = data
|
|
|
@@ -983,7 +993,7 @@ const state = createState({
|
|
983
|
993
|
|
|
984
|
994
|
if (selectedIds.size === 1) {
|
|
985
|
995
|
if (!shapes[0]) {
|
|
986
|
|
- console.error("Could not find that shape! Clearing selected IDs.")
|
|
|
996
|
+ console.error('Could not find that shape! Clearing selected IDs.')
|
|
987
|
997
|
data.selectedIds.clear()
|
|
988
|
998
|
return null
|
|
989
|
999
|
}
|