@jbrowse/plugin-config 1.6.9 → 1.7.0
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.js +123 -0
- package/dist/ConfigurationEditorWidget/components/CodeEditor.js +77 -0
- package/dist/ConfigurationEditorWidget/components/ColorEditor.js +125 -0
- package/dist/ConfigurationEditorWidget/components/ColorEditor.test.js +31 -0
- package/dist/ConfigurationEditorWidget/components/ColorPicker.js +72 -0
- package/dist/ConfigurationEditorWidget/components/ConfigurationEditor.js +176 -0
- package/dist/ConfigurationEditorWidget/components/ConfigurationEditor.test.js +121 -0
- package/dist/ConfigurationEditorWidget/components/JsonEditor.js +82 -0
- package/dist/ConfigurationEditorWidget/components/SlotEditor.js +438 -0
- package/dist/ConfigurationEditorWidget/components/TypeSelector.js +48 -0
- package/dist/ConfigurationEditorWidget/index.js +45 -0
- package/dist/ConfigurationEditorWidget/model.js +28 -0
- package/dist/FromConfigAdapter/FromConfigAdapter.js +215 -0
- package/dist/FromConfigAdapter/FromConfigAdapter.test.js +100 -0
- package/dist/FromConfigAdapter/FromConfigRegionsAdapter.js +154 -0
- package/dist/FromConfigAdapter/FromConfigRegionsAdapter.test.js +200 -0
- package/dist/FromConfigAdapter/FromConfigSequenceAdapter.js +201 -0
- package/dist/FromConfigAdapter/FromConfigSequenceAdapter.test.js +110 -0
- package/dist/FromConfigAdapter/configSchema.js +51 -0
- package/dist/FromConfigAdapter/index.js +51 -0
- package/dist/RefNameAliasAdapter/RefNameAliasAdapter.js +125 -0
- package/dist/RefNameAliasAdapter/RefNameAliasAdapter.test.js +41 -0
- package/dist/RefNameAliasAdapter/configSchema.js +26 -0
- package/dist/RefNameAliasAdapter/index.js +23 -0
- package/dist/index.js +150 -6
- package/dist/index.test.js +41 -0
- package/package.json +3 -6
- package/src/ConfigurationEditorWidget/components/ConfigurationEditor.js +22 -17
- package/src/ConfigurationEditorWidget/components/JsonEditor.js +1 -2
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports["default"] = void 0;
|
|
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 _jexlStrings = require("@jbrowse/core/util/jexlStrings");
|
|
19
|
+
|
|
20
|
+
var _core = require("@material-ui/core");
|
|
21
|
+
|
|
22
|
+
var _Help = _interopRequireDefault(require("@material-ui/icons/Help"));
|
|
23
|
+
|
|
24
|
+
var _mobxStateTree = require("mobx-state-tree");
|
|
25
|
+
|
|
26
|
+
var _mobxReact = require("mobx-react");
|
|
27
|
+
|
|
28
|
+
var _reactSimpleCodeEditor = _interopRequireDefault(require("react-simple-code-editor"));
|
|
29
|
+
|
|
30
|
+
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); }
|
|
31
|
+
|
|
32
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(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; }
|
|
33
|
+
|
|
34
|
+
// fontSize and fontFamily have to match between Editor and SyntaxHighlighter
|
|
35
|
+
var fontSize = '12px'; // Optimize by using system default fonts:
|
|
36
|
+
// https://css-tricks.com/snippets/css/font-stacks/
|
|
37
|
+
|
|
38
|
+
var fontFamily = 'Consolas, "Andale Mono WT", "Andale Mono", "Lucida Console", "Lucida Sans Typewriter", "DejaVu Sans Mono", "Bitstream Vera Sans Mono", "Liberation Mono", "Nimbus Mono L", Monaco, "Courier New", Courier, monospace';
|
|
39
|
+
var useStyles = (0, _core.makeStyles)(function (theme) {
|
|
40
|
+
return {
|
|
41
|
+
callbackEditor: {
|
|
42
|
+
marginTop: '16px',
|
|
43
|
+
borderBottom: "1px solid ".concat(theme.palette.divider),
|
|
44
|
+
fontFamily: fontFamily,
|
|
45
|
+
fontSize: fontSize
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
function CallbackEditor(_ref) {
|
|
51
|
+
var slot = _ref.slot;
|
|
52
|
+
var classes = useStyles();
|
|
53
|
+
|
|
54
|
+
var _useState = (0, _react.useState)(slot.value),
|
|
55
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
56
|
+
code = _useState2[0],
|
|
57
|
+
setCode = _useState2[1];
|
|
58
|
+
|
|
59
|
+
var _useState3 = (0, _react.useState)(),
|
|
60
|
+
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
|
|
61
|
+
error = _useState4[0],
|
|
62
|
+
setCodeError = _useState4[1];
|
|
63
|
+
|
|
64
|
+
var debouncedCode = (0, _util.useDebounce)(code, 400);
|
|
65
|
+
(0, _react.useEffect)(function () {
|
|
66
|
+
try {
|
|
67
|
+
var _getEnv$pluginManager;
|
|
68
|
+
|
|
69
|
+
var jexlDebouncedCode = debouncedCode.startsWith('jexl:') ? debouncedCode : "jexl:".concat(debouncedCode);
|
|
70
|
+
(0, _jexlStrings.stringToJexlExpression)(jexlDebouncedCode, (_getEnv$pluginManager = (0, _mobxStateTree.getEnv)(slot).pluginManager) === null || _getEnv$pluginManager === void 0 ? void 0 : _getEnv$pluginManager.jexl);
|
|
71
|
+
slot.set(jexlDebouncedCode);
|
|
72
|
+
setCodeError(null);
|
|
73
|
+
} catch (e) {
|
|
74
|
+
console.error({
|
|
75
|
+
e: e
|
|
76
|
+
});
|
|
77
|
+
setCodeError(e);
|
|
78
|
+
}
|
|
79
|
+
}, [debouncedCode, slot]); // if default value is a callback, will have to remove jexl:
|
|
80
|
+
// do this last
|
|
81
|
+
|
|
82
|
+
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_core.FormControl, null, /*#__PURE__*/_react["default"].createElement(_core.InputLabel, {
|
|
83
|
+
shrink: true,
|
|
84
|
+
htmlFor: "callback-editor"
|
|
85
|
+
}, slot.name), /*#__PURE__*/_react["default"].createElement(_reactSimpleCodeEditor["default"], {
|
|
86
|
+
className: classes.callbackEditor,
|
|
87
|
+
value: code.startsWith('jexl:') ? code.split('jexl:')[1] : code,
|
|
88
|
+
onValueChange: function onValueChange(newCode) {
|
|
89
|
+
return setCode(newCode);
|
|
90
|
+
},
|
|
91
|
+
highlight: function highlight(newCode) {
|
|
92
|
+
return newCode;
|
|
93
|
+
},
|
|
94
|
+
padding: 10,
|
|
95
|
+
style: {
|
|
96
|
+
background: error ? '#fdd' : undefined
|
|
97
|
+
}
|
|
98
|
+
}), error ? /*#__PURE__*/_react["default"].createElement(_core.FormHelperText, {
|
|
99
|
+
style: {
|
|
100
|
+
color: '#f00'
|
|
101
|
+
}
|
|
102
|
+
}, "".concat(error)) : null, /*#__PURE__*/_react["default"].createElement(_core.FormHelperText, null, slot.description)), /*#__PURE__*/_react["default"].createElement(_core.Tooltip, {
|
|
103
|
+
title: /*#__PURE__*/_react["default"].createElement("div", null, "Callbacks are written in Jexl format. Click to learn more.", /*#__PURE__*/_react["default"].createElement("br", null), " Names of available context items: ", slot.contextVariable),
|
|
104
|
+
arrow: true
|
|
105
|
+
}, /*#__PURE__*/_react["default"].createElement(_core.IconButton, {
|
|
106
|
+
color: "primary",
|
|
107
|
+
onClick: function onClick() {
|
|
108
|
+
var newWindow = window.open('https://github.com/TomFrost/Jexl', '_blank', 'noopener,noreferrer');
|
|
109
|
+
|
|
110
|
+
if (newWindow) {
|
|
111
|
+
newWindow.opener = null;
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
}, /*#__PURE__*/_react["default"].createElement(_Help["default"], null))));
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
CallbackEditor.propTypes = {
|
|
118
|
+
slot: _mobxReact.PropTypes.objectOrObservableObject.isRequired
|
|
119
|
+
};
|
|
120
|
+
|
|
121
|
+
var _default = (0, _mobxReact.observer)(CallbackEditor);
|
|
122
|
+
|
|
123
|
+
exports["default"] = _default;
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports["default"] = CodeEditor;
|
|
11
|
+
|
|
12
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
13
|
+
|
|
14
|
+
var _reactSimpleCodeEditor = _interopRequireDefault(require("react-simple-code-editor"));
|
|
15
|
+
|
|
16
|
+
var _reactSyntaxHighlighter = require("react-syntax-highlighter");
|
|
17
|
+
|
|
18
|
+
var _json = _interopRequireDefault(require("react-syntax-highlighter/dist/cjs/languages/hljs/json"));
|
|
19
|
+
|
|
20
|
+
var _a11yDark = _interopRequireDefault(require("react-syntax-highlighter/dist/cjs/styles/hljs/a11y-dark"));
|
|
21
|
+
|
|
22
|
+
var _a11yLight = _interopRequireDefault(require("react-syntax-highlighter/dist/cjs/styles/hljs/a11y-light"));
|
|
23
|
+
|
|
24
|
+
var _core = require("@material-ui/core");
|
|
25
|
+
|
|
26
|
+
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); }
|
|
27
|
+
|
|
28
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(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; }
|
|
29
|
+
|
|
30
|
+
// fontSize and fontFamily have to match between Editor and SyntaxHighlighter
|
|
31
|
+
var fontSize = '12px'; // Optimize by using system default fonts: https://css-tricks.com/snippets/css/font-stacks/
|
|
32
|
+
|
|
33
|
+
var fontFamily = 'Consolas, "Andale Mono WT", "Andale Mono", "Lucida Console", "Lucida Sans Typewriter", "DejaVu Sans Mono", "Bitstream Vera Sans Mono", "Liberation Mono", "Nimbus Mono L", Monaco, "Courier New", Courier, monospace';
|
|
34
|
+
var useStyles = (0, _core.makeStyles)({
|
|
35
|
+
callbackEditor: {
|
|
36
|
+
fontFamily: fontFamily,
|
|
37
|
+
fontSize: fontSize,
|
|
38
|
+
overflowX: 'auto',
|
|
39
|
+
marginTop: '16px',
|
|
40
|
+
borderBottom: '1px solid rgba(0,0,0,0.42)'
|
|
41
|
+
},
|
|
42
|
+
syntaxHighlighter: {
|
|
43
|
+
margin: 0,
|
|
44
|
+
fontFamily: fontFamily,
|
|
45
|
+
fontSize: fontSize
|
|
46
|
+
}
|
|
47
|
+
}); // eslint-disable-next-line react/prop-types
|
|
48
|
+
|
|
49
|
+
function CodeEditor(_ref) {
|
|
50
|
+
var contents = _ref.contents,
|
|
51
|
+
setContents = _ref.setContents;
|
|
52
|
+
var classes = useStyles();
|
|
53
|
+
var theme = (0, _core.useTheme)();
|
|
54
|
+
(0, _react.useEffect)(function () {
|
|
55
|
+
_reactSyntaxHighlighter.Light.registerLanguage('json', _json["default"]);
|
|
56
|
+
}, []);
|
|
57
|
+
return /*#__PURE__*/_react["default"].createElement(_reactSimpleCodeEditor["default"], {
|
|
58
|
+
className: classes.callbackEditor,
|
|
59
|
+
value: contents,
|
|
60
|
+
onValueChange: setContents,
|
|
61
|
+
highlight: function highlight(newCode) {
|
|
62
|
+
return /*#__PURE__*/_react["default"].createElement(_reactSyntaxHighlighter.Light, {
|
|
63
|
+
language: "json",
|
|
64
|
+
style: theme.palette.type === 'dark' ? _a11yDark["default"] : _a11yLight["default"],
|
|
65
|
+
className: classes.syntaxHighlighter // override some inline style stuff that's higher specificity
|
|
66
|
+
// than className
|
|
67
|
+
,
|
|
68
|
+
customStyle: {
|
|
69
|
+
background: 'none',
|
|
70
|
+
padding: 0
|
|
71
|
+
}
|
|
72
|
+
}, newCode);
|
|
73
|
+
},
|
|
74
|
+
padding: 10,
|
|
75
|
+
style: {}
|
|
76
|
+
});
|
|
77
|
+
}
|
|
@@ -0,0 +1,125 @@
|
|
|
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"] = exports.ColorSlot = void 0;
|
|
9
|
+
|
|
10
|
+
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
|
|
11
|
+
|
|
12
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
13
|
+
|
|
14
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
15
|
+
|
|
16
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
17
|
+
|
|
18
|
+
var _mobxReact = require("mobx-react");
|
|
19
|
+
|
|
20
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
21
|
+
|
|
22
|
+
var _TextField = _interopRequireDefault(require("@material-ui/core/TextField"));
|
|
23
|
+
|
|
24
|
+
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); }
|
|
25
|
+
|
|
26
|
+
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; }
|
|
27
|
+
|
|
28
|
+
var ColorPicker = /*#__PURE__*/(0, _react.lazy)(function () {
|
|
29
|
+
return Promise.resolve().then(function () {
|
|
30
|
+
return _interopRequireWildcard(require('./ColorPicker'));
|
|
31
|
+
});
|
|
32
|
+
}); // this is needed because passing a entire color object into the react-color
|
|
33
|
+
// for alpha, can't pass in an rgba string for example
|
|
34
|
+
|
|
35
|
+
function serializeColor(color) {
|
|
36
|
+
if (color instanceof Object) {
|
|
37
|
+
var _ref = color,
|
|
38
|
+
r = _ref.r,
|
|
39
|
+
g = _ref.g,
|
|
40
|
+
b = _ref.b,
|
|
41
|
+
a = _ref.a;
|
|
42
|
+
return a === undefined ? "rgb(".concat(r, ",").concat(g, ",").concat(b, ")") : "rgba(".concat(r, ",").concat(g, ",").concat(b, ",").concat(a, ")");
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
return color;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
var ColorSlot = function ColorSlot(props) {
|
|
49
|
+
var value = props.value,
|
|
50
|
+
label = props.label,
|
|
51
|
+
TextFieldProps = props.TextFieldProps,
|
|
52
|
+
_onChange = props.onChange;
|
|
53
|
+
|
|
54
|
+
var _useState = (0, _react.useState)(false),
|
|
55
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
56
|
+
displayed = _useState2[0],
|
|
57
|
+
setDisplayed = _useState2[1];
|
|
58
|
+
|
|
59
|
+
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_TextField["default"], (0, _extends2["default"])({
|
|
60
|
+
value: value,
|
|
61
|
+
label: label,
|
|
62
|
+
InputProps: {
|
|
63
|
+
style: {
|
|
64
|
+
color: value,
|
|
65
|
+
borderRightWidth: '25px',
|
|
66
|
+
borderRightStyle: 'solid',
|
|
67
|
+
borderRightColor: value
|
|
68
|
+
}
|
|
69
|
+
},
|
|
70
|
+
onClick: function onClick() {
|
|
71
|
+
return setDisplayed(!displayed);
|
|
72
|
+
},
|
|
73
|
+
onChange: function onChange(event) {
|
|
74
|
+
_onChange(event.target.value);
|
|
75
|
+
}
|
|
76
|
+
}, TextFieldProps)), displayed ? /*#__PURE__*/_react["default"].createElement(_react["default"].Suspense, {
|
|
77
|
+
fallback: /*#__PURE__*/_react["default"].createElement("div", null)
|
|
78
|
+
}, /*#__PURE__*/_react["default"].createElement(ColorPicker, {
|
|
79
|
+
color: value,
|
|
80
|
+
onChange: function onChange(event) {
|
|
81
|
+
_onChange(serializeColor(event.rgb));
|
|
82
|
+
}
|
|
83
|
+
})) : null);
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
exports.ColorSlot = ColorSlot;
|
|
87
|
+
ColorSlot.propTypes = {
|
|
88
|
+
onChange: _propTypes["default"].func.isRequired,
|
|
89
|
+
label: _propTypes["default"].string,
|
|
90
|
+
TextFieldProps: _propTypes["default"].shape({}),
|
|
91
|
+
value: _propTypes["default"].string
|
|
92
|
+
};
|
|
93
|
+
ColorSlot.defaultProps = {
|
|
94
|
+
label: '',
|
|
95
|
+
value: '#000',
|
|
96
|
+
TextFieldProps: {}
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
function ColorEditorSlot(props) {
|
|
100
|
+
var slot = props.slot;
|
|
101
|
+
return /*#__PURE__*/_react["default"].createElement(ColorSlot, {
|
|
102
|
+
label: slot.name,
|
|
103
|
+
value: slot.value,
|
|
104
|
+
onChange: function onChange(color) {
|
|
105
|
+
slot.set(color);
|
|
106
|
+
},
|
|
107
|
+
TextFieldProps: {
|
|
108
|
+
helperText: slot.description,
|
|
109
|
+
fullWidth: true
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
ColorEditorSlot.propTypes = {
|
|
115
|
+
slot: _propTypes["default"].shape({
|
|
116
|
+
name: _propTypes["default"].string.isRequired,
|
|
117
|
+
description: _propTypes["default"].string,
|
|
118
|
+
value: _propTypes["default"].string.isRequired,
|
|
119
|
+
set: _propTypes["default"].func.isRequired
|
|
120
|
+
}).isRequired
|
|
121
|
+
};
|
|
122
|
+
|
|
123
|
+
var _default = (0, _mobxReact.observer)(ColorEditorSlot);
|
|
124
|
+
|
|
125
|
+
exports["default"] = _default;
|
|
@@ -0,0 +1,31 @@
|
|
|
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 _ColorEditor = require("./ColorEditor");
|
|
10
|
+
|
|
11
|
+
describe('ColorPicker widget', function () {
|
|
12
|
+
it('can change value via the text field', function () {
|
|
13
|
+
var myfn = jest.fn();
|
|
14
|
+
|
|
15
|
+
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ColorEditor.ColorSlot, {
|
|
16
|
+
value: "green",
|
|
17
|
+
onChange: myfn
|
|
18
|
+
})),
|
|
19
|
+
getByDisplayValue = _render.getByDisplayValue;
|
|
20
|
+
|
|
21
|
+
var ret = getByDisplayValue('green');
|
|
22
|
+
|
|
23
|
+
_react2.fireEvent.change(ret, {
|
|
24
|
+
target: {
|
|
25
|
+
value: 'red'
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
expect(myfn).toHaveBeenCalledWith('red');
|
|
30
|
+
});
|
|
31
|
+
});
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports.ColorPicker = ColorPicker;
|
|
11
|
+
exports["default"] = void 0;
|
|
12
|
+
|
|
13
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
14
|
+
|
|
15
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
16
|
+
|
|
17
|
+
var _styles = require("@material-ui/core/styles");
|
|
18
|
+
|
|
19
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
20
|
+
|
|
21
|
+
var _reactColor = require("react-color");
|
|
22
|
+
|
|
23
|
+
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); }
|
|
24
|
+
|
|
25
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(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; }
|
|
26
|
+
|
|
27
|
+
var useStyles = (0, _styles.makeStyles)({
|
|
28
|
+
popover: {
|
|
29
|
+
position: 'absolute',
|
|
30
|
+
zIndex: 2
|
|
31
|
+
},
|
|
32
|
+
cover: {
|
|
33
|
+
position: 'fixed',
|
|
34
|
+
top: 0,
|
|
35
|
+
right: 0,
|
|
36
|
+
bottom: 0,
|
|
37
|
+
left: 0
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
function ColorPicker(props) {
|
|
42
|
+
var color = props.color,
|
|
43
|
+
onChange = props.onChange;
|
|
44
|
+
var classes = useStyles();
|
|
45
|
+
|
|
46
|
+
var _useState = (0, _react.useState)(true),
|
|
47
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
48
|
+
displayColorPicker = _useState2[0],
|
|
49
|
+
setDisplayColorPicker = _useState2[1];
|
|
50
|
+
|
|
51
|
+
var handleClose = function handleClose() {
|
|
52
|
+
setDisplayColorPicker(false);
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
return /*#__PURE__*/_react["default"].createElement("div", null, displayColorPicker ? /*#__PURE__*/_react["default"].createElement("div", {
|
|
56
|
+
className: classes.popover
|
|
57
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
58
|
+
role: "presentation",
|
|
59
|
+
className: classes.cover,
|
|
60
|
+
onClick: handleClose
|
|
61
|
+
}), /*#__PURE__*/_react["default"].createElement(_reactColor.ChromePicker, {
|
|
62
|
+
color: color,
|
|
63
|
+
onChange: onChange
|
|
64
|
+
})) : null);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
ColorPicker.propTypes = {
|
|
68
|
+
color: _propTypes["default"].string.isRequired,
|
|
69
|
+
onChange: _propTypes["default"].func.isRequired
|
|
70
|
+
};
|
|
71
|
+
var _default = ColorPicker;
|
|
72
|
+
exports["default"] = _default;
|
|
@@ -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;
|