@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
package/ui/theme.js CHANGED
@@ -1,233 +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;
9
- 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("@material-ui/core/colors");
16
-
17
- var _styles = require("@material-ui/core/styles");
18
-
19
- var _createPalette = require("@material-ui/core/styles/createPalette");
20
-
21
- var _deepmerge = _interopRequireDefault(require("deepmerge"));
22
-
23
- 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; }
24
-
25
- 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; }
26
-
27
- var midnight = '#0D233F';
28
- var grape = '#721E63';
29
- var forest = '#135560';
30
- var mandarin = '#FFB11D';
31
- var refTheme = (0, _styles.createTheme)();
32
- var jbrowseDefaultPalette = {
33
- // type: 'dark',
34
- primary: {
35
- main: midnight
36
- },
37
- secondary: {
38
- main: grape
39
- },
40
- tertiary: refTheme.palette.augmentColor({
41
- main: forest
42
- }),
43
- quaternary: refTheme.palette.augmentColor({
44
- main: mandarin
45
- }),
46
- stopCodon: '#e22',
47
- startCodon: '#3e3',
48
- bases: {
49
- A: refTheme.palette.augmentColor(_colors.green),
50
- C: refTheme.palette.augmentColor(_colors.blue),
51
- G: refTheme.palette.augmentColor(_colors.amber),
52
- T: refTheme.palette.augmentColor(_colors.red)
53
- }
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
54
4
  };
55
- exports.jbrowseDefaultPalette = jbrowseDefaultPalette;
56
-
57
- function
58
- /* palette: PaletteOptions = {} */
59
- createJBrowseDefaultProps() {
60
- return {
61
- MuiButton: {
62
- size: 'small'
63
- },
64
- MuiFilledInput: {
65
- margin: 'dense'
66
- },
67
- MuiFormControl: {
68
- margin: 'dense'
69
- },
70
- MuiFormHelperText: {
71
- margin: 'dense'
72
- },
73
- MuiIconButton: {
74
- size: 'small'
75
- },
76
- MuiInputBase: {
77
- margin: 'dense'
78
- },
79
- MuiList: {
80
- dense: true
81
- },
82
- MuiListItem: {
83
- dense: true
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 }),
84
28
  },
85
- MuiOutlinedInput: {
86
- margin: 'dense'
87
- },
88
- MuiFab: {
89
- size: 'small'
90
- },
91
- MuiTable: {
92
- size: 'small'
93
- },
94
- MuiTextField: {
95
- margin: 'dense',
96
- size: 'small'
97
- },
98
- MuiToolbar: {
99
- variant: 'dense'
100
- },
101
- MuiSvgIcon: {
102
- fontSize: 'small'
103
- },
104
- MuiToggleButtonGroup: {
105
- size: 'small'
106
- },
107
- MuiCheckbox: {
108
- size: 'small'
109
- },
110
- MuiLink: {
111
- underline: 'always'
112
- }
113
- };
114
- }
115
-
116
- function createJBrowseDefaultOverrides() {
117
- var palette = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
118
- var generatedPalette = (0, _deepmerge.default)(jbrowseDefaultPalette, palette);
119
- return {
120
- MuiIconButton: {
121
- colorSecondary: {
122
- color: generatedPalette.tertiary.main
123
- }
124
- },
125
- MuiButton: {
126
- textSecondary: {
127
- color: generatedPalette.tertiary.main
128
- }
129
- },
130
- MuiFab: {
131
- secondary: {
132
- backgroundColor: generatedPalette.quaternary.main
133
- }
134
- },
135
- MuiLink: {
136
- root: {
137
- color: generatedPalette.tertiary.main
138
- }
139
- },
140
- MuiAccordion: {
141
- root: {
142
- // avoid extra padding around accordion element
143
- margin: 0,
144
- '&$expanded': {
145
- margin: 0
146
- }
147
- }
148
- },
149
- MuiAccordionSummary: {
150
- root: {
151
- // !important needed to combat the MuiButton being applied to
152
- // accordions in mui4.12.2 having a background:'transparent' that
153
- // otherwise overrides this other
154
- backgroundColor: generatedPalette.tertiary.main + ' !important',
155
- // width:100% added in 4.12.2 also
156
- width: '100%',
157
- '&$expanded': {
158
- // overrides the subclass e.g. .MuiAccordionSummary-root-311.MuiAccordionSummary-expanded-312
159
- minHeight: 0,
160
- color: generatedPalette.tertiary.contrastText,
161
- backgroundColor: generatedPalette.tertiary.main
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
+ },
162
121
  },
163
- minHeight: 0
164
- },
165
- content: {
166
- '&$expanded': {
167
- margin: '8px 8px'
122
+ };
123
+ }
124
+ exports.createJBrowseDefaultProps = createJBrowseDefaultProps;
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
+ },
168
167
  },
169
- margin: '8px 8px',
170
- color: generatedPalette.tertiary.contrastText
171
- }
172
- },
173
- // makes menus more compact
174
- MuiMenuItem: {
175
- root: {
176
- paddingTop: 3,
177
- paddingBottom: 3
178
- }
179
- },
180
- // the below two are linked to make menus more compact
181
- MuiListItemIcon: {
182
- root: {
183
- minWidth: 32
184
- }
185
- },
186
- MuiListItemText: {
187
- inset: {
188
- paddingLeft: 32
189
- }
190
- }
191
- };
168
+ };
192
169
  }
193
-
194
- var jbrowseBaseTheme = {
195
- palette: jbrowseDefaultPalette,
196
- typography: {
197
- fontSize: 12
198
- },
199
- spacing: 4,
200
- props: createJBrowseDefaultProps(),
201
- overrides: createJBrowseDefaultOverrides()
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()),
202
176
  };
203
- exports.jbrowseBaseTheme = jbrowseBaseTheme;
204
-
177
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
205
178
  function createJBrowseTheme(theme) {
206
- var _theme$palette, _theme$palette2;
207
-
208
- if (!theme) {
209
- return (0, _styles.createTheme)(jbrowseBaseTheme);
210
- }
211
-
212
- if ((_theme$palette = theme.palette) !== null && _theme$palette !== void 0 && _theme$palette.tertiary) {
213
- theme = _objectSpread(_objectSpread({}, theme), {}, {
214
- palette: _objectSpread(_objectSpread({}, theme.palette), {}, {
215
- tertiary: refTheme.palette.augmentColor(theme.palette.tertiary)
216
- })
217
- });
218
- }
219
-
220
- if ((_theme$palette2 = theme.palette) !== null && _theme$palette2 !== void 0 && _theme$palette2.quaternary) {
221
- theme = _objectSpread(_objectSpread({}, theme), {}, {
222
- palette: _objectSpread(_objectSpread({}, theme.palette), {}, {
223
- quaternary: refTheme.palette.augmentColor(theme.palette.quaternary)
224
- })
225
- });
226
- }
227
-
228
- theme = _objectSpread(_objectSpread({}, theme), {}, {
229
- props: (0, _deepmerge.default)(createJBrowseDefaultProps(), theme.props || {}),
230
- overrides: (0, _deepmerge.default)(createJBrowseDefaultOverrides(theme.palette), theme.overrides || {})
231
- });
232
- return (0, _styles.createTheme)((0, _deepmerge.default)(jbrowseBaseTheme, theme));
233
- }
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
+ });
190
+ }
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
+ });
201
+ }
202
+ // @ts-ignore
203
+ return (0, styles_1.createTheme)((0, deepmerge_1.default)(exports.jbrowseBaseTheme, theme || {}));
204
+ }
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;