1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
| import { getType, types } from "mobx-state-tree";
|
| export const EditableRegion = types
| .model("EditableRegion")
| .volatile(() => ({
| editorEnabled: true,
| /**
| * Adding properties to the editableFields array on the
| * target model will make them editable in the details panel.
| */
| editableFields: [
| // { property: "x", label: "X" },
| ],
| }))
| .views((self) => ({
| getProperty(name) {
| return self[name];
| },
|
| getPropertyType(name) {
| return getType(self).properties[name];
| },
|
| isPropertyEditable(name) {
| return self.editableFields.some((f) => f.property === name);
| },
|
| get hasEditableFields() {
| return self.editableFields.length > 0;
| },
| }))
| .actions((self) => ({
| setProperty(propName, value) {
| if (self.isPropertyEditable(propName)) {
| self[propName] = value;
| } else {
| throw new Error(`Property ${propName} of model ${self.type} is not editable`);
| }
| },
| }));
|
|