@jbrowse/core 2.0.0 → 2.1.2

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 (184) hide show
  1. package/BaseFeatureWidget/BaseFeatureDetail.d.ts +9 -3
  2. package/BaseFeatureWidget/BaseFeatureDetail.js +313 -581
  3. package/BaseFeatureWidget/SequenceFeatureDetails.js +213 -478
  4. package/BaseFeatureWidget/index.js +88 -126
  5. package/BaseFeatureWidget/types.d.ts +1 -0
  6. package/BaseFeatureWidget/types.js +1 -4
  7. package/BaseFeatureWidget/util.js +40 -75
  8. package/CorePlugin.js +55 -94
  9. package/Plugin.js +9 -34
  10. package/PluginLoader.js +153 -422
  11. package/PluginManager.d.ts +28 -33
  12. package/PluginManager.js +377 -666
  13. package/ReExports/Attributes.js +3 -10
  14. package/ReExports/BaseCard.js +3 -10
  15. package/ReExports/DataGrid.js +5 -12
  16. package/ReExports/FeatureDetails.js +3 -10
  17. package/ReExports/index.js +6 -12
  18. package/ReExports/list.d.ts +5 -0
  19. package/ReExports/list.js +271 -7
  20. package/ReExports/material-ui-colors.js +15 -16
  21. package/ReExports/modules.d.ts +11 -20
  22. package/ReExports/modules.js +453 -798
  23. package/TextSearch/BaseResults.js +51 -123
  24. package/TextSearch/TextSearchManager.js +66 -144
  25. package/assemblyManager/assembly.js +280 -555
  26. package/assemblyManager/assemblyConfigSchema.js +47 -64
  27. package/assemblyManager/assemblyManager.js +126 -272
  28. package/assemblyManager/index.js +9 -22
  29. package/configuration/configurationSchema.js +167 -203
  30. package/configuration/configurationSlot.js +248 -326
  31. package/configuration/index.js +19 -35
  32. package/configuration/util.js +131 -173
  33. package/data_adapters/BaseAdapter.d.ts +2 -2
  34. package/data_adapters/BaseAdapter.js +132 -521
  35. package/data_adapters/CytobandAdapter.js +40 -126
  36. package/data_adapters/dataAdapterCache.js +77 -158
  37. package/package.json +4 -5
  38. package/pluggableElementTypes/AdapterType.js +24 -79
  39. package/pluggableElementTypes/AddTrackWorkflowType.d.ts +17 -0
  40. package/pluggableElementTypes/AddTrackWorkflowType.js +20 -0
  41. package/pluggableElementTypes/ConnectionType.js +22 -65
  42. package/pluggableElementTypes/DisplayType.js +35 -82
  43. package/pluggableElementTypes/InternetAccountType.js +23 -64
  44. package/pluggableElementTypes/PluggableElementBase.js +8 -20
  45. package/pluggableElementTypes/RpcMethodType.js +85 -427
  46. package/pluggableElementTypes/TextSearchAdapterType.js +16 -55
  47. package/pluggableElementTypes/TrackType.js +26 -70
  48. package/pluggableElementTypes/ViewType.js +21 -63
  49. package/pluggableElementTypes/WidgetType.js +21 -64
  50. package/pluggableElementTypes/index.d.ts +4 -3
  51. package/pluggableElementTypes/index.js +42 -125
  52. package/pluggableElementTypes/models/BaseConnectionModelFactory.js +28 -43
  53. package/pluggableElementTypes/models/BaseDisplayModel.js +58 -95
  54. package/pluggableElementTypes/models/BaseTrackModel.js +139 -199
  55. package/pluggableElementTypes/models/BaseViewModel.js +24 -40
  56. package/pluggableElementTypes/models/InternetAccountModel.js +116 -263
  57. package/pluggableElementTypes/models/baseConnectionConfig.js +14 -25
  58. package/pluggableElementTypes/models/baseInternetAccountConfig.js +29 -38
  59. package/pluggableElementTypes/models/baseTrackConfig.js +106 -133
  60. package/pluggableElementTypes/models/index.js +21 -70
  61. package/pluggableElementTypes/renderers/BoxRendererType.js +132 -291
  62. package/pluggableElementTypes/renderers/CircularChordRendererType.js +8 -38
  63. package/pluggableElementTypes/renderers/ComparativeServerSideRendererType.js +60 -192
  64. package/pluggableElementTypes/renderers/FeatureRendererType.d.ts +0 -2
  65. package/pluggableElementTypes/renderers/FeatureRendererType.js +89 -255
  66. package/pluggableElementTypes/renderers/RendererType.js +31 -105
  67. package/pluggableElementTypes/renderers/ServerSideRenderedContent.js +61 -72
  68. package/pluggableElementTypes/renderers/ServerSideRendererType.js +112 -265
  69. package/pluggableElementTypes/renderers/index.js +19 -62
  70. package/pluggableElementTypes/renderers/util/serializableFilterChain.js +27 -65
  71. package/rpc/BaseRpcDriver.js +169 -405
  72. package/rpc/MainThreadRpcDriver.js +27 -150
  73. package/rpc/RpcManager.js +58 -159
  74. package/rpc/WebWorkerRpcDriver.js +54 -171
  75. package/rpc/configSchema.js +25 -49
  76. package/rpc/coreRpcMethods.d.ts +1 -3
  77. package/rpc/coreRpcMethods.js +221 -959
  78. package/rpc/remoteAbortSignals.js +46 -70
  79. package/tsconfig.build.tsbuildinfo +1 -1
  80. package/ui/AboutDialog.js +106 -162
  81. package/ui/App.js +157 -242
  82. package/ui/AssemblySelector.js +59 -120
  83. package/ui/CascadingMenu.js +101 -196
  84. package/ui/ColorPicker.d.ts +16 -0
  85. package/ui/ColorPicker.js +97 -0
  86. package/ui/Drawer.js +28 -61
  87. package/ui/DrawerWidget.js +108 -202
  88. package/ui/DropDownMenu.js +60 -91
  89. package/ui/EditableTypography.js +87 -149
  90. package/ui/ErrorMessage.js +41 -56
  91. package/ui/FactoryResetDialog.js +24 -57
  92. package/ui/FatalErrorDialog.js +59 -91
  93. package/ui/FileSelector/FileSelector.js +123 -189
  94. package/ui/FileSelector/LocalFileChooser.js +44 -75
  95. package/ui/FileSelector/UrlChooser.js +17 -38
  96. package/ui/FileSelector/index.js +6 -12
  97. package/ui/Icons.js +45 -69
  98. package/ui/Logo.js +57 -110
  99. package/ui/Menu.js +232 -354
  100. package/ui/PrerenderedCanvas.js +63 -87
  101. package/ui/ResizeHandle.js +87 -116
  102. package/ui/ReturnToImportFormDialog.js +32 -63
  103. package/ui/SanitizedHTML.js +64 -47
  104. package/ui/Snackbar.js +74 -101
  105. package/ui/SnackbarModel.js +37 -51
  106. package/ui/Tooltip.js +49 -76
  107. package/ui/ViewContainer.js +113 -196
  108. package/ui/colors.d.ts +10 -0
  109. package/ui/colors.js +78 -0
  110. package/ui/index.js +51 -181
  111. package/ui/react-colorful.d.ts +17 -0
  112. package/ui/react-colorful.js +455 -0
  113. package/ui/theme.d.ts +23 -1
  114. package/ui/theme.js +199 -247
  115. package/util/Base1DUtils.d.ts +32 -0
  116. package/util/Base1DUtils.js +174 -0
  117. package/util/Base1DViewModel.d.ts +16 -30
  118. package/util/Base1DViewModel.js +116 -293
  119. package/util/QuickLRU.js +84 -332
  120. package/util/TimeTraveller.d.ts +19 -0
  121. package/util/TimeTraveller.js +86 -0
  122. package/util/aborting.js +49 -127
  123. package/util/analytics.js +91 -154
  124. package/util/blockTypes.js +106 -240
  125. package/util/calculateDynamicBlocks.js +98 -128
  126. package/util/calculateStaticBlocks.js +105 -125
  127. package/util/color/cssColorsLevel4.js +156 -160
  128. package/util/color/index.js +33 -55
  129. package/util/compositeMap.js +49 -333
  130. package/util/formatFastaStrings.js +9 -14
  131. package/util/idMaker.js +18 -31
  132. package/util/index.d.ts +18 -32
  133. package/util/index.js +747 -1226
  134. package/util/io/RemoteFileWithRangeCache.js +88 -257
  135. package/util/io/index.js +95 -169
  136. package/util/jexl.js +60 -115
  137. package/util/jexlStrings.js +24 -29
  138. package/util/layouts/BaseLayout.js +1 -4
  139. package/util/layouts/GranularRectLayout.js +388 -555
  140. package/util/layouts/MultiLayout.js +41 -109
  141. package/util/layouts/PrecomputedLayout.js +56 -112
  142. package/util/layouts/PrecomputedMultiLayout.js +22 -59
  143. package/util/layouts/SceneGraph.js +127 -197
  144. package/util/layouts/index.js +29 -66
  145. package/util/mst-reflection.js +55 -71
  146. package/util/offscreenCanvasPonyfill.js +66 -134
  147. package/util/offscreenCanvasUtils.d.ts +2 -7
  148. package/util/offscreenCanvasUtils.js +49 -146
  149. package/util/range.js +29 -40
  150. package/util/rxjs.js +20 -27
  151. package/util/simpleFeature.js +88 -152
  152. package/util/stats.js +91 -151
  153. package/util/tracks.js +130 -173
  154. package/util/types/index.js +110 -179
  155. package/util/types/mst.js +91 -146
  156. package/util/types/util.js +1 -4
  157. package/util/when.js +54 -101
  158. package/BaseFeatureWidget/SequenceFeatureDetails.test.js +0 -122
  159. package/BaseFeatureWidget/index.test.js +0 -69
  160. package/TextSearch/BaseResults.test.js +0 -42
  161. package/configuration/configurationSchema.test.js +0 -266
  162. package/configuration/configurationSlot.test.js +0 -69
  163. package/configuration/util.test.js +0 -39
  164. package/data_adapters/BaseAdapter.test.js +0 -200
  165. package/declare.d.js +0 -1
  166. package/pluggableElementTypes/RpcMethodType.test.js +0 -118
  167. package/pluggableElementTypes/renderers/declare.d.js +0 -1
  168. package/pluggableElementTypes/renderers/util/serializableFilterChain.test.js +0 -20
  169. package/rpc/BaseRpcDriver.test.js +0 -540
  170. package/rpc/declaration.d.js +0 -1
  171. package/ui/FatalErrorDialog.test.js +0 -82
  172. package/ui/SanitizedHTML.test.js +0 -36
  173. package/ui/theme.test.js +0 -92
  174. package/util/Base1DViewModel.test.js +0 -130
  175. package/util/calculateDynamicBlocks.test.js +0 -74
  176. package/util/calculateStaticBlocks.test.js +0 -297
  177. package/util/declare.d.js +0 -1
  178. package/util/formatFastaStrings.test.js +0 -40
  179. package/util/index.test.js +0 -213
  180. package/util/jexlStrings.test.js +0 -48
  181. package/util/layouts/GranularRectLayout.test.js +0 -99
  182. package/util/range.test.js +0 -64
  183. package/util/simpleFeature.test.js +0 -34
  184. package/util/stats.test.js +0 -172
@@ -1,207 +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 _material = require("@mui/material");
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("@mui/icons-material/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
- rootPopupState.close();
56
- onClick === null || onClick === void 0 ? void 0 : onClick(event);
57
- }, [rootPopupState, onClick]);
58
- return /*#__PURE__*/_react.default.createElement(_material.MenuItem, (0, _extends2.default)({}, props, {
59
- onClick: handleClick
60
- }));
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');
43
+ }
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 });
61
49
  }
62
-
63
- function CascadingSubmenu(_ref2) {
64
- var title = _ref2.title,
65
- inset = _ref2.inset,
66
- popupId = _ref2.popupId,
67
- props = (0, _objectWithoutProperties2.default)(_ref2, _excluded2);
68
-
69
- var _React$useContext = _react.default.useContext(CascadingContext),
70
- parentPopupState = _React$useContext.parentPopupState;
71
-
72
- var popupState = (0, _hooks.usePopupState)({
73
- popupId: popupId,
74
- variant: 'popover',
75
- parentPopupState: parentPopupState
76
- });
77
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_material.MenuItem, (0, _extends2.default)({}, (0, _hooks.bindHover)(popupState), (0, _hooks.bindFocus)(popupState)), /*#__PURE__*/_react.default.createElement(_material.ListItemText, {
78
- primary: title,
79
- inset: inset
80
- }), /*#__PURE__*/_react.default.createElement(_ChevronRight.default, null)), /*#__PURE__*/_react.default.createElement(CascadingSubmenuHover, (0, _extends2.default)({}, props, {
81
- anchorOrigin: {
82
- vertical: 'top',
83
- horizontal: 'right'
84
- },
85
- transformOrigin: {
86
- vertical: 'top',
87
- horizontal: 'left'
88
- },
89
- popupState: popupState
90
- })));
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 })));
91
62
  }
92
-
93
- function CascadingSubmenuHover(_ref3) {
94
- var popupState = _ref3.popupState,
95
- onMenuItemClick = _ref3.onMenuItemClick,
96
- menuItems = _ref3.menuItems,
97
- classes = _ref3.classes,
98
- props = (0, _objectWithoutProperties2.default)(_ref3, _excluded3);
99
-
100
- var _useContext2 = (0, _react.useContext)(CascadingContext),
101
- rootPopupState = _useContext2.rootPopupState;
102
-
103
- var context = (0, _react.useMemo)(function () {
104
- return {
105
- rootPopupState: rootPopupState || popupState,
106
- parentPopupState: popupState
107
- };
108
- }, [rootPopupState, popupState]);
109
- return /*#__PURE__*/_react.default.createElement(CascadingContext.Provider, {
110
- value: context
111
- }, /*#__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) })));
112
71
  }
113
-
114
- function CascadingMenu(_ref4) {
115
- var popupState = _ref4.popupState,
116
- onMenuItemClick = _ref4.onMenuItemClick,
117
- menuItems = _ref4.menuItems,
118
- props = (0, _objectWithoutProperties2.default)(_ref4, _excluded4);
119
-
120
- var _React$useContext2 = _react.default.useContext(CascadingContext),
121
- rootPopupState = _React$useContext2.rootPopupState;
122
-
123
- var context = _react.default.useMemo(function () {
124
- return {
125
- rootPopupState: rootPopupState || popupState,
126
- parentPopupState: popupState
127
- };
128
- }, [rootPopupState, popupState]);
129
-
130
- return /*#__PURE__*/_react.default.createElement(CascadingContext.Provider, {
131
- value: context
132
- }, /*#__PURE__*/_react.default.createElement(_material.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) })));
133
80
  }
134
-
135
- function EndDecoration(_ref5) {
136
- var item = _ref5.item;
137
-
138
- if ('subMenu' in item) {
139
- return /*#__PURE__*/_react.default.createElement(_Menu.MenuItemEndDecoration, {
140
- type: "subMenu"
141
- });
142
- } else if (item.type === 'checkbox' || item.type === 'radio') {
143
- return /*#__PURE__*/_react.default.createElement(_Menu.MenuItemEndDecoration, {
144
- type: item.type,
145
- checked: item.checked,
146
- disabled: item.disabled
147
- });
148
- }
149
-
150
- 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;
151
89
  }
152
-
153
- function CascadingMenuList(_ref6) {
154
- var onMenuItemClick = _ref6.onMenuItemClick,
155
- menuItems = _ref6.menuItems,
156
- props = (0, _objectWithoutProperties2.default)(_ref6, _excluded5);
157
-
158
- function handleClick(callback) {
159
- return function (event) {
160
- onMenuItemClick(event, callback);
161
- };
162
- }
163
-
164
- var hasIcon = menuItems.some(function (menuItem) {
165
- return 'icon' in menuItem && menuItem.icon;
166
- });
167
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, menuItems.map(function (item, idx) {
168
- return 'subMenu' in item ? /*#__PURE__*/_react.default.createElement(CascadingSubmenu, {
169
- key: "subMenu-".concat(item.label, "-").concat(idx),
170
- popupId: "subMenu-".concat(item.label),
171
- title: item.label,
172
- inset: hasIcon,
173
- onMenuItemClick: onMenuItemClick,
174
- menuItems: item.subMenu
175
- }, /*#__PURE__*/_react.default.createElement(CascadingMenuList, (0, _extends2.default)({}, props, {
176
- onMenuItemClick: onMenuItemClick,
177
- menuItems: item.subMenu
178
- }))) : item.type === 'divider' ? /*#__PURE__*/_react.default.createElement(_material.Divider, {
179
- key: "divider-".concat(idx),
180
- component: "li"
181
- }) : item.type === 'subHeader' ? /*#__PURE__*/_react.default.createElement(_material.ListSubheader, {
182
- key: "subHeader-".concat(item.label, "-").concat(idx)
183
- }, item.label) : /*#__PURE__*/_react.default.createElement(CascadingMenuItem, {
184
- key: "".concat(item.label, "-").concat(idx),
185
- onClick: 'onClick' in item ? handleClick(item.onClick) : undefined,
186
- disabled: Boolean(item.disabled)
187
- }, item.icon ? /*#__PURE__*/_react.default.createElement(_material.ListItemIcon, null, /*#__PURE__*/_react.default.createElement(item.icon, null)) : null, ' ', /*#__PURE__*/_react.default.createElement(_material.ListItemText, {
188
- primary: item.label,
189
- secondary: item.subLabel,
190
- inset: hasIcon && !item.icon
191
- }), /*#__PURE__*/_react.default.createElement("div", {
192
- style: {
193
- flexGrow: 1,
194
- minWidth: 10
195
- }
196
- }), /*#__PURE__*/_react.default.createElement(EndDecoration, {
197
- item: item
198
- }));
199
- }));
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
+ })));
200
107
  }
201
-
202
108
  function CascadingMenuChildren(props) {
203
- 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 })));
204
111
  }
205
-
206
- var _default = CascadingMenuChildren;
207
- 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,67 +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 _material = require("@mui/material");
13
-
14
- var _mui = require("tss-react/mui");
15
-
16
- var _mobxReact = require("mobx-react");
17
-
18
- var _ResizeHandle = _interopRequireDefault(require("./ResizeHandle"));
19
-
20
- var useStyles = (0, _mui.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
-
44
- var _useStyles = useStyles(),
45
- classes = _useStyles.classes;
46
-
47
- return /*#__PURE__*/_react.default.createElement(_material.Paper, {
48
- className: classes.paper,
49
- elevation: 16,
50
- square: true
51
- }, drawerPosition === 'right' ? /*#__PURE__*/_react.default.createElement(_ResizeHandle.default, {
52
- onDrag: session.resizeDrawer,
53
- className: classes.resizeHandle,
54
- vertical: true
55
- }) : null, children, drawerPosition === 'left' ? /*#__PURE__*/_react.default.createElement(_ResizeHandle.default, {
56
- onDrag: session.resizeDrawer,
57
- className: classes.resizeHandle,
58
- style: {
59
- left: drawerWidth
20
+ width: 4,
21
+ position: 'fixed',
22
+ top: 0,
23
+ zIndex: theme.zIndex.drawer + 1,
60
24
  },
61
- vertical: true
62
- }) : 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));
63
33
  }
64
-
65
- var _default = (0, _mobxReact.observer)(Drawer);
66
-
67
- exports.default = _default;
34
+ exports.default = (0, mobx_react_1.observer)(Drawer);