@jbrowse/plugin-config 1.6.9 → 1.7.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/ConfigurationEditorWidget/components/CallbackEditor.d.ts +9 -9
- package/dist/ConfigurationEditorWidget/components/CallbackEditor.js +123 -0
- package/dist/ConfigurationEditorWidget/components/CodeEditor.d.ts +4 -4
- package/dist/ConfigurationEditorWidget/components/CodeEditor.js +77 -0
- package/dist/ConfigurationEditorWidget/components/ColorEditor.d.ts +44 -44
- package/dist/ConfigurationEditorWidget/components/ColorEditor.js +125 -0
- package/dist/ConfigurationEditorWidget/components/ColorEditor.test.js +31 -0
- package/dist/ConfigurationEditorWidget/components/ColorPicker.d.ts +14 -14
- package/dist/ConfigurationEditorWidget/components/ColorPicker.js +72 -0
- package/dist/ConfigurationEditorWidget/components/ConfigurationEditor.d.ts +4 -4
- package/dist/ConfigurationEditorWidget/components/ConfigurationEditor.js +176 -0
- package/dist/ConfigurationEditorWidget/components/ConfigurationEditor.test.js +121 -0
- package/dist/ConfigurationEditorWidget/components/JsonEditor.d.ts +9 -9
- package/dist/ConfigurationEditorWidget/components/JsonEditor.js +82 -0
- package/dist/ConfigurationEditorWidget/components/SlotEditor.d.ts +6 -6
- package/dist/ConfigurationEditorWidget/components/SlotEditor.js +438 -0
- package/dist/ConfigurationEditorWidget/components/TypeSelector.d.ts +7 -7
- package/dist/ConfigurationEditorWidget/components/TypeSelector.js +48 -0
- package/dist/ConfigurationEditorWidget/index.d.ts +3 -3
- package/dist/ConfigurationEditorWidget/index.js +45 -0
- package/dist/ConfigurationEditorWidget/model.d.ts +8 -8
- package/dist/ConfigurationEditorWidget/model.js +28 -0
- package/dist/FromConfigAdapter/FromConfigAdapter.d.ts +24 -24
- package/dist/FromConfigAdapter/FromConfigAdapter.js +215 -0
- package/dist/FromConfigAdapter/FromConfigAdapter.test.js +100 -0
- package/dist/FromConfigAdapter/FromConfigRegionsAdapter.d.ts +23 -23
- package/dist/FromConfigAdapter/FromConfigRegionsAdapter.js +154 -0
- package/dist/FromConfigAdapter/FromConfigRegionsAdapter.test.js +200 -0
- package/dist/FromConfigAdapter/FromConfigSequenceAdapter.d.ts +25 -25
- package/dist/FromConfigAdapter/FromConfigSequenceAdapter.js +201 -0
- package/dist/FromConfigAdapter/FromConfigSequenceAdapter.test.js +110 -0
- package/dist/FromConfigAdapter/configSchema.d.ts +3 -3
- package/dist/FromConfigAdapter/configSchema.js +51 -0
- package/dist/FromConfigAdapter/index.d.ts +4 -4
- package/dist/FromConfigAdapter/index.js +51 -0
- package/dist/RefNameAliasAdapter/RefNameAliasAdapter.d.ts +8 -8
- package/dist/RefNameAliasAdapter/RefNameAliasAdapter.js +125 -0
- package/dist/RefNameAliasAdapter/RefNameAliasAdapter.test.js +41 -0
- package/dist/RefNameAliasAdapter/configSchema.d.ts +2 -2
- package/dist/RefNameAliasAdapter/configSchema.js +26 -0
- package/dist/RefNameAliasAdapter/index.d.ts +2 -2
- package/dist/RefNameAliasAdapter/index.js +23 -0
- package/dist/index.d.ts +12 -12
- package/dist/index.js +150 -6
- package/dist/index.test.js +41 -0
- package/package.json +5 -7
- package/src/ConfigurationEditorWidget/components/ConfigurationEditor.js +22 -17
- package/src/ConfigurationEditorWidget/components/JsonEditor.js +1 -2
- package/dist/ConfigurationEditorWidget/components/ConfigurationEditor.test.d.ts +0 -1
- package/dist/index.test.d.ts +0 -1
- package/dist/plugin-config.cjs.development.js +0 -2740
- package/dist/plugin-config.cjs.development.js.map +0 -1
- package/dist/plugin-config.cjs.production.min.js +0 -2
- package/dist/plugin-config.cjs.production.min.js.map +0 -1
- package/dist/plugin-config.esm.js +0 -2732
- package/dist/plugin-config.esm.js.map +0 -1
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports["default"] = void 0;
|
|
9
|
+
|
|
10
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
11
|
+
|
|
12
|
+
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
13
|
+
|
|
14
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
15
|
+
|
|
16
|
+
var _react = _interopRequireDefault(require("react"));
|
|
17
|
+
|
|
18
|
+
var _configuration = require("@jbrowse/core/configuration");
|
|
19
|
+
|
|
20
|
+
var _core = require("@material-ui/core");
|
|
21
|
+
|
|
22
|
+
var _mobxReact = require("mobx-react");
|
|
23
|
+
|
|
24
|
+
var _mobxStateTree = require("mobx-state-tree");
|
|
25
|
+
|
|
26
|
+
var _pluralize = require("pluralize");
|
|
27
|
+
|
|
28
|
+
var _ExpandMore = _interopRequireDefault(require("@material-ui/icons/ExpandMore"));
|
|
29
|
+
|
|
30
|
+
var _SlotEditor = _interopRequireDefault(require("./SlotEditor"));
|
|
31
|
+
|
|
32
|
+
var _TypeSelector = _interopRequireDefault(require("./TypeSelector"));
|
|
33
|
+
|
|
34
|
+
// icons
|
|
35
|
+
// locals
|
|
36
|
+
var useStyles = (0, _core.makeStyles)(function (theme) {
|
|
37
|
+
return {
|
|
38
|
+
expandIcon: {
|
|
39
|
+
color: '#fff'
|
|
40
|
+
},
|
|
41
|
+
root: {
|
|
42
|
+
padding: theme.spacing(1, 3, 1, 1)
|
|
43
|
+
},
|
|
44
|
+
expansionPanelDetails: {
|
|
45
|
+
display: 'block',
|
|
46
|
+
padding: theme.spacing(1)
|
|
47
|
+
},
|
|
48
|
+
accordion: {
|
|
49
|
+
border: "1px solid ".concat(theme.palette.text.primary)
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
});
|
|
53
|
+
var Member = (0, _mobxReact.observer)(function (props) {
|
|
54
|
+
var classes = useStyles();
|
|
55
|
+
var slotName = props.slotName,
|
|
56
|
+
slotSchema = props.slotSchema,
|
|
57
|
+
schema = props.schema,
|
|
58
|
+
_props$slot = props.slot,
|
|
59
|
+
slot = _props$slot === void 0 ? schema[slotName] : _props$slot,
|
|
60
|
+
_props$path = props.path,
|
|
61
|
+
path = _props$path === void 0 ? [] : _props$path;
|
|
62
|
+
var typeSelector;
|
|
63
|
+
|
|
64
|
+
if ((0, _configuration.isConfigurationSchemaType)(slotSchema)) {
|
|
65
|
+
if (slot.length) {
|
|
66
|
+
return slot.map(function (subslot, slotIndex) {
|
|
67
|
+
var key = "".concat((0, _pluralize.singular)(slotName), " ").concat(slotIndex + 1);
|
|
68
|
+
return /*#__PURE__*/_react["default"].createElement(Member, (0, _extends2["default"])({}, props, {
|
|
69
|
+
key: key,
|
|
70
|
+
slot: subslot,
|
|
71
|
+
slotName: key
|
|
72
|
+
}));
|
|
73
|
+
});
|
|
74
|
+
} // if this is an explicitly typed schema, make a type-selecting dropdown
|
|
75
|
+
// that can be used to change its type
|
|
76
|
+
|
|
77
|
+
|
|
78
|
+
var typeNameChoices = (0, _configuration.getTypeNamesFromExplicitlyTypedUnion)(slotSchema);
|
|
79
|
+
|
|
80
|
+
if (typeNameChoices.length) {
|
|
81
|
+
typeSelector = /*#__PURE__*/_react["default"].createElement(_TypeSelector["default"], {
|
|
82
|
+
typeNameChoices: typeNameChoices,
|
|
83
|
+
slotName: slotName,
|
|
84
|
+
slot: slot,
|
|
85
|
+
onChange: function onChange(evt) {
|
|
86
|
+
if (evt.target.value !== slot.type) {
|
|
87
|
+
schema.setSubschema(slotName, {
|
|
88
|
+
type: evt.target.value
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
return /*#__PURE__*/_react["default"].createElement(_core.Accordion, {
|
|
96
|
+
defaultExpanded: true,
|
|
97
|
+
className: classes.accordion,
|
|
98
|
+
TransitionProps: {
|
|
99
|
+
unmountOnExit: true,
|
|
100
|
+
timeout: 150
|
|
101
|
+
}
|
|
102
|
+
}, /*#__PURE__*/_react["default"].createElement(_core.AccordionSummary, {
|
|
103
|
+
expandIcon: /*#__PURE__*/_react["default"].createElement(_ExpandMore["default"], {
|
|
104
|
+
className: classes.expandIcon
|
|
105
|
+
})
|
|
106
|
+
}, /*#__PURE__*/_react["default"].createElement(_core.Typography, null, [].concat((0, _toConsumableArray2["default"])(path), [slotName]).join('🡒'))), /*#__PURE__*/_react["default"].createElement(_core.AccordionDetails, {
|
|
107
|
+
className: classes.expansionPanelDetails
|
|
108
|
+
}, typeSelector, /*#__PURE__*/_react["default"].createElement(_core.FormGroup, null, /*#__PURE__*/_react["default"].createElement(Schema, {
|
|
109
|
+
schema: slot,
|
|
110
|
+
path: [].concat((0, _toConsumableArray2["default"])(path), [slotName])
|
|
111
|
+
}))));
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
if ((0, _configuration.isConfigurationSlotType)(slotSchema)) {
|
|
115
|
+
// this is a regular config slot
|
|
116
|
+
return /*#__PURE__*/_react["default"].createElement(_SlotEditor["default"], {
|
|
117
|
+
key: slotName,
|
|
118
|
+
slot: slot,
|
|
119
|
+
slotSchema: slotSchema
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
return null;
|
|
124
|
+
});
|
|
125
|
+
var Schema = (0, _mobxReact.observer)(function (_ref) {
|
|
126
|
+
var schema = _ref.schema,
|
|
127
|
+
_ref$path = _ref.path,
|
|
128
|
+
path = _ref$path === void 0 ? [] : _ref$path;
|
|
129
|
+
var properties = (0, _mobxStateTree.getMembers)(schema).properties;
|
|
130
|
+
return Object.entries(properties).map(function (_ref2) {
|
|
131
|
+
var _ref3 = (0, _slicedToArray2["default"])(_ref2, 2),
|
|
132
|
+
slotName = _ref3[0],
|
|
133
|
+
slotSchema = _ref3[1];
|
|
134
|
+
|
|
135
|
+
return /*#__PURE__*/_react["default"].createElement(Member, {
|
|
136
|
+
key: slotName,
|
|
137
|
+
slotName: slotName,
|
|
138
|
+
slotSchema: slotSchema,
|
|
139
|
+
path: path,
|
|
140
|
+
schema: schema
|
|
141
|
+
});
|
|
142
|
+
});
|
|
143
|
+
});
|
|
144
|
+
var ConfigurationEditor = (0, _mobxReact.observer)(function (_ref4) {
|
|
145
|
+
var model = _ref4.model;
|
|
146
|
+
var classes = useStyles(); // key forces a re-render, otherwise the same field can end up being used
|
|
147
|
+
// for different tracks since only the backing model changes for example
|
|
148
|
+
// see pr #804
|
|
149
|
+
|
|
150
|
+
var key = model.target && (0, _configuration.readConfObject)(model.target, 'trackId');
|
|
151
|
+
var name = model.target && (0, _configuration.readConfObject)(model.target, 'name');
|
|
152
|
+
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_core.Accordion, {
|
|
153
|
+
key: key,
|
|
154
|
+
defaultExpanded: true,
|
|
155
|
+
className: classes.accordion,
|
|
156
|
+
TransitionProps: {
|
|
157
|
+
unmountOnExit: true,
|
|
158
|
+
timeout: 150
|
|
159
|
+
}
|
|
160
|
+
}, /*#__PURE__*/_react["default"].createElement(_core.AccordionSummary, {
|
|
161
|
+
expandIcon: /*#__PURE__*/_react["default"].createElement(_ExpandMore["default"], {
|
|
162
|
+
className: classes.expandIcon
|
|
163
|
+
})
|
|
164
|
+
}, /*#__PURE__*/_react["default"].createElement(_core.Typography, null, name ? name : 'Configuration')), /*#__PURE__*/_react["default"].createElement(_core.AccordionDetails, {
|
|
165
|
+
className: classes.expansionPanelDetails,
|
|
166
|
+
"data-testid": "configEditor"
|
|
167
|
+
}, !model.target ? 'no target set' : /*#__PURE__*/_react["default"].createElement(Schema, {
|
|
168
|
+
schema: model.target
|
|
169
|
+
}))), /*#__PURE__*/_react["default"].createElement("div", {
|
|
170
|
+
style: {
|
|
171
|
+
height: 300
|
|
172
|
+
}
|
|
173
|
+
}));
|
|
174
|
+
});
|
|
175
|
+
var _default = ConfigurationEditor;
|
|
176
|
+
exports["default"] = _default;
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _react = _interopRequireDefault(require("react"));
|
|
6
|
+
|
|
7
|
+
var _react2 = require("@testing-library/react");
|
|
8
|
+
|
|
9
|
+
var _configuration = require("@jbrowse/core/configuration");
|
|
10
|
+
|
|
11
|
+
var _PluginManager = _interopRequireDefault(require("@jbrowse/core/PluginManager"));
|
|
12
|
+
|
|
13
|
+
var _pluginAlignments = _interopRequireDefault(require("@jbrowse/plugin-alignments"));
|
|
14
|
+
|
|
15
|
+
var _pluginSvg = _interopRequireDefault(require("@jbrowse/plugin-svg"));
|
|
16
|
+
|
|
17
|
+
var _pluginLinearGenomeView = require("@jbrowse/plugin-linear-genome-view");
|
|
18
|
+
|
|
19
|
+
var _ConfigurationEditor = _interopRequireDefault(require("./ConfigurationEditor"));
|
|
20
|
+
|
|
21
|
+
describe('ConfigurationEditor widget', function () {
|
|
22
|
+
it('renders with just the required model elements', function () {
|
|
23
|
+
var TestSchema = (0, _configuration.ConfigurationSchema)('TestThing', {
|
|
24
|
+
foo: {
|
|
25
|
+
type: 'string',
|
|
26
|
+
defaultValue: 'bar'
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ConfigurationEditor["default"], {
|
|
31
|
+
model: {
|
|
32
|
+
target: TestSchema.create()
|
|
33
|
+
}
|
|
34
|
+
})),
|
|
35
|
+
container = _render.container;
|
|
36
|
+
|
|
37
|
+
expect(container.firstChild).toMatchSnapshot();
|
|
38
|
+
});
|
|
39
|
+
it('renders all the different types of built-in slots', function () {
|
|
40
|
+
var TestSchema = (0, _configuration.ConfigurationSchema)('TestThing', {
|
|
41
|
+
stringTest: {
|
|
42
|
+
name: 'stringTest',
|
|
43
|
+
description: 'stringTest',
|
|
44
|
+
type: 'string',
|
|
45
|
+
defaultValue: 'string1'
|
|
46
|
+
},
|
|
47
|
+
fileLocationTest: {
|
|
48
|
+
name: 'fileLocationTest',
|
|
49
|
+
description: 'fileLocationTest',
|
|
50
|
+
type: 'fileLocation',
|
|
51
|
+
defaultValue: {
|
|
52
|
+
uri: '/path/to/my.file',
|
|
53
|
+
locationType: 'UriLocation'
|
|
54
|
+
}
|
|
55
|
+
},
|
|
56
|
+
stringArrayTest: {
|
|
57
|
+
name: 'stringArrayTest',
|
|
58
|
+
description: 'stringArrayTest',
|
|
59
|
+
type: 'stringArray',
|
|
60
|
+
defaultValue: ['string1', 'string2']
|
|
61
|
+
},
|
|
62
|
+
stringArrayMapTest: {
|
|
63
|
+
name: 'stringArrayMapTest',
|
|
64
|
+
description: 'stringArrayMapTest',
|
|
65
|
+
type: 'stringArrayMap',
|
|
66
|
+
defaultValue: {
|
|
67
|
+
key1: ['string1', 'string2']
|
|
68
|
+
}
|
|
69
|
+
},
|
|
70
|
+
numberTest: {
|
|
71
|
+
name: 'numberTest',
|
|
72
|
+
description: 'numberTest',
|
|
73
|
+
type: 'number',
|
|
74
|
+
defaultValue: 88.5
|
|
75
|
+
},
|
|
76
|
+
integerTest: {
|
|
77
|
+
name: 'integerTest',
|
|
78
|
+
description: 'integerTest',
|
|
79
|
+
type: 'integer',
|
|
80
|
+
defaultValue: 42
|
|
81
|
+
},
|
|
82
|
+
colorTest: {
|
|
83
|
+
name: 'colorTest',
|
|
84
|
+
description: 'colorTest',
|
|
85
|
+
type: 'color',
|
|
86
|
+
defaultValue: '#396494'
|
|
87
|
+
},
|
|
88
|
+
booleanTest: {
|
|
89
|
+
name: 'booleanTest',
|
|
90
|
+
description: 'booleanTest',
|
|
91
|
+
type: 'boolean',
|
|
92
|
+
defaultValue: true
|
|
93
|
+
}
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ConfigurationEditor["default"], {
|
|
97
|
+
model: {
|
|
98
|
+
target: TestSchema.create()
|
|
99
|
+
}
|
|
100
|
+
})),
|
|
101
|
+
container = _render2.container;
|
|
102
|
+
|
|
103
|
+
expect(container.firstChild).toMatchSnapshot();
|
|
104
|
+
});
|
|
105
|
+
it('renders with defaults of the PileupTrack schema', function () {
|
|
106
|
+
console.warn = jest.fn();
|
|
107
|
+
var pluginManager = new _PluginManager["default"]([new _pluginAlignments["default"](), new _pluginSvg["default"]()]);
|
|
108
|
+
pluginManager.createPluggableElements();
|
|
109
|
+
pluginManager.configure();
|
|
110
|
+
var PileupDisplaySchema = (0, _pluginLinearGenomeView.linearBasicDisplayConfigSchemaFactory)(pluginManager);
|
|
111
|
+
|
|
112
|
+
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ConfigurationEditor["default"], {
|
|
113
|
+
model: {
|
|
114
|
+
target: PileupDisplaySchema.create()
|
|
115
|
+
}
|
|
116
|
+
})),
|
|
117
|
+
container = _render3.container;
|
|
118
|
+
|
|
119
|
+
expect(container.firstChild).toMatchSnapshot();
|
|
120
|
+
});
|
|
121
|
+
});
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
declare function _default({ slot }: {
|
|
2
|
-
slot: any;
|
|
3
|
-
}): JSX.Element;
|
|
4
|
-
declare namespace _default {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
}
|
|
8
|
-
}
|
|
9
|
-
export default _default;
|
|
1
|
+
declare function _default({ slot }: {
|
|
2
|
+
slot: any;
|
|
3
|
+
}): JSX.Element;
|
|
4
|
+
declare namespace _default {
|
|
5
|
+
namespace propTypes {
|
|
6
|
+
const slot: import("prop-types").Validator<any>;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
export default _default;
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports["default"] = void 0;
|
|
9
|
+
|
|
10
|
+
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
|
|
11
|
+
|
|
12
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
13
|
+
|
|
14
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
15
|
+
|
|
16
|
+
var _util = require("@jbrowse/core/util");
|
|
17
|
+
|
|
18
|
+
var _core = require("@material-ui/core");
|
|
19
|
+
|
|
20
|
+
var _mobxReact = require("mobx-react");
|
|
21
|
+
|
|
22
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
23
|
+
|
|
24
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || (0, _typeof2["default"])(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
25
|
+
|
|
26
|
+
var useStyles = (0, _core.makeStyles)({
|
|
27
|
+
error: {
|
|
28
|
+
color: 'red',
|
|
29
|
+
fontSize: '0.8em'
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
var CodeEditor = /*#__PURE__*/(0, _react.lazy)(function () {
|
|
33
|
+
return Promise.resolve().then(function () {
|
|
34
|
+
return _interopRequireWildcard(require('./CodeEditor'));
|
|
35
|
+
});
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
function JsonEditor(_ref) {
|
|
39
|
+
var slot = _ref.slot;
|
|
40
|
+
var classes = useStyles();
|
|
41
|
+
|
|
42
|
+
var _useState = (0, _react.useState)(JSON.stringify(slot.value, null, ' ')),
|
|
43
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
44
|
+
contents = _useState2[0],
|
|
45
|
+
setContents = _useState2[1];
|
|
46
|
+
|
|
47
|
+
var _useState3 = (0, _react.useState)(),
|
|
48
|
+
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
|
|
49
|
+
error = _useState4[0],
|
|
50
|
+
setError = _useState4[1];
|
|
51
|
+
|
|
52
|
+
var debouncedJson = (0, _util.useDebounce)(contents, 400);
|
|
53
|
+
(0, _react.useEffect)(function () {
|
|
54
|
+
try {
|
|
55
|
+
slot.set(JSON.parse(debouncedJson));
|
|
56
|
+
setError(undefined);
|
|
57
|
+
} catch (e) {
|
|
58
|
+
setError(e.message);
|
|
59
|
+
}
|
|
60
|
+
}, [debouncedJson, slot]);
|
|
61
|
+
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, error ? /*#__PURE__*/_react["default"].createElement("p", {
|
|
62
|
+
className: classes.error
|
|
63
|
+
}, error) : null, /*#__PURE__*/_react["default"].createElement(_core.FormControl, {
|
|
64
|
+
error: error
|
|
65
|
+
}, /*#__PURE__*/_react["default"].createElement(_core.InputLabel, {
|
|
66
|
+
shrink: true,
|
|
67
|
+
htmlFor: "callback-editor"
|
|
68
|
+
}, slot.name), /*#__PURE__*/_react["default"].createElement(_react["default"].Suspense, {
|
|
69
|
+
fallback: /*#__PURE__*/_react["default"].createElement("div", null)
|
|
70
|
+
}, /*#__PURE__*/_react["default"].createElement(CodeEditor, {
|
|
71
|
+
contents: contents,
|
|
72
|
+
setContents: setContents
|
|
73
|
+
})), /*#__PURE__*/_react["default"].createElement(_core.FormHelperText, null, slot.description)));
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
JsonEditor.propTypes = {
|
|
77
|
+
slot: _mobxReact.PropTypes.objectOrObservableObject.isRequired
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
var _default = (0, _mobxReact.observer)(JsonEditor);
|
|
81
|
+
|
|
82
|
+
exports["default"] = _default;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
export const useSlotEditorStyles: (props?: any) =>
|
|
2
|
-
export default SlotEditor;
|
|
3
|
-
declare function SlotEditor({ slot, slotSchema }: {
|
|
4
|
-
slot: any;
|
|
5
|
-
slotSchema: any;
|
|
6
|
-
}): JSX.Element;
|
|
1
|
+
export const useSlotEditorStyles: (props?: any) => import("@material-ui/styles").ClassNameMap<"paper" | "paperContent" | "slotModeSwitch">;
|
|
2
|
+
export default SlotEditor;
|
|
3
|
+
declare function SlotEditor({ slot, slotSchema }: {
|
|
4
|
+
slot: any;
|
|
5
|
+
slotSchema: any;
|
|
6
|
+
}): JSX.Element;
|