@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
package/ui/theme.js CHANGED
@@ -1,253 +1,205 @@
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.createJBrowseDefaultOverrides = createJBrowseDefaultOverrides;
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
+ exports.createJBrowseTheme = exports.jbrowseBaseTheme = exports.createJBrowseDefaultOverrides = exports.createJBrowseDefaultProps = exports.jbrowseDefaultPalette = void 0;
7
+ const colors_1 = require("@mui/material/colors");
8
+ const styles_1 = require("@mui/material/styles");
9
+ const deepmerge_1 = __importDefault(require("deepmerge"));
10
+ const midnight = '#0D233F';
11
+ const grape = '#721E63';
12
+ const forest = '#135560';
13
+ const mandarin = '#FFB11D';
14
+ const refTheme = (0, styles_1.createTheme)();
15
+ exports.jbrowseDefaultPalette = {
16
+ // type: 'dark',
17
+ primary: { main: midnight },
18
+ secondary: { main: grape },
19
+ tertiary: refTheme.palette.augmentColor({ color: { main: forest } }),
20
+ quaternary: refTheme.palette.augmentColor({ color: { main: mandarin } }),
21
+ stopCodon: '#e22',
22
+ startCodon: '#3e3',
23
+ bases: {
24
+ A: refTheme.palette.augmentColor({ color: colors_1.green }),
25
+ C: refTheme.palette.augmentColor({ color: colors_1.blue }),
26
+ G: refTheme.palette.augmentColor({ color: colors_1.amber }),
27
+ T: refTheme.palette.augmentColor({ color: colors_1.red }),
28
+ },
29
+ };
30
+ function createJBrowseDefaultProps( /* palette: PaletteOptions = {} */) {
31
+ return {
32
+ components: {
33
+ MuiButton: {
34
+ defaultProps: {
35
+ size: 'small',
36
+ },
37
+ },
38
+ MuiAccordion: {
39
+ defaultProps: {
40
+ disableGutters: true,
41
+ TransitionProps: { timeout: 150 },
42
+ },
43
+ },
44
+ MuiFilledInput: {
45
+ defaultProps: {
46
+ margin: 'dense',
47
+ },
48
+ },
49
+ MuiFormControl: {
50
+ defaultProps: {
51
+ margin: 'dense',
52
+ size: 'small',
53
+ },
54
+ },
55
+ MuiFormHelperText: {
56
+ defaultProps: {
57
+ margin: 'dense',
58
+ },
59
+ },
60
+ MuiIconButton: {
61
+ defaultProps: {
62
+ size: 'small',
63
+ },
64
+ },
65
+ MuiInputBase: {
66
+ defaultProps: {
67
+ margin: 'dense',
68
+ },
69
+ },
70
+ MuiAutocomplete: {
71
+ defaultProps: {
72
+ size: 'small',
73
+ },
74
+ },
75
+ MuiInputLabel: {
76
+ defaultProps: {
77
+ margin: 'dense',
78
+ },
79
+ },
80
+ MuiToolbar: {
81
+ defaultProps: {
82
+ variant: 'dense',
83
+ },
84
+ },
85
+ MuiListItem: {
86
+ defaultProps: {
87
+ dense: true,
88
+ },
89
+ },
90
+ MuiOutlinedInput: {
91
+ defaultProps: {
92
+ margin: 'dense',
93
+ },
94
+ },
95
+ MuiFab: {
96
+ defaultProps: {
97
+ size: 'small',
98
+ },
99
+ },
100
+ MuiTable: {
101
+ defaultProps: {
102
+ size: 'small',
103
+ },
104
+ },
105
+ MuiMenuList: {
106
+ defaultProps: {
107
+ dense: true,
108
+ },
109
+ },
110
+ MuiMenuItem: {
111
+ defaultProps: {
112
+ dense: true,
113
+ },
114
+ },
115
+ MuiTextField: {
116
+ defaultProps: {
117
+ margin: 'dense',
118
+ variant: 'standard',
119
+ },
120
+ },
121
+ },
122
+ };
123
+ }
9
124
  exports.createJBrowseDefaultProps = createJBrowseDefaultProps;
10
- exports.createJBrowseTheme = createJBrowseTheme;
11
- exports.jbrowseDefaultPalette = exports.jbrowseBaseTheme = void 0;
12
-
13
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
14
-
15
- var _colors = require("@mui/material/colors");
16
-
17
- var _styles = require("@mui/material/styles");
18
-
19
- var _deepmerge = _interopRequireDefault(require("deepmerge"));
20
-
21
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
22
-
23
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
24
-
25
- var midnight = '#0D233F';
26
- var grape = '#721E63';
27
- var forest = '#135560';
28
- var mandarin = '#FFB11D';
29
- var refTheme = (0, _styles.createTheme)();
30
- var jbrowseDefaultPalette = {
31
- // type: 'dark',
32
- primary: {
33
- main: midnight
34
- },
35
- secondary: {
36
- main: grape
37
- },
38
- tertiary: refTheme.palette.augmentColor({
39
- color: {
40
- main: forest
41
- }
42
- }),
43
- quaternary: refTheme.palette.augmentColor({
44
- color: {
45
- main: mandarin
46
- }
47
- }),
48
- stopCodon: '#e22',
49
- startCodon: '#3e3',
50
- bases: {
51
- A: refTheme.palette.augmentColor({
52
- color: _colors.green
53
- }),
54
- C: refTheme.palette.augmentColor({
55
- color: _colors.blue
56
- }),
57
- G: refTheme.palette.augmentColor({
58
- color: _colors.amber
59
- }),
60
- T: refTheme.palette.augmentColor({
61
- color: _colors.red
62
- })
63
- }
125
+ function createJBrowseDefaultOverrides(palette = {}) {
126
+ const generatedPalette = (0, deepmerge_1.default)(exports.jbrowseDefaultPalette, palette);
127
+ return {
128
+ components: {
129
+ MuiIconButton: {
130
+ styleOverrides: {
131
+ colorSecondary: {
132
+ color: generatedPalette.tertiary.main,
133
+ },
134
+ },
135
+ },
136
+ MuiButton: {
137
+ styleOverrides: {
138
+ textSecondary: {
139
+ color: generatedPalette.tertiary.main,
140
+ },
141
+ },
142
+ },
143
+ MuiFab: {
144
+ styleOverrides: {
145
+ secondary: {
146
+ backgroundColor: generatedPalette.quaternary.main,
147
+ },
148
+ },
149
+ },
150
+ MuiLink: {
151
+ styleOverrides: {
152
+ root: {
153
+ color: generatedPalette.tertiary.main,
154
+ },
155
+ },
156
+ },
157
+ MuiAccordionSummary: {
158
+ styleOverrides: {
159
+ root: {
160
+ backgroundColor: generatedPalette.tertiary.main,
161
+ },
162
+ content: {
163
+ color: generatedPalette.tertiary.contrastText,
164
+ },
165
+ },
166
+ },
167
+ },
168
+ };
169
+ }
170
+ exports.createJBrowseDefaultOverrides = createJBrowseDefaultOverrides;
171
+ exports.jbrowseBaseTheme = {
172
+ palette: exports.jbrowseDefaultPalette,
173
+ typography: { fontSize: 12 },
174
+ spacing: 4,
175
+ ...(0, deepmerge_1.default)(createJBrowseDefaultProps(), createJBrowseDefaultOverrides()),
64
176
  };
65
- exports.jbrowseDefaultPalette = jbrowseDefaultPalette;
66
-
67
- function
68
- /* palette: PaletteOptions = {} */
69
- createJBrowseDefaultProps() {
70
- return {
71
- components: {
72
- MuiButton: {
73
- defaultProps: {
74
- size: 'small'
75
- }
76
- },
77
- MuiAccordion: {
78
- defaultProps: {
79
- disableGutters: true,
80
- TransitionProps: {
81
- timeout: 150
82
- }
83
- }
84
- },
85
- MuiFilledInput: {
86
- defaultProps: {
87
- margin: 'dense'
88
- }
89
- },
90
- MuiFormControl: {
91
- defaultProps: {
92
- margin: 'dense',
93
- size: 'small'
94
- }
95
- },
96
- MuiFormHelperText: {
97
- defaultProps: {
98
- margin: 'dense'
99
- }
100
- },
101
- MuiIconButton: {
102
- defaultProps: {
103
- size: 'small'
104
- }
105
- },
106
- MuiInputBase: {
107
- defaultProps: {
108
- margin: 'dense'
109
- }
110
- },
111
- MuiAutocomplete: {
112
- defaultProps: {
113
- size: 'small'
114
- }
115
- },
116
- MuiInputLabel: {
117
- defaultProps: {
118
- margin: 'dense'
119
- }
120
- },
121
- MuiToolbar: {
122
- defaultProps: {
123
- variant: 'dense'
124
- }
125
- },
126
- MuiListItem: {
127
- defaultProps: {
128
- dense: true
129
- }
130
- },
131
- MuiOutlinedInput: {
132
- defaultProps: {
133
- margin: 'dense'
134
- }
135
- },
136
- MuiFab: {
137
- defaultProps: {
138
- size: 'small'
139
- }
140
- },
141
- MuiTable: {
142
- defaultProps: {
143
- size: 'small'
144
- }
145
- },
146
- MuiMenuList: {
147
- defaultProps: {
148
- dense: true
149
- }
150
- },
151
- MuiMenuItem: {
152
- defaultProps: {
153
- dense: true
154
- }
155
- },
156
- MuiTextField: {
157
- defaultProps: {
158
- margin: 'dense',
159
- variant: 'standard'
160
- }
161
- }
177
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
178
+ function createJBrowseTheme(theme) {
179
+ var _a, _b, _c, _d;
180
+ if ((_a = theme === null || theme === void 0 ? void 0 : theme.palette) === null || _a === void 0 ? void 0 : _a.tertiary) {
181
+ theme = (0, deepmerge_1.default)(theme, {
182
+ palette: {
183
+ tertiary: refTheme.palette.augmentColor(((_b = theme.palette.tertiary) === null || _b === void 0 ? void 0 : _b.color)
184
+ ? theme.palette.tertiary
185
+ : {
186
+ color: theme.palette.tertiary,
187
+ }),
188
+ },
189
+ });
162
190
  }
163
- };
164
- }
165
-
166
- function createJBrowseDefaultOverrides() {
167
- var palette = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
168
- var generatedPalette = (0, _deepmerge.default)(jbrowseDefaultPalette, palette);
169
- return {
170
- components: {
171
- MuiIconButton: {
172
- styleOverrides: {
173
- colorSecondary: {
174
- color: generatedPalette.tertiary.main
175
- }
176
- }
177
- },
178
- MuiButton: {
179
- styleOverrides: {
180
- textSecondary: {
181
- color: generatedPalette.tertiary.main
182
- }
183
- }
184
- },
185
- MuiFab: {
186
- styleOverrides: {
187
- secondary: {
188
- backgroundColor: generatedPalette.quaternary.main
189
- }
190
- }
191
- },
192
- MuiLink: {
193
- styleOverrides: {
194
- root: {
195
- color: generatedPalette.tertiary.main
196
- }
197
- }
198
- },
199
- MuiAccordionSummary: {
200
- styleOverrides: {
201
- root: {
202
- backgroundColor: generatedPalette.tertiary.main
203
- },
204
- content: {
205
- color: generatedPalette.tertiary.contrastText
206
- }
207
- }
208
- }
191
+ if ((_c = theme === null || theme === void 0 ? void 0 : theme.palette) === null || _c === void 0 ? void 0 : _c.quaternary) {
192
+ theme = (0, deepmerge_1.default)(theme, {
193
+ palette: {
194
+ quaternary: refTheme.palette.augmentColor(((_d = theme.palette.quaternary) === null || _d === void 0 ? void 0 : _d.color)
195
+ ? theme.palette.quaternary
196
+ : {
197
+ color: theme.palette.quaternary,
198
+ }),
199
+ },
200
+ });
209
201
  }
210
- };
202
+ // @ts-ignore
203
+ return (0, styles_1.createTheme)((0, deepmerge_1.default)(exports.jbrowseBaseTheme, theme || {}));
211
204
  }
212
-
213
- var jbrowseBaseTheme = _objectSpread({
214
- palette: jbrowseDefaultPalette,
215
- typography: {
216
- fontSize: 12
217
- },
218
- spacing: 4
219
- }, (0, _deepmerge.default)(createJBrowseDefaultProps(), createJBrowseDefaultOverrides())); // eslint-disable-next-line @typescript-eslint/no-explicit-any
220
-
221
-
222
- exports.jbrowseBaseTheme = jbrowseBaseTheme;
223
-
224
- function createJBrowseTheme(theme) {
225
- var _theme, _theme$palette, _theme2, _theme2$palette;
226
-
227
- if ((_theme = theme) !== null && _theme !== void 0 && (_theme$palette = _theme.palette) !== null && _theme$palette !== void 0 && _theme$palette.tertiary) {
228
- var _theme$palette$tertia;
229
-
230
- theme = (0, _deepmerge.default)(theme, {
231
- palette: {
232
- tertiary: refTheme.palette.augmentColor((_theme$palette$tertia = theme.palette.tertiary) !== null && _theme$palette$tertia !== void 0 && _theme$palette$tertia.color ? theme.palette.tertiary : {
233
- color: theme.palette.tertiary
234
- })
235
- }
236
- });
237
- }
238
-
239
- if ((_theme2 = theme) !== null && _theme2 !== void 0 && (_theme2$palette = _theme2.palette) !== null && _theme2$palette !== void 0 && _theme2$palette.quaternary) {
240
- var _theme$palette$quater;
241
-
242
- theme = (0, _deepmerge.default)(theme, {
243
- palette: {
244
- quaternary: refTheme.palette.augmentColor((_theme$palette$quater = theme.palette.quaternary) !== null && _theme$palette$quater !== void 0 && _theme$palette$quater.color ? theme.palette.quaternary : {
245
- color: theme.palette.quaternary
246
- })
247
- }
248
- });
249
- } // @ts-ignore
250
-
251
-
252
- return (0, _styles.createTheme)((0, _deepmerge.default)(jbrowseBaseTheme, theme || {}));
253
- }
205
+ exports.createJBrowseTheme = createJBrowseTheme;
@@ -0,0 +1,32 @@
1
+ import { ViewSnap } from './index';
2
+ export interface BpOffset {
3
+ refName?: string;
4
+ index: number;
5
+ offset: number;
6
+ start?: number;
7
+ end?: number;
8
+ }
9
+ export declare function moveTo(self: ViewSnap & {
10
+ zoomTo: (arg: number) => number;
11
+ scrollTo: (arg: number) => void;
12
+ }, start?: BpOffset, end?: BpOffset): void;
13
+ export declare function pxToBp(self: ViewSnap, px: number): {
14
+ coord: number;
15
+ index: number;
16
+ refName: string;
17
+ oob: boolean;
18
+ assemblyName: string;
19
+ offset: number;
20
+ start: number;
21
+ end: number;
22
+ reversed: boolean;
23
+ };
24
+ export declare function bpToPx({ refName, coord, regionNumber, self, }: {
25
+ refName: string;
26
+ coord: number;
27
+ regionNumber?: number;
28
+ self: ViewSnap;
29
+ }): {
30
+ index: number;
31
+ offsetPx: number;
32
+ } | undefined;
@@ -0,0 +1,174 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.bpToPx = exports.pxToBp = exports.moveTo = void 0;
4
+ const mobx_state_tree_1 = require("mobx-state-tree");
5
+ function lengthBetween(self, start, end) {
6
+ let bpSoFar = 0;
7
+ const { displayedRegions } = self;
8
+ if (start.index === end.index) {
9
+ bpSoFar += end.offset - start.offset;
10
+ }
11
+ else {
12
+ const s = displayedRegions[start.index];
13
+ bpSoFar += s.end - s.start - start.offset;
14
+ if (end.index - start.index >= 2) {
15
+ for (let i = start.index + 1; i < end.index; i++) {
16
+ const region = displayedRegions[i];
17
+ const len = region.end - region.start;
18
+ bpSoFar += len;
19
+ }
20
+ }
21
+ bpSoFar += end.offset;
22
+ }
23
+ return bpSoFar;
24
+ }
25
+ function moveTo(self, start, end) {
26
+ if (!start || !end) {
27
+ return;
28
+ }
29
+ const { width, interRegionPaddingWidth } = self;
30
+ const len = lengthBetween(self, start, end);
31
+ const numBlocks = end.index - start.index;
32
+ const targetBpPerPx = len / (width - interRegionPaddingWidth * numBlocks);
33
+ const newBpPerPx = self.zoomTo(targetBpPerPx);
34
+ // If our target bpPerPx was smaller than the allowed minBpPerPx, adjust
35
+ // the scroll so the requested range is in the middle of the screen
36
+ let extraBp = 0;
37
+ if (targetBpPerPx < newBpPerPx) {
38
+ extraBp = ((newBpPerPx - targetBpPerPx) * self.width) / 2;
39
+ }
40
+ let bpToStart = -extraBp;
41
+ for (let i = 0; i < self.displayedRegions.length; i += 1) {
42
+ const region = self.displayedRegions[i];
43
+ if (start.index === i) {
44
+ bpToStart += start.offset;
45
+ break;
46
+ }
47
+ else {
48
+ bpToStart += region.end - region.start;
49
+ }
50
+ }
51
+ self.scrollTo(Math.round(bpToStart / self.bpPerPx));
52
+ }
53
+ exports.moveTo = moveTo;
54
+ // manual return type since getSnapshot hard to infer here
55
+ function pxToBp(self, px) {
56
+ var _a;
57
+ let bpSoFar = 0;
58
+ const { bpPerPx, offsetPx, displayedRegions, interRegionPaddingWidth, staticBlocks, } = self;
59
+ const blocks = staticBlocks.contentBlocks;
60
+ const bp = (offsetPx + px) * bpPerPx;
61
+ if (bp < 0) {
62
+ const region = displayedRegions[0];
63
+ const snap = (0, mobx_state_tree_1.getSnapshot)(region);
64
+ // @ts-ignore
65
+ return {
66
+ // xref https://github.com/mobxjs/mobx-state-tree/issues/1524 for Omit
67
+ ...snap,
68
+ oob: true,
69
+ coord: region.reversed
70
+ ? Math.floor(region.end - bp) + 1
71
+ : Math.floor(region.start + bp) + 1,
72
+ offset: bp,
73
+ index: 0,
74
+ };
75
+ }
76
+ const interRegionPaddingBp = interRegionPaddingWidth * bpPerPx;
77
+ let currBlock = 0;
78
+ for (let i = 0; i < displayedRegions.length; i++) {
79
+ const region = displayedRegions[i];
80
+ const len = region.end - region.start;
81
+ const offset = bp - bpSoFar;
82
+ if (len + bpSoFar > bp && bpSoFar <= bp) {
83
+ const snap = (0, mobx_state_tree_1.getSnapshot)(region);
84
+ // @ts-ignore
85
+ return {
86
+ // xref https://github.com/mobxjs/mobx-state-tree/issues/1524 for Omit
87
+ ...snap,
88
+ oob: false,
89
+ offset,
90
+ coord: region.reversed
91
+ ? Math.floor(region.end - offset) + 1
92
+ : Math.floor(region.start + offset) + 1,
93
+ index: i,
94
+ };
95
+ }
96
+ // add the interRegionPaddingWidth if the boundary is in the screen e.g. in
97
+ // a static block
98
+ if (((_a = blocks[currBlock]) === null || _a === void 0 ? void 0 : _a.regionNumber) === i) {
99
+ bpSoFar += len + interRegionPaddingBp;
100
+ currBlock++;
101
+ }
102
+ else {
103
+ bpSoFar += len;
104
+ }
105
+ }
106
+ if (bp >= bpSoFar) {
107
+ const region = displayedRegions[displayedRegions.length - 1];
108
+ const len = region.end - region.start;
109
+ const offset = bp - bpSoFar + len;
110
+ const snap = (0, mobx_state_tree_1.getSnapshot)(region);
111
+ // @ts-ignore
112
+ return {
113
+ // xref https://github.com/mobxjs/mobx-state-tree/issues/1524 for Omit
114
+ ...snap,
115
+ oob: true,
116
+ offset,
117
+ coord: region.reversed
118
+ ? Math.floor(region.end - offset) + 1
119
+ : Math.floor(region.start + offset) + 1,
120
+ index: displayedRegions.length - 1,
121
+ };
122
+ }
123
+ return {
124
+ coord: 0,
125
+ index: 0,
126
+ refName: '',
127
+ oob: true,
128
+ assemblyName: '',
129
+ offset: 0,
130
+ start: 0,
131
+ end: 0,
132
+ reversed: false,
133
+ };
134
+ }
135
+ exports.pxToBp = pxToBp;
136
+ function bpToPx({ refName, coord, regionNumber, self, }) {
137
+ var _a;
138
+ let bpSoFar = 0;
139
+ const { interRegionPaddingWidth, bpPerPx, displayedRegions, staticBlocks } = self;
140
+ const blocks = staticBlocks.contentBlocks;
141
+ const interRegionPaddingBp = interRegionPaddingWidth * bpPerPx;
142
+ let currBlock = 0;
143
+ let i = 0;
144
+ for (; i < displayedRegions.length; i++) {
145
+ const region = displayedRegions[i];
146
+ const len = region.end - region.start;
147
+ if (refName === region.refName &&
148
+ coord >= region.start &&
149
+ coord <= region.end) {
150
+ if (regionNumber ? regionNumber === i : true) {
151
+ bpSoFar += region.reversed ? region.end - coord : coord - region.start;
152
+ break;
153
+ }
154
+ }
155
+ // add the interRegionPaddingWidth if the boundary is in the screen e.g. in
156
+ // a static block
157
+ if (((_a = blocks[currBlock]) === null || _a === void 0 ? void 0 : _a.regionNumber) === i) {
158
+ bpSoFar += len + interRegionPaddingBp;
159
+ currBlock++;
160
+ }
161
+ else {
162
+ bpSoFar += len;
163
+ }
164
+ }
165
+ const found = displayedRegions[i];
166
+ if (found) {
167
+ return {
168
+ index: i,
169
+ offsetPx: Math.round(bpSoFar / bpPerPx),
170
+ };
171
+ }
172
+ return undefined;
173
+ }
174
+ exports.bpToPx = bpToPx;