@jbrowse/core 1.7.11 → 2.1.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.
Files changed (204) hide show
  1. package/BaseFeatureWidget/BaseFeatureDetail.d.ts +20 -4
  2. package/BaseFeatureWidget/BaseFeatureDetail.js +313 -558
  3. package/BaseFeatureWidget/SequenceFeatureDetails.js +213 -473
  4. package/BaseFeatureWidget/index.d.ts +2 -2
  5. package/BaseFeatureWidget/index.js +88 -124
  6. package/BaseFeatureWidget/types.d.ts +1 -0
  7. package/BaseFeatureWidget/types.js +1 -4
  8. package/BaseFeatureWidget/util.js +40 -75
  9. package/CorePlugin.js +55 -94
  10. package/Plugin.js +9 -34
  11. package/PluginLoader.js +153 -422
  12. package/PluginManager.d.ts +84 -117
  13. package/PluginManager.js +377 -666
  14. package/ReExports/Attributes.d.ts +2 -0
  15. package/ReExports/Attributes.js +5 -0
  16. package/ReExports/BaseCard.d.ts +2 -0
  17. package/ReExports/BaseCard.js +5 -0
  18. package/ReExports/DataGrid.d.ts +2 -0
  19. package/ReExports/DataGrid.js +6 -0
  20. package/ReExports/FeatureDetails.d.ts +2 -0
  21. package/ReExports/FeatureDetails.js +5 -0
  22. package/ReExports/index.js +6 -12
  23. package/ReExports/list.d.ts +5 -0
  24. package/ReExports/list.js +271 -7
  25. package/ReExports/material-ui-colors.d.ts +1 -19
  26. package/ReExports/material-ui-colors.js +16 -158
  27. package/ReExports/modules.d.ts +68 -109
  28. package/ReExports/modules.js +455 -244
  29. package/TextSearch/BaseResults.js +51 -123
  30. package/TextSearch/TextSearchManager.d.ts +3 -1
  31. package/TextSearch/TextSearchManager.js +66 -144
  32. package/assemblyManager/assembly.js +280 -554
  33. package/assemblyManager/assemblyConfigSchema.js +47 -64
  34. package/assemblyManager/assemblyManager.d.ts +12 -10
  35. package/assemblyManager/assemblyManager.js +126 -270
  36. package/assemblyManager/index.js +9 -22
  37. package/configuration/configurationSchema.js +167 -203
  38. package/configuration/configurationSlot.js +248 -326
  39. package/configuration/index.js +19 -35
  40. package/configuration/util.d.ts +1 -1
  41. package/configuration/util.js +131 -173
  42. package/data_adapters/BaseAdapter.d.ts +2 -2
  43. package/data_adapters/BaseAdapter.js +132 -521
  44. package/data_adapters/CytobandAdapter.js +40 -126
  45. package/data_adapters/dataAdapterCache.js +77 -158
  46. package/package.json +16 -18
  47. package/pluggableElementTypes/AdapterType.js +24 -79
  48. package/pluggableElementTypes/AddTrackWorkflowType.d.ts +17 -0
  49. package/pluggableElementTypes/AddTrackWorkflowType.js +20 -0
  50. package/pluggableElementTypes/ConnectionType.js +22 -65
  51. package/pluggableElementTypes/DisplayType.js +35 -82
  52. package/pluggableElementTypes/InternetAccountType.js +23 -64
  53. package/pluggableElementTypes/PluggableElementBase.js +8 -20
  54. package/pluggableElementTypes/RpcMethodType.js +85 -427
  55. package/pluggableElementTypes/TextSearchAdapterType.js +16 -55
  56. package/pluggableElementTypes/TrackType.js +26 -70
  57. package/pluggableElementTypes/ViewType.js +21 -63
  58. package/pluggableElementTypes/WidgetType.js +21 -64
  59. package/pluggableElementTypes/index.d.ts +4 -3
  60. package/pluggableElementTypes/index.js +42 -125
  61. package/pluggableElementTypes/models/BaseConnectionModelFactory.js +28 -43
  62. package/pluggableElementTypes/models/BaseDisplayModel.d.ts +10 -10
  63. package/pluggableElementTypes/models/BaseDisplayModel.js +58 -95
  64. package/pluggableElementTypes/models/BaseTrackModel.d.ts +1 -1
  65. package/pluggableElementTypes/models/BaseTrackModel.js +139 -200
  66. package/pluggableElementTypes/models/BaseViewModel.js +24 -40
  67. package/pluggableElementTypes/models/InternetAccountModel.js +116 -263
  68. package/pluggableElementTypes/models/baseConnectionConfig.js +14 -25
  69. package/pluggableElementTypes/models/baseInternetAccountConfig.js +29 -38
  70. package/pluggableElementTypes/models/baseTrackConfig.js +106 -133
  71. package/pluggableElementTypes/models/index.js +21 -70
  72. package/pluggableElementTypes/renderers/BoxRendererType.js +132 -291
  73. package/pluggableElementTypes/renderers/CircularChordRendererType.js +8 -38
  74. package/pluggableElementTypes/renderers/ComparativeServerSideRendererType.js +60 -192
  75. package/pluggableElementTypes/renderers/FeatureRendererType.d.ts +0 -2
  76. package/pluggableElementTypes/renderers/FeatureRendererType.js +89 -255
  77. package/pluggableElementTypes/renderers/RendererType.js +31 -105
  78. package/pluggableElementTypes/renderers/ServerSideRenderedContent.js +61 -72
  79. package/pluggableElementTypes/renderers/ServerSideRendererType.d.ts +2 -2
  80. package/pluggableElementTypes/renderers/ServerSideRendererType.js +112 -265
  81. package/pluggableElementTypes/renderers/index.js +19 -62
  82. package/pluggableElementTypes/renderers/util/serializableFilterChain.js +27 -65
  83. package/rpc/BaseRpcDriver.js +169 -405
  84. package/rpc/MainThreadRpcDriver.js +27 -150
  85. package/rpc/RpcManager.js +58 -159
  86. package/rpc/WebWorkerRpcDriver.js +54 -171
  87. package/rpc/configSchema.js +25 -49
  88. package/rpc/coreRpcMethods.d.ts +1 -3
  89. package/rpc/coreRpcMethods.js +221 -959
  90. package/rpc/remoteAbortSignals.js +46 -70
  91. package/tsconfig.build.tsbuildinfo +1 -1
  92. package/ui/AboutDialog.js +107 -158
  93. package/ui/App.js +157 -261
  94. package/ui/AssemblySelector.d.ts +1 -1
  95. package/ui/AssemblySelector.js +59 -115
  96. package/ui/CascadingMenu.js +100 -199
  97. package/ui/ColorPicker.d.ts +16 -0
  98. package/ui/ColorPicker.js +97 -0
  99. package/ui/Drawer.js +28 -58
  100. package/ui/DrawerWidget.js +109 -209
  101. package/ui/DropDownMenu.d.ts +0 -8
  102. package/ui/DropDownMenu.js +60 -97
  103. package/ui/EditableTypography.d.ts +1 -1
  104. package/ui/EditableTypography.js +87 -155
  105. package/ui/ErrorMessage.js +41 -66
  106. package/ui/FactoryResetDialog.js +24 -57
  107. package/ui/FatalErrorDialog.js +59 -91
  108. package/ui/FileSelector/FileSelector.js +123 -189
  109. package/ui/FileSelector/LocalFileChooser.js +44 -71
  110. package/ui/FileSelector/UrlChooser.js +17 -38
  111. package/ui/FileSelector/index.js +6 -12
  112. package/ui/Icons.d.ts +1 -1
  113. package/ui/Icons.js +45 -69
  114. package/ui/Logo.js +57 -110
  115. package/ui/Menu.d.ts +1 -1
  116. package/ui/Menu.js +232 -355
  117. package/ui/PrerenderedCanvas.js +63 -78
  118. package/ui/ResizeHandle.js +87 -114
  119. package/ui/ReturnToImportFormDialog.js +32 -59
  120. package/ui/SanitizedHTML.js +63 -52
  121. package/ui/Snackbar.js +74 -99
  122. package/ui/SnackbarModel.js +37 -51
  123. package/ui/Tooltip.d.ts +3 -1
  124. package/ui/Tooltip.js +49 -74
  125. package/ui/ViewContainer.js +113 -183
  126. package/ui/colors.d.ts +10 -0
  127. package/ui/colors.js +78 -0
  128. package/ui/index.js +51 -181
  129. package/ui/react-colorful.d.ts +17 -0
  130. package/ui/react-colorful.js +455 -0
  131. package/ui/theme.d.ts +279 -131
  132. package/ui/theme.js +197 -225
  133. package/util/Base1DUtils.d.ts +32 -0
  134. package/util/Base1DUtils.js +174 -0
  135. package/util/Base1DViewModel.d.ts +16 -37
  136. package/util/Base1DViewModel.js +116 -295
  137. package/util/QuickLRU.js +84 -332
  138. package/util/TimeTraveller.d.ts +19 -0
  139. package/util/TimeTraveller.js +86 -0
  140. package/util/aborting.js +49 -127
  141. package/util/analytics.js +91 -154
  142. package/util/blockTypes.js +106 -240
  143. package/util/calculateDynamicBlocks.js +98 -128
  144. package/util/calculateStaticBlocks.js +105 -125
  145. package/util/color/cssColorsLevel4.js +156 -160
  146. package/util/color/index.js +33 -55
  147. package/util/compositeMap.js +49 -333
  148. package/util/formatFastaStrings.js +9 -14
  149. package/util/idMaker.js +18 -31
  150. package/util/index.d.ts +18 -39
  151. package/util/index.js +743 -1236
  152. package/util/io/RemoteFileWithRangeCache.js +88 -257
  153. package/util/io/index.js +95 -169
  154. package/util/jexl.js +60 -115
  155. package/util/jexlStrings.js +24 -29
  156. package/util/layouts/BaseLayout.js +1 -4
  157. package/util/layouts/GranularRectLayout.js +388 -557
  158. package/util/layouts/MultiLayout.js +41 -109
  159. package/util/layouts/PrecomputedLayout.js +56 -114
  160. package/util/layouts/PrecomputedMultiLayout.js +22 -59
  161. package/util/layouts/SceneGraph.js +127 -197
  162. package/util/layouts/index.js +29 -66
  163. package/util/mst-reflection.js +55 -71
  164. package/util/offscreenCanvasPonyfill.js +66 -134
  165. package/util/offscreenCanvasUtils.d.ts +2 -7
  166. package/util/offscreenCanvasUtils.js +49 -146
  167. package/util/range.js +29 -40
  168. package/util/rxjs.js +20 -27
  169. package/util/simpleFeature.js +88 -152
  170. package/util/stats.js +91 -151
  171. package/util/tracks.js +130 -171
  172. package/util/types/index.d.ts +3 -3
  173. package/util/types/index.js +110 -179
  174. package/util/types/mst.d.ts +3 -3
  175. package/util/types/mst.js +91 -142
  176. package/util/types/util.js +1 -4
  177. package/util/when.js +54 -101
  178. package/BaseFeatureWidget/SequenceFeatureDetails.test.js +0 -122
  179. package/BaseFeatureWidget/index.test.js +0 -51
  180. package/TextSearch/BaseResults.test.js +0 -42
  181. package/configuration/configurationSchema.test.js +0 -266
  182. package/configuration/configurationSlot.test.js +0 -69
  183. package/configuration/util.test.js +0 -39
  184. package/data_adapters/BaseAdapter.test.js +0 -200
  185. package/declare.d.js +0 -1
  186. package/pluggableElementTypes/RpcMethodType.test.js +0 -118
  187. package/pluggableElementTypes/renderers/declare.d.js +0 -1
  188. package/pluggableElementTypes/renderers/util/serializableFilterChain.test.js +0 -20
  189. package/rpc/BaseRpcDriver.test.js +0 -540
  190. package/rpc/declaration.d.js +0 -1
  191. package/ui/FatalErrorDialog.test.js +0 -82
  192. package/ui/SanitizedHTML.test.js +0 -36
  193. package/ui/theme.test.js +0 -111
  194. package/util/Base1DViewModel.test.js +0 -130
  195. package/util/calculateDynamicBlocks.test.js +0 -74
  196. package/util/calculateStaticBlocks.test.js +0 -297
  197. package/util/declare.d.js +0 -1
  198. package/util/formatFastaStrings.test.js +0 -40
  199. package/util/index.test.js +0 -213
  200. package/util/jexlStrings.test.js +0 -48
  201. package/util/layouts/GranularRectLayout.test.js +0 -99
  202. package/util/range.test.js +0 -64
  203. package/util/simpleFeature.test.js +0 -34
  204. package/util/stats.test.js +0 -172
@@ -1,211 +1,112 @@
1
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
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
9
17
  });
10
- exports.default = void 0;
11
-
12
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
-
14
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
15
-
16
- var _react = _interopRequireWildcard(require("react"));
17
-
18
- var _core = require("@material-ui/core");
19
-
20
- var _Menu = require("./Menu");
21
-
22
- var _hooks = require("material-ui-popup-state/hooks");
23
-
24
- var _HoverMenu = _interopRequireDefault(require("material-ui-popup-state/HoverMenu"));
25
-
26
- var _ChevronRight = _interopRequireDefault(require("@material-ui/icons/ChevronRight"));
27
-
28
- var _excluded = ["onClick"],
29
- _excluded2 = ["title", "inset", "popupId"],
30
- _excluded3 = ["popupState", "onMenuItemClick", "menuItems", "classes"],
31
- _excluded4 = ["popupState", "onMenuItemClick", "menuItems"],
32
- _excluded5 = ["onMenuItemClick", "menuItems"];
33
-
34
- 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); }
35
-
36
- 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; }
37
-
38
- var CascadingContext = /*#__PURE__*/_react.default.createContext({
39
- parentPopupState: null,
40
- rootPopupState: null
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ const react_1 = __importStar(require("react"));
30
+ const material_1 = require("@mui/material");
31
+ const Menu_1 = require("./Menu");
32
+ const hooks_1 = require("material-ui-popup-state/hooks");
33
+ const HoverMenu_1 = __importDefault(require("material-ui-popup-state/HoverMenu"));
34
+ const ChevronRight_1 = __importDefault(require("@mui/icons-material/ChevronRight"));
35
+ const CascadingContext = react_1.default.createContext({
36
+ parentPopupState: null,
37
+ rootPopupState: null,
41
38
  });
42
-
43
- function CascadingMenuItem(_ref) {
44
- var onClick = _ref.onClick,
45
- props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
46
-
47
- var _useContext = (0, _react.useContext)(CascadingContext),
48
- rootPopupState = _useContext.rootPopupState;
49
-
50
- if (!rootPopupState) {
51
- throw new Error('must be used inside a CascadingMenu');
52
- }
53
-
54
- var handleClick = (0, _react.useCallback)(function (event) {
55
- // @ts-ignore
56
- rootPopupState.close(event);
57
-
58
- if (onClick) {
59
- onClick(event);
39
+ function CascadingMenuItem({ onClick, ...props }) {
40
+ const { rootPopupState } = (0, react_1.useContext)(CascadingContext);
41
+ if (!rootPopupState) {
42
+ throw new Error('must be used inside a CascadingMenu');
60
43
  }
61
- }, [rootPopupState, onClick]);
62
- return /*#__PURE__*/_react.default.createElement(_core.MenuItem, (0, _extends2.default)({}, props, {
63
- onClick: handleClick
64
- }));
44
+ const handleClick = (0, react_1.useCallback)((event) => {
45
+ rootPopupState.close();
46
+ onClick === null || onClick === void 0 ? void 0 : onClick(event);
47
+ }, [rootPopupState, onClick]);
48
+ return react_1.default.createElement(material_1.MenuItem, { ...props, onClick: handleClick });
65
49
  }
66
-
67
- function CascadingSubmenu(_ref2) {
68
- var title = _ref2.title,
69
- inset = _ref2.inset,
70
- popupId = _ref2.popupId,
71
- props = (0, _objectWithoutProperties2.default)(_ref2, _excluded2);
72
-
73
- var _React$useContext = _react.default.useContext(CascadingContext),
74
- parentPopupState = _React$useContext.parentPopupState;
75
-
76
- var popupState = (0, _hooks.usePopupState)({
77
- popupId: popupId,
78
- variant: 'popover',
79
- parentPopupState: parentPopupState
80
- });
81
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_core.MenuItem, (0, _extends2.default)({}, (0, _hooks.bindHover)(popupState), (0, _hooks.bindFocus)(popupState)), /*#__PURE__*/_react.default.createElement(_core.ListItemText, {
82
- primary: title,
83
- inset: inset
84
- }), /*#__PURE__*/_react.default.createElement(_ChevronRight.default, null)), /*#__PURE__*/_react.default.createElement(CascadingSubmenuHover, (0, _extends2.default)({}, props, {
85
- anchorOrigin: {
86
- vertical: 'top',
87
- horizontal: 'right'
88
- },
89
- transformOrigin: {
90
- vertical: 'top',
91
- horizontal: 'left'
92
- },
93
- popupState: popupState
94
- })));
50
+ function CascadingSubmenu({ title, inset, popupId, ...props }) {
51
+ const { parentPopupState } = react_1.default.useContext(CascadingContext);
52
+ const popupState = (0, hooks_1.usePopupState)({
53
+ popupId,
54
+ variant: 'popover',
55
+ parentPopupState,
56
+ });
57
+ return (react_1.default.createElement(react_1.default.Fragment, null,
58
+ react_1.default.createElement(material_1.MenuItem, { ...(0, hooks_1.bindHover)(popupState), ...(0, hooks_1.bindFocus)(popupState) },
59
+ react_1.default.createElement(material_1.ListItemText, { primary: title, inset: inset }),
60
+ react_1.default.createElement(ChevronRight_1.default, null)),
61
+ react_1.default.createElement(CascadingSubmenuHover, { ...props, anchorOrigin: { vertical: 'top', horizontal: 'right' }, transformOrigin: { vertical: 'top', horizontal: 'left' }, popupState: popupState })));
95
62
  }
96
-
97
- function CascadingSubmenuHover(_ref3) {
98
- var popupState = _ref3.popupState,
99
- onMenuItemClick = _ref3.onMenuItemClick,
100
- menuItems = _ref3.menuItems,
101
- classes = _ref3.classes,
102
- props = (0, _objectWithoutProperties2.default)(_ref3, _excluded3);
103
-
104
- var _useContext2 = (0, _react.useContext)(CascadingContext),
105
- rootPopupState = _useContext2.rootPopupState;
106
-
107
- var context = (0, _react.useMemo)(function () {
108
- return {
109
- rootPopupState: rootPopupState || popupState,
110
- parentPopupState: popupState
111
- };
112
- }, [rootPopupState, popupState]);
113
- return /*#__PURE__*/_react.default.createElement(CascadingContext.Provider, {
114
- value: context
115
- }, /*#__PURE__*/_react.default.createElement(_HoverMenu.default, (0, _extends2.default)({}, props, (0, _hooks.bindMenu)(popupState))));
63
+ function CascadingSubmenuHover({ popupState, onMenuItemClick, menuItems, classes, ...props }) {
64
+ const { rootPopupState } = (0, react_1.useContext)(CascadingContext);
65
+ const context = (0, react_1.useMemo)(() => ({
66
+ rootPopupState: rootPopupState || popupState,
67
+ parentPopupState: popupState,
68
+ }), [rootPopupState, popupState]);
69
+ return (react_1.default.createElement(CascadingContext.Provider, { value: context },
70
+ react_1.default.createElement(HoverMenu_1.default, { ...props, ...(0, hooks_1.bindMenu)(popupState) })));
116
71
  }
117
-
118
- function CascadingMenu(_ref4) {
119
- var popupState = _ref4.popupState,
120
- onMenuItemClick = _ref4.onMenuItemClick,
121
- menuItems = _ref4.menuItems,
122
- props = (0, _objectWithoutProperties2.default)(_ref4, _excluded4);
123
-
124
- var _React$useContext2 = _react.default.useContext(CascadingContext),
125
- rootPopupState = _React$useContext2.rootPopupState;
126
-
127
- var context = _react.default.useMemo(function () {
128
- return {
129
- rootPopupState: rootPopupState || popupState,
130
- parentPopupState: popupState
131
- };
132
- }, [rootPopupState, popupState]);
133
-
134
- return /*#__PURE__*/_react.default.createElement(CascadingContext.Provider, {
135
- value: context
136
- }, /*#__PURE__*/_react.default.createElement(_core.Menu, (0, _extends2.default)({}, props, (0, _hooks.bindMenu)(popupState))));
72
+ function CascadingMenu({ popupState, onMenuItemClick, menuItems, ...props }) {
73
+ const { rootPopupState } = react_1.default.useContext(CascadingContext);
74
+ const context = react_1.default.useMemo(() => ({
75
+ rootPopupState: rootPopupState || popupState,
76
+ parentPopupState: popupState,
77
+ }), [rootPopupState, popupState]);
78
+ return (react_1.default.createElement(CascadingContext.Provider, { value: context },
79
+ react_1.default.createElement(material_1.Menu, { ...props, ...(0, hooks_1.bindMenu)(popupState) })));
137
80
  }
138
-
139
- function EndDecoration(_ref5) {
140
- var item = _ref5.item;
141
-
142
- if ('subMenu' in item) {
143
- return /*#__PURE__*/_react.default.createElement(_Menu.MenuItemEndDecoration, {
144
- type: "subMenu"
145
- });
146
- } else if (item.type === 'checkbox' || item.type === 'radio') {
147
- return /*#__PURE__*/_react.default.createElement(_Menu.MenuItemEndDecoration, {
148
- type: item.type,
149
- checked: item.checked,
150
- disabled: item.disabled
151
- });
152
- }
153
-
154
- return null;
81
+ function EndDecoration({ item }) {
82
+ if ('subMenu' in item) {
83
+ return react_1.default.createElement(Menu_1.MenuItemEndDecoration, { type: "subMenu" });
84
+ }
85
+ else if (item.type === 'checkbox' || item.type === 'radio') {
86
+ return (react_1.default.createElement(Menu_1.MenuItemEndDecoration, { type: item.type, checked: item.checked, disabled: item.disabled }));
87
+ }
88
+ return null;
155
89
  }
156
-
157
- function CascadingMenuList(_ref6) {
158
- var onMenuItemClick = _ref6.onMenuItemClick,
159
- menuItems = _ref6.menuItems,
160
- props = (0, _objectWithoutProperties2.default)(_ref6, _excluded5);
161
-
162
- function handleClick(callback) {
163
- return function (event) {
164
- onMenuItemClick(event, callback);
165
- };
166
- }
167
-
168
- var hasIcon = menuItems.some(function (menuItem) {
169
- return 'icon' in menuItem && menuItem.icon;
170
- });
171
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, menuItems.map(function (item, idx) {
172
- return 'subMenu' in item ? /*#__PURE__*/_react.default.createElement(CascadingSubmenu, {
173
- key: "subMenu-".concat(item.label, "-").concat(idx),
174
- popupId: "subMenu-".concat(item.label),
175
- title: item.label,
176
- inset: hasIcon,
177
- onMenuItemClick: onMenuItemClick,
178
- menuItems: item.subMenu
179
- }, /*#__PURE__*/_react.default.createElement(CascadingMenuList, (0, _extends2.default)({}, props, {
180
- onMenuItemClick: onMenuItemClick,
181
- menuItems: item.subMenu
182
- }))) : item.type === 'divider' ? /*#__PURE__*/_react.default.createElement(_core.Divider, {
183
- key: "divider-".concat(idx),
184
- component: "li"
185
- }) : item.type === 'subHeader' ? /*#__PURE__*/_react.default.createElement(_core.ListSubheader, {
186
- key: "subHeader-".concat(item.label, "-").concat(idx)
187
- }, item.label) : /*#__PURE__*/_react.default.createElement(CascadingMenuItem, {
188
- key: "".concat(item.label, "-").concat(idx),
189
- onClick: 'onClick' in item ? handleClick(item.onClick) : undefined,
190
- disabled: Boolean(item.disabled)
191
- }, item.icon ? /*#__PURE__*/_react.default.createElement(_core.ListItemIcon, null, /*#__PURE__*/_react.default.createElement(item.icon, null)) : null, ' ', /*#__PURE__*/_react.default.createElement(_core.ListItemText, {
192
- primary: item.label,
193
- secondary: item.subLabel,
194
- inset: hasIcon && !item.icon
195
- }), /*#__PURE__*/_react.default.createElement("div", {
196
- style: {
197
- flexGrow: 1,
198
- minWidth: 10
199
- }
200
- }), /*#__PURE__*/_react.default.createElement(EndDecoration, {
201
- item: item
202
- }));
203
- }));
90
+ function CascadingMenuList({ onMenuItemClick, menuItems, ...props }) {
91
+ function handleClick(callback) {
92
+ return (event) => {
93
+ onMenuItemClick(event, callback);
94
+ };
95
+ }
96
+ const hasIcon = menuItems.some(menuItem => 'icon' in menuItem && menuItem.icon);
97
+ return (react_1.default.createElement(react_1.default.Fragment, null, menuItems.map((item, idx) => {
98
+ return 'subMenu' in item ? (react_1.default.createElement(CascadingSubmenu, { key: `subMenu-${item.label}-${idx}`, popupId: `subMenu-${item.label}`, title: item.label, inset: hasIcon, onMenuItemClick: onMenuItemClick, menuItems: item.subMenu },
99
+ react_1.default.createElement(CascadingMenuList, { ...props, onMenuItemClick: onMenuItemClick, menuItems: item.subMenu }))) : item.type === 'divider' ? (react_1.default.createElement(material_1.Divider, { key: `divider-${idx}`, component: "li" })) : item.type === 'subHeader' ? (react_1.default.createElement(material_1.ListSubheader, { key: `subHeader-${item.label}-${idx}` }, item.label)) : (react_1.default.createElement(CascadingMenuItem, { key: `${item.label}-${idx}`, onClick: 'onClick' in item ? handleClick(item.onClick) : undefined, disabled: Boolean(item.disabled) },
100
+ item.icon ? (react_1.default.createElement(material_1.ListItemIcon, null,
101
+ react_1.default.createElement(item.icon, null))) : null,
102
+ ' ',
103
+ react_1.default.createElement(material_1.ListItemText, { primary: item.label, secondary: item.subLabel, inset: hasIcon && !item.icon }),
104
+ react_1.default.createElement("div", { style: { flexGrow: 1, minWidth: 10 } }),
105
+ react_1.default.createElement(EndDecoration, { item: item })));
106
+ })));
204
107
  }
205
-
206
108
  function CascadingMenuChildren(props) {
207
- return /*#__PURE__*/_react.default.createElement(CascadingMenu, props, /*#__PURE__*/_react.default.createElement(CascadingMenuList, props));
109
+ return (react_1.default.createElement(CascadingMenu, { ...props },
110
+ react_1.default.createElement(CascadingMenuList, { ...props })));
208
111
  }
209
-
210
- var _default = CascadingMenuChildren;
211
- exports.default = _default;
112
+ exports.default = CascadingMenuChildren;
@@ -0,0 +1,16 @@
1
+ /// <reference types="react" />
2
+ export declare const PopoverPicker: ({ color, onChange, }: {
3
+ color: string;
4
+ onChange: (color: string) => void;
5
+ }) => JSX.Element;
6
+ export declare function ColorPopover({ anchorEl, onChange, onClose, color, }: {
7
+ color: string;
8
+ anchorEl: HTMLElement | null;
9
+ onChange: (val: string) => void;
10
+ onClose: () => void;
11
+ }): JSX.Element;
12
+ export declare function ColorPicker({ onChange, color, }: {
13
+ color: string;
14
+ onChange: (val: string) => void;
15
+ }): JSX.Element;
16
+ export default PopoverPicker;
@@ -0,0 +1,97 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.ColorPicker = exports.ColorPopover = exports.PopoverPicker = void 0;
30
+ const react_1 = __importStar(require("react"));
31
+ const color_1 = __importDefault(require("color"));
32
+ const material_1 = require("@mui/material");
33
+ const mui_1 = require("tss-react/mui");
34
+ // locals
35
+ const paletteColors = __importStar(require("./colors"));
36
+ const util_1 = require("../util");
37
+ // we are using a vendored copy of react-colorful because the default uses
38
+ // pure-ESM which is difficult to make pass with jest e.g.
39
+ // https://stackoverflow.com/questions/58613492/how-to-resolve-cannot-use-import-statement-outside-a-module-in-jest
40
+ const react_colorful_1 = require("./react-colorful");
41
+ const useStyles = (0, mui_1.makeStyles)()({
42
+ picker: { position: 'relative' },
43
+ swatches: {
44
+ display: 'flex',
45
+ padding: 12,
46
+ flexWrap: 'wrap',
47
+ },
48
+ swatch: {
49
+ width: 24,
50
+ height: 24,
51
+ margin: 4,
52
+ border: 'none',
53
+ padding: 0,
54
+ cursor: 'pointer',
55
+ outline: 'none',
56
+ },
57
+ });
58
+ const PopoverPicker = ({ color, onChange, }) => {
59
+ const [anchorEl, setAnchorEl] = (0, react_1.useState)(null);
60
+ const { classes } = useStyles();
61
+ return (react_1.default.createElement("div", { className: classes.picker },
62
+ react_1.default.createElement("div", { className: classes.swatch, style: { backgroundColor: color }, onClick: event => setAnchorEl(event.currentTarget) }),
63
+ react_1.default.createElement(ColorPopover, { anchorEl: anchorEl, onClose: () => setAnchorEl(null), color: color, onChange: onChange })));
64
+ };
65
+ exports.PopoverPicker = PopoverPicker;
66
+ function ColorPopover({ anchorEl, onChange, onClose, color, }) {
67
+ return (react_1.default.createElement(material_1.Popover, { open: !!anchorEl, anchorEl: anchorEl, onClose: onClose },
68
+ react_1.default.createElement(ColorPicker, { color: color, onChange: onChange })));
69
+ }
70
+ exports.ColorPopover = ColorPopover;
71
+ function ColorPicker({ onChange, color, }) {
72
+ const { classes } = useStyles();
73
+ const [val, setVal] = (0, util_1.useLocalStorage)('colorPickerPalette', 'set1');
74
+ const presetColors = paletteColors[val];
75
+ const palettes = Object.keys(paletteColors);
76
+ const [text, setText] = (0, react_1.useState)(color);
77
+ const rgb = (0, color_1.default)(color).rgb().toString();
78
+ const handleChange = (val) => {
79
+ setText(val);
80
+ try {
81
+ onChange((0, color_1.default)(val).rgb().toString());
82
+ }
83
+ catch (e) { }
84
+ };
85
+ return (react_1.default.createElement("div", { style: { display: 'flex', padding: 10 } },
86
+ react_1.default.createElement("div", { style: { width: 200, margin: 5 } },
87
+ react_1.default.createElement(react_colorful_1.RgbaStringColorPicker, { color: rgb, onChange: handleChange })),
88
+ react_1.default.createElement("div", { style: { width: 200, margin: 5 } },
89
+ react_1.default.createElement(material_1.Select, { value: val, onChange: event => {
90
+ const pal = event.target.value;
91
+ setVal(pal);
92
+ } }, palettes.map(p => (react_1.default.createElement(material_1.MenuItem, { value: p, key: p }, p)))),
93
+ react_1.default.createElement("div", { className: classes.swatches }, presetColors.map((presetColor, idx) => (react_1.default.createElement("button", { key: presetColor + '-' + idx, className: classes.swatch, style: { background: presetColor }, onClick: () => handleChange(presetColor) })))),
94
+ react_1.default.createElement(material_1.TextField, { helperText: 'Manually set color (hex, rgb, or css color name)', value: text, onChange: event => handleChange(event.target.value) }))));
95
+ }
96
+ exports.ColorPicker = ColorPicker;
97
+ exports.default = exports.PopoverPicker;
package/ui/Drawer.js CHANGED
@@ -1,64 +1,34 @@
1
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 _react = _interopRequireDefault(require("react"));
11
-
12
- var _Paper = _interopRequireDefault(require("@material-ui/core/Paper"));
13
-
14
- var _styles = require("@material-ui/core/styles");
15
-
16
- var _mobxReact = require("mobx-react");
17
-
18
- var _ResizeHandle = _interopRequireDefault(require("./ResizeHandle"));
19
-
20
- var useStyles = (0, _styles.makeStyles)(function (theme) {
21
- return {
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ const material_1 = require("@mui/material");
8
+ const mui_1 = require("tss-react/mui");
9
+ const mobx_react_1 = require("mobx-react");
10
+ const ResizeHandle_1 = __importDefault(require("./ResizeHandle"));
11
+ const useStyles = (0, mui_1.makeStyles)()(theme => ({
22
12
  paper: {
23
- overflowY: 'auto',
24
- height: '100%',
25
- zIndex: theme.zIndex.drawer,
26
- outline: 'none',
27
- background: theme.palette.background.default
13
+ overflowY: 'auto',
14
+ height: '100%',
15
+ zIndex: theme.zIndex.drawer,
16
+ outline: 'none',
17
+ background: theme.palette.background.default,
28
18
  },
29
19
  resizeHandle: {
30
- width: 4,
31
- position: 'fixed',
32
- top: 0,
33
- zIndex: theme.zIndex.drawer + 1
34
- }
35
- };
36
- });
37
-
38
- function Drawer(_ref) {
39
- var children = _ref.children,
40
- session = _ref.session;
41
- var drawerPosition = session.drawerPosition,
42
- drawerWidth = session.drawerWidth;
43
- var classes = useStyles();
44
- return /*#__PURE__*/_react.default.createElement(_Paper.default, {
45
- className: classes.paper,
46
- elevation: 16,
47
- square: true
48
- }, drawerPosition === 'right' ? /*#__PURE__*/_react.default.createElement(_ResizeHandle.default, {
49
- onDrag: session.resizeDrawer,
50
- className: classes.resizeHandle,
51
- vertical: true
52
- }) : null, children, drawerPosition === 'left' ? /*#__PURE__*/_react.default.createElement(_ResizeHandle.default, {
53
- onDrag: session.resizeDrawer,
54
- className: classes.resizeHandle,
55
- style: {
56
- left: drawerWidth
20
+ width: 4,
21
+ position: 'fixed',
22
+ top: 0,
23
+ zIndex: theme.zIndex.drawer + 1,
57
24
  },
58
- vertical: true
59
- }) : null);
25
+ }));
26
+ function Drawer({ children, session, }) {
27
+ const { drawerPosition, drawerWidth } = session;
28
+ const { classes } = useStyles();
29
+ return (react_1.default.createElement(material_1.Paper, { className: classes.paper, elevation: 16, square: true },
30
+ drawerPosition === 'right' ? (react_1.default.createElement(ResizeHandle_1.default, { onDrag: session.resizeDrawer, className: classes.resizeHandle, vertical: true })) : null,
31
+ children,
32
+ drawerPosition === 'left' ? (react_1.default.createElement(ResizeHandle_1.default, { onDrag: session.resizeDrawer, className: classes.resizeHandle, style: { left: drawerWidth }, vertical: true })) : null));
60
33
  }
61
-
62
- var _default = (0, _mobxReact.observer)(Drawer);
63
-
64
- exports.default = _default;
34
+ exports.default = (0, mobx_react_1.observer)(Drawer);