@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/util/when.js CHANGED
@@ -1,115 +1,68 @@
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.when = when;
9
- exports.whenPresent = whenPresent;
10
-
11
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
12
-
13
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
14
-
15
- var _mobx = require("mobx");
16
-
17
- var _aborting = require("./aborting");
18
-
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.whenPresent = exports.when = void 0;
4
+ const mobx_1 = require("mobx");
5
+ const aborting_1 = require("./aborting");
19
6
  /**
20
7
  * Wrapper for mobx `when` that adds timeout and aborting support.
21
8
  */
22
- function when(getter) {
23
- var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
24
- timeout = _ref.timeout,
25
- signal = _ref.signal,
26
- name = _ref.name;
27
-
28
- return new Promise(function (resolve, reject) {
29
- var finished = false;
30
- var whenPromise = (0, _mobx.when)(getter); // set up timeout
31
-
32
- var timeoutId;
33
-
34
- var finishTimeout = function finishTimeout() {};
35
-
36
- if (timeout) {
37
- timeoutId = setTimeout(function () {
38
- if (!finished) {
39
- finished = true;
40
- whenPromise.cancel();
41
- reject(new Error("timed out waiting for ".concat(name || 'whenPresent')));
9
+ function when(getter, { timeout, signal, name } = {}) {
10
+ return new Promise((resolve, reject) => {
11
+ let finished = false;
12
+ const whenPromise = (0, mobx_1.when)(getter);
13
+ // set up timeout
14
+ let timeoutId;
15
+ let finishTimeout = () => { };
16
+ if (timeout) {
17
+ timeoutId = setTimeout(() => {
18
+ if (!finished) {
19
+ finished = true;
20
+ whenPromise.cancel();
21
+ reject(new Error(`timed out waiting for ${name || 'whenPresent'}`));
22
+ }
23
+ }, timeout);
24
+ finishTimeout = () => timeoutId && clearTimeout(timeoutId);
42
25
  }
43
- }, timeout);
44
-
45
- finishTimeout = function finishTimeout() {
46
- return timeoutId && clearTimeout(timeoutId);
47
- };
48
- } // set up aborting
49
-
50
-
51
- if (signal) {
52
- signal.addEventListener('abort', function () {
53
- if (!finished) {
54
- finished = true; // mobx when supports a cancel method
55
-
56
- whenPromise.cancel();
57
- finishTimeout();
58
- reject((0, _aborting.makeAbortError)());
26
+ // set up aborting
27
+ if (signal) {
28
+ signal.addEventListener('abort', () => {
29
+ if (!finished) {
30
+ finished = true;
31
+ // mobx when supports a cancel method
32
+ whenPromise.cancel();
33
+ finishTimeout();
34
+ reject((0, aborting_1.makeAbortError)());
35
+ }
36
+ });
59
37
  }
60
- });
61
- }
62
-
63
- whenPromise.then(function () {
64
- if (!finished) {
65
- finished = true;
66
- finishTimeout();
67
- resolve(true);
68
- }
69
- }).catch(function (err) {
70
- if (!finished) {
71
- finished = true;
72
- finishTimeout();
73
- reject(err);
74
- }
38
+ whenPromise
39
+ .then(() => {
40
+ if (!finished) {
41
+ finished = true;
42
+ finishTimeout();
43
+ resolve(true);
44
+ }
45
+ })
46
+ .catch(err => {
47
+ if (!finished) {
48
+ finished = true;
49
+ finishTimeout();
50
+ reject(err);
51
+ }
52
+ });
75
53
  });
76
- });
77
54
  }
55
+ exports.when = when;
78
56
  /**
79
57
  * Wrapper for mobx `when` that makes a promise for the return value
80
58
  * of the given function at the point in time when it becomes not
81
59
  * undefined and not null.
82
60
  */
83
-
84
-
85
- function whenPresent(_x) {
86
- return _whenPresent.apply(this, arguments);
61
+ async function whenPresent(getter, opts = {}) {
62
+ await when(() => {
63
+ const val = getter();
64
+ return val !== undefined && val !== null;
65
+ }, opts);
66
+ return getter();
87
67
  }
88
-
89
- function _whenPresent() {
90
- _whenPresent = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(getter) {
91
- var opts,
92
- _args = arguments;
93
- return _regenerator.default.wrap(function _callee$(_context) {
94
- while (1) {
95
- switch (_context.prev = _context.next) {
96
- case 0:
97
- opts = _args.length > 1 && _args[1] !== undefined ? _args[1] : {};
98
- _context.next = 3;
99
- return when(function () {
100
- var val = getter();
101
- return val !== undefined && val !== null;
102
- }, opts);
103
-
104
- case 3:
105
- return _context.abrupt("return", getter());
106
-
107
- case 4:
108
- case "end":
109
- return _context.stop();
110
- }
111
- }
112
- }, _callee);
113
- }));
114
- return _whenPresent.apply(this, arguments);
115
- }
68
+ exports.whenPresent = whenPresent;
@@ -1,122 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- var _react = _interopRequireDefault(require("react"));
6
-
7
- var _react2 = require("@testing-library/react");
8
-
9
- var _fs = _interopRequireDefault(require("fs"));
10
-
11
- var _SequenceFeatureDetails = require("./SequenceFeatureDetails");
12
-
13
- var _DLGAP = _interopRequireDefault(require("./test_data/DLGAP3.json"));
14
-
15
- var _NCDN = _interopRequireDefault(require("./test_data/NCDN.json"));
16
-
17
- test('test using the sequence feature panel', function () {
18
- // produced from uniprot
19
- // https://www.uniprot.org/uniprot/O95886.fasta
20
- var pep = readFasta('./test_data/DLGAP3_pep.fa'); // produced with samtools faidx
21
- // 'https://jbrowse.org/genomes/hg19/fasta/hg19.fa.gz'
22
- // 1:35331037..35395251
23
-
24
- var dna = readFasta('./test_data/DLGAP3_dna.fa'); // http://localhost:3000/?config=test_data%2Fconfig_demo.json&session=share-zMPjiv36k0&password=ddxCy
25
-
26
- var feature = _DLGAP.default;
27
-
28
- var _render = (0, _react2.render)( /*#__PURE__*/_react.default.createElement(_SequenceFeatureDetails.SequencePanel, {
29
- sequence: {
30
- seq: dna
31
- },
32
- mode: "protein",
33
- feature: feature.subfeatures[0]
34
- })),
35
- getByTestId = _render.getByTestId;
36
-
37
- var element = getByTestId('sequence_panel'); // http://m.ensembl.org/Homo_sapiens/Gene/Summary?db=core;g=ENSG00000116544;r=1:34865436-34929650
38
- // with stop codon on the end
39
-
40
- expect(element.textContent).toEqual(">NM_001080418.3-protein\n".concat(pep, "*"));
41
- });
42
-
43
- var readFasta = function readFasta(filename) {
44
- return _fs.default.readFileSync(require.resolve(filename), 'utf8').split('\n').slice(1).join('');
45
- };
46
-
47
- test('NCDN collapsed intron', function () {
48
- // samtools faidx 'https://jbrowse.org/genomes/hg19/fasta/hg19.fa.gz' 1:36,023,400-36,032,380 > out.fa
49
- var dna = readFasta('./test_data/NCDN_dna.fa'); // http://localhost:3000/?config=test_data%2Fconfig_demo.json&session=share-zMPjiv36k0&password=ddxCy
50
-
51
- var feature = _NCDN.default;
52
-
53
- var _render2 = (0, _react2.render)( /*#__PURE__*/_react.default.createElement(_SequenceFeatureDetails.SequencePanel, {
54
- sequence: {
55
- seq: dna
56
- },
57
- mode: "gene_collapsed_intron",
58
- feature: feature.subfeatures[0]
59
- })),
60
- getByTestId = _render2.getByTestId;
61
-
62
- var element = getByTestId('sequence_panel'); // UTR
63
-
64
- expect(element.children[0].textContent).toEqual('>NM_014284.3-gene_collapsed_intron\nAGTGGGCAACGCGGCGTGAGCAGCGGCCCGAGGCTCCCGGAGCATCGCGCTGGGAGAAGACTTCGCCGCTCGGGGCCGCAGCCTGGTGAGCTCAGCCCCCTTCGGGCCCTCCCCTGCATCCCAGCCGGGGCCTCTCCGAGCCGGCGCTGATCGATGCCGACACACCCCGGGGACCCTATCGCGACTCCATCGCGCCATATCGCGACACCATCGTGCCCTGTCGAGACTCCATTTTGTCACAGCCCTTTTCAATATATATCTTTTTTTTTTTTAATTTGCCCTGTCATCTTTGGGGGCTGTCTCCCATGTCGTGATTTTGACGTGATCTCTCCGTGACATCACCGCGCCATCGTGAAGTGTGATCTCATCGCCGCCCTGTCGTGACTTCATCAATGTCGTGTTGTGACCTGGCTGCGGCGGGACAGGTGGTGACCG...GTGTTCACAGTTGGGCAAGGCGAGCATCATGGCCTCGGATTGCGAGCCAGCTCTGAACCAGGCAGAGGGCCGAAACCCCACCCTGGAGCGCTACCTGGGAGCCCTCCGTGAGGCCAAGAATGACAGCGAGCAGTTTGCAGCCCTGCTGCTAGTAAGGAACT...CCCCCTATAGGTGACCAAGGCAGTCAAAGCAGGTGACATAGATGCCAAAACTCGGCGGCGGATCTTCGATGCTGTCGGCTTCACCTTCCCCAATCGTCTCCTGACCACCAAGGAGGCGCCGGATGGCTGCCCTGACCATGTTCTGCGGGCTTTGGGTGTGGCCCTGCTGGCCTGCTTCTGCAGTGACCCTGAACTGGCCGCCCATCCCCAAGTCCTGAACAAGATTCCCATTCTTAGCACCTTCCTCACAGCCCGGGGGGACCCGGACGATGCTGCCCGCCGCTCCATGATTGATGACACCTACCAGTGCCTGACGGCTGTAGCAGGCACACCCAGAGGGCCTCGGCACCTCATTGCTGGTGGCACCGTGTCTGCCCTATGCCAGGCATACCTGGGGCACGGCTATGGCTTTGACCAGGCCCTGGCACTCCTGGTGGGGCTGCTGGCTGCTGCCGAGACACAGTGCTGGAAGGAGGCGGAGCCCGACCTGCTGGCCGTGTTGCGGGGCCTCAGTGAGGATTTCCAGAAAGCTGAGGATGCCAGCAAGTTTGAGCTCTGCCAGCTGCTGCCCCTCTTTTTGCCCCCGACAACCGTGCCCCCTGAATGCTACCGGGATCTGCAGGCCGGGCTGGCACGCATCCTGGGAAGCAAGCTGAGCTCCTGGCAGCGCAACCCTGCACTGAAGCTGGCAGCCCGCCTGGCACACGCCTGCGGCTCCGACTGGATCCCGGCGGGCAGCTCCGGGAGCAAGTTCCTGGCCCTGCTGGTGAATCTGGCGTGCGTGGAAGTGCGGCTGGCACTGGAGGAGACGGGCACGGAGGTGAAAGAGGATGTGGTGACCGCCTGCTATGCCCTCATGGAGTTGGGGATCCAGGAATGCACTCGCTGTGAGCAGTCACTGCTTAAGGAGCCACAGAAGGTGCAGCTCGTGAGCGTCATGAAGGAGGCCATAGGGGCTGTTATCCACTACCTGCTGCAGGTGAGGGTGC...GTGGCAACAGGTGGGGTCAGAGAAGCAGAAGGAGCCCTTTGTGTTTGCCTCGGTGCGGATCCTGGGTGCCTGGCTGGCCGAGGAGACCTCATCCTTGCGTAAGGAGGTGTGCCAGCTGCTGCCCTTCCTCGTCCGCTATGCCAAGACCCTCTACGAGGAGGCCGAGGAGGCCAATGACCTTTCCCAGCAGGTGGCCAACCTGGCCATCTCCCCCACCACCCCAGGGCCCACCTGGCCAGGAGACGCTCTCCGGTGAGTCTGT...ACATCCCCAGGCTCCTCCTGCCTGGCTGGTGCCACCTGACCGTTGAAGATGGGCCCCGGGAGATCCTGATCAAGGAAGGGGCCCCCTCGCTTCTGTGCAAGTATTTCCTGCAGCAGTGGGAACTCACATCCCCTGGCCACGACACCTCGGTGCTGCCTGACAGCGTGGAGATTGGCCTGCAGACCTGCTGCCACATCTTCCTCAACCTCGTGGTCACCGCACCGGGGCTGATCAAGTGAGGGGCT...TCTTTTCCAGGCGTGACGCCTGCTTCACATCTCTAATGAACACCCTCATGACGTCGCTACCAGCACTAGTGCAGCAACAGGGAAGGCTGCTTCTGGCTGCTAATGTGGCCACCCTGGGGCTCCTCATGGCCCGGCTCCTTAGCACCTCTCCAGGTAAGAACTG...TACCTTGCAGCTCTTCAGGGAACACCAGCATCCCGAGGGTTCTTCGCAGCTGCCATCCTCTTCCTATCACAGTCCCACGTGGCGCGGGCCACCCCGGGCTCAGACCAGGCAGTGCTAGCCCTGTCCCCTGAGTATGAGGGCATCTGGGCCGACCTGCAGGAGCTCTGGTTCCTGGGCATGCAGGCCTTCACCGGCTGTGTGCCTCTGCTGCCCTGGCTGGCCCCCGCTGCCCTGCGCTCCCGCTGGCCGCAGGAGCTGCTCCAGCTGCTAGGCAGTGTCAGCCCCAACTCTGTCAAGCCCGAGATGGTGGCCGCCTATCAGGGTGTCCTGGTGGAGCTGGCGCGGGCCAACCGGCTGTGCCGGGAGGCCATGAGGCTGCAGGCGGGCGAGGAGACGGCCAGCCACTACCGCATGGCTGCCTTGGAGCAGTGCCTGTCAGAGCCCTGAGGGGTGTCCACCGGGGACAGACCCAGGGGCGGGCAGAGAGGGAAGGAGGGAGGAGGCATCTTCCCTGAAGCCCCCAATCTGGCCCCCCCCTCCCCAGACTTCCTCCCCAAAACACCCCAGCTTTCTGGCTTTTCTGAGGGCAAGGGCATGGTGCCCACCCCTCAAGTGTAAGGAACTGCGTTCCGCCCCTCAGGCCCCCATGGGGGCAGGGATCGGCTTGGAAATCAACGTGGTTGTCCCCGCCAGGCCGGGGAAGGTTGGAGCAGCCCCCAGGGAGGGGGGCACTAGGTGTCATTGTGCCCGATGTCTGGCTCCCCTGCAGGAGGGAGGCTCCAGGGTAAGACAGGGCTGGCAGGAGCAGACTGCCTCAGCCCATGTGCCCTGCCGGCCAGGGCGTGGGCTCCCCTCGGCTGTGGTGCCTCCTCTGGCCCCCCAGGTCCACGTCCTTTAAATTGGCCCTTTGGCTCTTGCCCTTGGCTCCCTTGGGCAGACAGCAGGCTTAGGCCATTGATATCGCAGTTCTTCCTATCAGCTTCAGTGACCCAGGGTCTGAACTGCCTCCATCCTAGGGCAACCTGGGGCAGACAGGCCTGGTGGGGGGTGGGGAAACCTCCTTCCACCTGAGCTTGCTTGAAGGGACCCAGAGTCTTTGGGCCCAGATCTTTAAACCTTTGTGTCGTGTTGCAGCAGAGTGACGATGGGGGTTGGGGGGTTATTTATTTTGCCTGTCCTTATCCCTGCTTGGACACCTGAGCATCTGATTCCTGTCCCCCTGGTGCCATCTGGCCTGGCTGGAGCCAGGAACAGGAGGGACACTTCCCCAGAATCCGCATGTTTCCCCAGTGATTACACTCCACTGCCACCGTGGTGCCTGGCTTTAACTCCCACCCCTGCTATGACTCCTCTCTGCAGAGACGCGACTGGCGGCTCCAGCAGGGACTACCTTTCTTATAAACCCAGGGGGACcacacacacacacacacacacacacacacacacacacacacacacacacacTCTTGATCCCTTGCTTCCCTCCCCCAGTGCGTTCTGTGATCGCCAAGTTCAAAGCTGTGCACATGTGGACACTCAATAAATGTTCATTGGTGACGAGAA');
65
- });
66
- test('NCDN updownstream', function () {
67
- // produced from uniprot
68
- // https://www.uniprot.org/uniprot/O95886.fasta
69
- var upstream = readFasta('./test_data/NCDN_upstream_dna.fa'); // samtools faidx 'https://jbrowse.org/genomes/hg19/fasta/hg19.fa.gz' 1:36,023,400-36,032,380 > out.fa
70
-
71
- var seq = readFasta('./test_data/NCDN_dna.fa'); // http://localhost:3000/?config=test_data%2Fconfig_demo.json&session=share-zMPjiv36k0&password=ddxCy
72
-
73
- var feature = _NCDN.default;
74
-
75
- var _render3 = (0, _react2.render)( /*#__PURE__*/_react.default.createElement(_SequenceFeatureDetails.SequencePanel, {
76
- sequence: {
77
- seq: seq,
78
- upstream: upstream
79
- },
80
- mode: "gene_updownstream",
81
- feature: feature.subfeatures[0]
82
- })),
83
- getByTestId = _render3.getByTestId;
84
-
85
- var element = getByTestId('sequence_panel');
86
- expect(element.children[0].textContent).toEqual('>NM_014284.3-gene_updownstream\nCTCACCCGGAGGAGGAGGAGGAAGAGGAAGAAGGTAGTGCGGGCTCCCCACCCGGACAGCTACCTCTCGCCTCAGCCTCCCTGGACAGCGACGGCGGCCGGAAACACCGCCTCCTCCCACCTCCCCGGGACCGACCCGGAAACACACTCTCCATGCTAACCAAGCCCTCCCGCCCCTCCCCCGGGAAGGGCAATGCCGGCCGCGAGACCAAGGGGGAGGAGGGGCAGTGCTGGGCGGGTAAAACTACGCACAAGCGAAGGAATCTGGGCCCCCAGCCTCTCGCCGCCCGCTCTCCAGAGGCAGTCTGCACCTTGCCTCCTTCGCTCGAGCCCCAGCCCCCAGACTCGGGCAATACCCACAAGCAAGATGGCGGCAACGGCGGCACCCCCTACTGCTTAGCACCCTGACTTGCCATTGGCCAGAGCCCGGAGTGAAGCAGCCGCGGATTCGTCAAGAGCGGTGCGGGGGTGGGGGTGGAGCTGCAGCAGCCTGGAGCCAGGAGTGGGCAACGCGGCGTGAGCAGCGGCCCGAGGCTCCCGGAGCATCGCGCTGGGAGAAGACTTCGCCGCTCGGGGCCGCAGCCTGGTGAGCTCAGCCCCCTTCGGGCCCTCCCCTGCATCCCAGCCGGGGCCTCTCCGAGCCGGCGCTGATCGATGCCGACACACCCCGGGGACCCTATCGCGACTCCATCGCGCCATATCGCGACACCATCGTGCCCTGTCGAGACTCCATTTTGTCACAGCCCTTTTCAATATATATCTTTTTTTTTTTTAATTTGCCCTGTCATCTTTGGGGGCTGTCTCCCATGTCGTGATTTTGACGTGATCTCTCCGTGACATCACCGCGCCATCGTGAAGTGTGATCTCATCGCCGCCCTGTCGTGACTTCATCAATGTCGTGTTGTGACCTGGCTGCGGCGGGACAGGTGGTGACCGCCAGGAACCCTCCTCCCCTTCTCATCTCCCCATCTCAGCAGCCCTGCTTCGATTATCCGGCTTTTGGATTCTCCGTTGTCCTGGGAACTATCCGGGACCCCCTCTTGCTTCTCCAGCCCCTGCCGGCATCCACAGGCTGGTAGCGGGACGGGGAGGGCGAGAAGAGGGAGCGCAAGGGGTTAATTctgctgctgccgccgccgctgctgctgctgctgcAGCCTCTACCCGAGGGAGGGAAAGGAGAGGAGGCAAGGAGCCTGCGGGGGCGACTGAGAGCCCTGGCTGGAGGGGTGGGGTCCCCAAAGGGGCCTCCAAGCCTTCCCTGTTGAGCGTCTTGTATTCTCACTTCTGAAGCGTATCTCTGCCTCTGAAGAAGGGAGGGGAAAGGAAGCCTGGGGTGTCCTTTTCTCCCATGTCAGCCTGAGTCCGGATAATCGAACTTCACCCATGTATGTCTCCATTTCTCCCTGTCTGTCCTCACCACTCACTCCCTCTGTGTCCCTGTGGAGGGAGATAAAACCCAGCCTCCGGTGCCAGGGGGACAGCTGAGCAGTGGGGCCAGCTCCCGCCCACCCCCAGGAGACTGGTGAGGAGAGCTGTCCGGCTGAGCAGCAGCATGCATGGTCCTTCTTTCCCGCTTTCTGGAGGTGACCTTGGACCAGGGTCCCTTCTTTATCCCTAAGGATTTGCAGATCCAGCCCCTTAAAGGGGCTTCTGGGGGGAGGTCAGTCCTGAGGAGTCCACCCCTCCAGATtctctcctcccctccctctgtgctaatccctccctccctccatcctccactctcacccccaccccacccccgtccctccTCTGCAGAGGGATGCTCAGTCCCTCTTGTGTTCACAGTTGGGCAAGGCGAGCATCATGGCCTCGGATTGCGAGCCAGCTCTGAACCAGGCAGAGGGCCGAAACCCCACCCTGGAGCGCTACCTGGGAGCCCTCCGTGAGGCCAAGAATGACAGCGAGCAGTTTGCAGCCCTGCTGCTAGTAAGGAACTGGCTGAAAATTGGGAGGTGGGAAGGGCTGGGTGGTTGGGCCCCCAAGGAATGGGGTCAGTGAGTCCCCAAGGATATGTACGTAGTGCTAGCAACCCTGGAGGCACCAACGAAGGCCCAAGACCCCTACCTTTGTGCTCTTTTTTGCTCCCCCTGAGAATGGGGGCAAAGAGGAGAATGGGACTGAATAAGGCTGTGGCACTAGGGGCTGCCTGGGTCTGTTTTCTGGGGCGTCCCAGAGCAGATGGAAGCTGACTCATAGGGTAACAGCAGCAGGTAGTAACTAGTGCAGAGTACTTGAGGGCTGGGGATGGTTGTTCTGGGCCTGGAGAGAGTAGCAGGGCTGGAAGTGGCTGGGGAGGGGTCCTAGGGGAAGGCCAGGATGGCAGTAGGTAGGTTAAGGAATGGGAGCTAGTTTGGGGCTTAGCCTTTTTGGAGGAACCCAAGCTGGGGACAGCAGAGCAGAAGCTGCAGTGCTAGGAAGGGGGGGTTGTGTGTGGGGGGTGAAGGGAGGAGGGAGTACAGCCGCTGCTTGTTTGCCATGGCAACAAGGAGAAGGCTCTGGAGTCAAgggctcacactgcagcagaggaggtgtttaggtgaaatgtaaggggaaatgttttgacaggcggagcggcgagacacaggagccatttcccctgagaaggtggcagaaatggatcagggacttctctggagggAGCAATTAAGGAAGGACTTTAAATCCTTGGGAGATCTTAAAACATTGAGTTCTAAGCCCCTTCCATCCCAGGTTGTGGGCATttagacatcaggaagaacttctcaactggccaggtgttgaaatgctcaaatgaatggttgaggaagactAGACCTCACTTCCATGGGACAGTCACAGATGAGAGGGATCCCAGAGGTCACATTTATCTGCCTCTAAGGAGAAAAAAGGAGCTGGATGAAATGACCTCAGATGAGTCCTGTTGCATAACCTCATCTTGCTAGTCCTCAGTGCCCCAGGATGCAGGAGAGGGACAGTCTTTCCCACTTCTTCCTTTCATCCTGATGATAGCACATACCCCCTATAGGTGACCAAGGCAGTCAAAGCAGGTGACATAGATGCCAAAACTCGGCGGCGGATCTTCGATGCTGTCGGCTTCACCTTCCCCAATCGTCTCCTGACCACCAAGGAGGCGCCGGATGGCTGCCCTGACCATGTTCTGCGGGCTTTGGGTGTGGCCCTGCTGGCCTGCTTCTGCAGTGACCCTGAACTGGCCGCCCATCCCCAAGTCCTGAACAAGATTCCCATTCTTAGCACCTTCCTCACAGCCCGGGGGGACCCGGACGATGCTGCCCGCCGCTCCATGATTGATGACACCTACCAGTGCCTGACGGCTGTAGCAGGCACACCCAGAGGGCCTCGGCACCTCATTGCTGGTGGCACCGTGTCTGCCCTATGCCAGGCATACCTGGGGCACGGCTATGGCTTTGACCAGGCCCTGGCACTCCTGGTGGGGCTGCTGGCTGCTGCCGAGACACAGTGCTGGAAGGAGGCGGAGCCCGACCTGCTGGCCGTGTTGCGGGGCCTCAGTGAGGATTTCCAGAAAGCTGAGGATGCCAGCAAGTTTGAGCTCTGCCAGCTGCTGCCCCTCTTTTTGCCCCCGACAACCGTGCCCCCTGAATGCTACCGGGATCTGCAGGCCGGGCTGGCACGCATCCTGGGAAGCAAGCTGAGCTCCTGGCAGCGCAACCCTGCACTGAAGCTGGCAGCCCGCCTGGCACACGCCTGCGGCTCCGACTGGATCCCGGCGGGCAGCTCCGGGAGCAAGTTCCTGGCCCTGCTGGTGAATCTGGCGTGCGTGGAAGTGCGGCTGGCACTGGAGGAGACGGGCACGGAGGTGAAAGAGGATGTGGTGACCGCCTGCTATGCCCTCATGGAGTTGGGGATCCAGGAATGCACTCGCTGTGAGCAGTCACTGCTTAAGGAGCCACAGAAGGTGCAGCTCGTGAGCGTCATGAAGGAGGCCATAGGGGCTGTTATCCACTACCTGCTGCAGGTGAGGGTGCAGTGACCCACAGAGGGGGCCCAGTATGGGGGGAGCCAGTGCTGGAGCTGGGAGGCAAGGGGGAGGAGAATAATGGGGAGACAGCGAAGCTGCATGTCCACACAAGCTGATACTGTAGCCAGCACTCCAGGGAGTAGTGTGCGGCCCAACCTCCCTCTCTCTCCCTCCCTCCACACAAGCACCATACCACACACCATATGTGCACTCACATCACAGTacacacacacgcacacacacacaacacaGTAACCTCCCACTCAAACGCTCCCCCCAATACACACACACTACACGCCACACACCTCTCCCCAACACATGCACACAAGATTGAAGCAGTCTGTTCTGCTCACTCCATAGCATTGTTTTATACACGCACACACCCGAACTTCTAATGGTGCAGGGAAGAGAAGCAGGGCTGCCTGGTTCCTGGCCTCTATAGAGGTCTGGCTAGATCAATTCGCCTGCCTCCCCTACATCCCCTCCTGCCTCCCCGCCTGAGAGGCCAGCTGTCCTGTCCCACAGGGATTCAGTCATGACTCTGGTCTCTTTAATGGCCTGCTCCAGCCACCGAGCTCACCAGCCATATATTCCATGCACCACGCTAAGCTCATGTCTTTTTTCTGACTTAGCACAAAAGAGAGCATCCCCTCACTCCCACCATTGGGAGCAGTTACACAGTAGCCAGGAACCTGCCCTCCCACCCCAGGTCAGAGCTGCTGTAAAGGGTGTTTAACTTAGCTTTTGACCTATGAATTTCCTTCTAGCCTTGAGACACTCCAGAGGTAGGGAGTTAGGGAGATGTGACTGGAGCCTCAGCGAGTACGGGGGCATGTCACTCAATTCACTCAGGCCCAGTTCACTCAGCAGACGTGTGTGGAGGGCCTGGCTCACTCTGTGCCAGTCCCTTGTGTGCGTCcctaccacatgctaggtgctgggttcatgggacagaataaaggttggggcctgcctttgaaaggctcacaggccagAATTTCCTTCTAGTTGTATTATTTCTAGCTGGCTGGCCTCTGGCAAGGCAGGGAGGGTCCCTGGTCCTGCTCCATCTCAAGGGGGTCCTGTGGCAACAGGTGGGGTCAGAGAAGCAGAAGGAGCCCTTTGTGTTTGCCTCGGTGCGGATCCTGGGTGCCTGGCTGGCCGAGGAGACCTCATCCTTGCGTAAGGAGGTGTGCCAGCTGCTGCCCTTCCTCGTCCGCTATGCCAAGACCCTCTACGAGGAGGCCGAGGAGGCCAATGACCTTTCCCAGCAGGTGGCCAACCTGGCCATCTCCCCCACCACCCCAGGGCCCACCTGGCCAGGAGACGCTCTCCGGTGAGTCTGTAGTTACAGTCTGTCCAGCTAGATCATTCTACCGAAAAGCGTTAACACAAGGACACCCCTCCCCACAAACTGAGCTGTGCCAGGCTTCCTGATTGGGCCATGAGATATCCCTTAGGGTTATTTCTGTTTTGGGGGGCTTGTTCCCACAGGACTCCTCGGCTGCCAGGTGTCACTTGCCAACCCCAGATTTCTCAGTTAAaagagaacttatacttattgagcacctactacgagccaggtattttgctataccctttaccaaaatgatctcatttggtccacgtggtaaatataacagaagtctcattcacatatgaaagattaggaaactgaggctcatagagattaaagtcacttgcccacagtcacactttgtggcagagcccaagtttggtcctgggttgtgcgactctgaagcttgtactttttctgtggtaccTGCGAGGATGTGTCCTTCTCCCCTACTTCCATTTCTCTTAGGCAAGGTGCCCTAAAAAGGGAATCTATGTGCCTTCATCTCTCCCAATCCCACACACGTCTGTCCCTTCCACATCCCCAGGCTCCTCCTGCCTGGCTGGTGCCACCTGACCGTTGAAGATGGGCCCCGGGAGATCCTGATCAAGGAAGGGGCCCCCTCGCTTCTGTGCAAGTATTTCCTGCAGCAGTGGGAACTCACATCCCCTGGCCACGACACCTCGGTGCTGCCTGACAGCGTGGAGATTGGCCTGCAGACCTGCTGCCACATCTTCCTCAACCTCGTGGTCACCGCACCGGGGCTGATCAAGTGAGGGGCTCGGGAGAGGTGGGGGAGGAGGCCGGAGGAGGCAAAGGAGGCTGCCCAGTTGCCTCAATTCTCAGTCTCCTACTTTGCCCCCCATGCCCATGGATTTGTTAGTGGTAGCATGGGGGTCTCAGAGTAGACATAGCCAGCCCCGCACAAGGATTCGGCATGCTGGAACCCCCAGGTACTGTCTCAGCATGTCTGCTTGTTCCAATCTCTGCCCCCCAGATGCTATGTTTGGGGCCCAAAGTTAATCACCCTACTGCCTAATTTCTTGCCAAGGGCTTGATTTGGCTGTACTAGACCCCCACCTACCTCCATCCTTCCCCCCTTTCTTTTCCAGGCGTGACGCCTGCTTCACATCTCTAATGAACACCCTCATGACGTCGCTACCAGCACTAGTGCAGCAACAGGGAAGGCTGCTTCTGGCTGCTAATGTGGCCACCCTGGGGCTCCTCATGGCCCGGCTCCTTAGCACCTCTCCAGGTAAGAACTGGGGATCCAGTCCTGATGGGTGAGGACAGAAGACCTGGGTGGACCTCCTGTGTTTGGGGCAAAAGTCACCATTTTTAGAAGATGGTTTTGCAGCATTTTCTAAGCAAGAGGAAATCTTTGCAGTGTATCTCCATCCCCTACCCCCACCGTTCTTCCCAAAATGCTAACATTCTCTTTCTTCTGAAGACTTTTAAGGCAAAGTCTGGTGGGTGTTAAGTACAGACCTGCTCACAGGCACAGGCATAGGCACCTGGAATCCCTGGCAGCCAGAGGAATCTGAATCCAGTGTTTTCAAGGTGGAGCCGCCCCCACCCAGGCCTTGAGTCAGAAACCTGACTTCCTTCCATTGATGTTTTTCTCTGCTCTGCTCGGTACCTCACCCCCATCAGTGACAGCCTTCAGCACTTGGTGTCCCTCTATGCACACCTTCTCCCTAGCTCTGCCTCACTCTGGCTGTTTGCAGGGGGAGGGACGTCCCCTCCAGCCCCTGGCAGCCCTCCGTGTCTCCCTCTTTGGCTGTGGGTGTCTGCTTGGGTCCCTCTGTCCCTGCCTGTTCCCTGTGCCCCATCTGTCAGGTTGGAGGAGCTGAGCAGATGCCTGGGAACAGGGCGTAACATGCCCGTACCTTCCACTGCCTCTGTGTTCCTTTTGAGGGGTTCCCAGCAGGGTACCCCGTCATGGGAAGGGGTGCACATCCCTGTACACCAGGAGCCCACTCTGCACTCTCAGTCCCAGGCTGCATCTCTGCAGCCCCCAATTTCATGGTCCCAGTTCTGGCTCACCCTCAAATACCACCAGGTTAGGTTGACAGCTTCCTGGAGAGCACCTGCAGTGTGAGGGTCACCCCTTGAACAGCCAGTAAGCAAAGCAGGGTCACTTGCTTATGTTCCTCTCTGGCGCCCTCTTCTGGCCCAAGGATCAAATGGTGCAACTCCCTTAACCTGTGTCTGAGCTCTGTGTCCAGAACCCTGAGGGGTTCTCTCTCCCATCTGACCCTGTGACTCACCCCCACCTCCAGTGCCGGTAGAGGTCTTGGTGGTTGAGTGTACCAAGATGATCAcatttaattctcacaacaaatttctaagatgagcactattggcccattttacaagtaaagaaacagacccagaaaagttaattacccaaggtcacacagtgagcatctaaggcagggtttcaacgcaggcagtctgattccaggctgtgccctGGCTCCTGCATGTGTCTACACAGAGGACTAGGGAAGGGTCTGACACAGCAGCTGGCCTGTCCGATTCATGCCCCACTCCTTCCGTTACCTTGCAGCTCTTCAGGGAACACCAGCATCCCGAGGGTTCTTCGCAGCTGCCATCCTCTTCCTATCACAGTCCCACGTGGCGCGGGCCACCCCGGGCTCAGACCAGGCAGTGCTAGCCCTGTCCCCTGAGTATGAGGGCATCTGGGCCGACCTGCAGGAGCTCTGGTTCCTGGGCATGCAGGCCTTCACCGGCTGTGTGCCTCTGCTGCCCTGGCTGGCCCCCGCTGCCCTGCGCTCCCGCTGGCCGCAGGAGCTGCTCCAGCTGCTAGGCAGTGTCAGCCCCAACTCTGTCAAGCCCGAGATGGTGGCCGCCTATCAGGGTGTCCTGGTGGAGCTGGCGCGGGCCAACCGGCTGTGCCGGGAGGCCATGAGGCTGCAGGCGGGCGAGGAGACGGCCAGCCACTACCGCATGGCTGCCTTGGAGCAGTGCCTGTCAGAGCCCTGAGGGGTGTCCACCGGGGACAGACCCAGGGGCGGGCAGAGAGGGAAGGAGGGAGGAGGCATCTTCCCTGAAGCCCCCAATCTGGCCCCCCCCTCCCCAGACTTCCTCCCCAAAACACCCCAGCTTTCTGGCTTTTCTGAGGGCAAGGGCATGGTGCCCACCCCTCAAGTGTAAGGAACTGCGTTCCGCCCCTCAGGCCCCCATGGGGGCAGGGATCGGCTTGGAAATCAACGTGGTTGTCCCCGCCAGGCCGGGGAAGGTTGGAGCAGCCCCCAGGGAGGGGGGCACTAGGTGTCATTGTGCCCGATGTCTGGCTCCCCTGCAGGAGGGAGGCTCCAGGGTAAGACAGGGCTGGCAGGAGCAGACTGCCTCAGCCCATGTGCCCTGCCGGCCAGGGCGTGGGCTCCCCTCGGCTGTGGTGCCTCCTCTGGCCCCCCAGGTCCACGTCCTTTAAATTGGCCCTTTGGCTCTTGCCCTTGGCTCCCTTGGGCAGACAGCAGGCTTAGGCCATTGATATCGCAGTTCTTCCTATCAGCTTCAGTGACCCAGGGTCTGAACTGCCTCCATCCTAGGGCAACCTGGGGCAGACAGGCCTGGTGGGGGGTGGGGAAACCTCCTTCCACCTGAGCTTGCTTGAAGGGACCCAGAGTCTTTGGGCCCAGATCTTTAAACCTTTGTGTCGTGTTGCAGCAGAGTGACGATGGGGGTTGGGGGGTTATTTATTTTGCCTGTCCTTATCCCTGCTTGGACACCTGAGCATCTGATTCCTGTCCCCCTGGTGCCATCTGGCCTGGCTGGAGCCAGGAACAGGAGGGACACTTCCCCAGAATCCGCATGTTTCCCCAGTGATTACACTCCACTGCCACCGTGGTGCCTGGCTTTAACTCCCACCCCTGCTATGACTCCTCTCTGCAGAGACGCGACTGGCGGCTCCAGCAGGGACTACCTTTCTTATAAACCCAGGGGGACcacacacacacacacacacacacacacacacacacacacacacacacacacTCTTGATCCCTTGCTTCCCTCCCCCAGTGCGTTCTGTGATCGCCAAGTTCAAAGCTGTGCACATGTGGACACTCAATAAATGTTCATTGGTGACGAGAA'); // expect(element.children[1].textContent).toEqual(
87
- // 'AGTGGGCAACGCGGCGTGAGCAGCGGCCCGAGGCTCCCGGAGCATCGCGCTGGGAGAAGACTTCGCCGCTCGGGGCCGCAGCCTGGTGAGCTCAGCCCCCTTCGGGCCCTCCCCTGCATCCCAGCCGGGGCCTCTCCGAGCCGGCGCTGATCGATGCCGACACACCCCGGGGACCCTATCGCGACTCCATCGCGCCATATCGCGACACCATCGTGCCCTGTCGAGACTCCATTTTGTCACAGCCCTTTTCAATATATATCTTTTTTTTTTTTAATTTGCCCTGTCATCTTTGGGGGCTGTCTCCCATGTCGTGATTTTGACGTGATCTCTCCGTGACATCACCGCGCCATCGTGAAGTGTGATCTCATCGCCGCCCTGTCGTGACTTCATCA',
88
- // )
89
- // 3rd is a blank element, so go to 4th, not strictly needed for 3rd to be
90
- // blank but helps test
91
- // expect(element.children[3].textContent).toEqual(
92
- // 'ATGTCGTGTTGTGACCTGGCTGCGGCGGGACAG',
93
- // )
94
- });
95
- test('single exon cDNA should not have duplicate sequences', function () {
96
- var seq = readFasta('./test_data/volvox.fa');
97
-
98
- var _render4 = (0, _react2.render)( /*#__PURE__*/_react.default.createElement(_SequenceFeatureDetails.SequencePanel, {
99
- sequence: {
100
- seq: seq
101
- },
102
- mode: "cdna",
103
- feature: {
104
- start: 1200,
105
- end: 1500,
106
- type: 'mRNA',
107
- subfeatures: [{
108
- start: 1200,
109
- end: 1500,
110
- type: 'exon'
111
- }, {
112
- start: 1200,
113
- end: 1500,
114
- type: 'CDS'
115
- }]
116
- }
117
- })),
118
- getByTestId = _render4.getByTestId;
119
-
120
- var element = getByTestId('sequence_panel');
121
- expect(element.children[0].textContent).toEqual('>unknown-cdna\natgtcacctcgggtactgcctctattacagaggtatcttaatggcgcatccagccttgtggctgggtctacgtacgcgtgggcaccatacgtatgttggcaggaaaggtcaatcatgcttgtttcctcgtcgcagaaacgttcacactattggctcgcgggatcgaacgggcctgattatttttccagctcctgcgttcctatcacgccaactgtcgctaataaaatgttatatagagataacccattgctatgcaaggatggagaaaccgcttcacaacaccctagaattacttcagca');
122
- });
@@ -1,51 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- var _react = _interopRequireDefault(require("react"));
6
-
7
- var _react2 = require("@testing-library/react");
8
-
9
- var _mobxStateTree = require("mobx-state-tree");
10
-
11
- var _configuration = require("../configuration");
12
-
13
- var _PluginManager = _interopRequireDefault(require("../PluginManager"));
14
-
15
- var _ = require(".");
16
-
17
- var _BaseFeatureDetail = _interopRequireDefault(require("./BaseFeatureDetail"));
18
-
19
- test('open up a widget', function () {
20
- console.warn = jest.fn();
21
- var pluginManager = new _PluginManager.default([]);
22
-
23
- var Session = _mobxStateTree.types.model({
24
- pluginManager: _mobxStateTree.types.optional(_mobxStateTree.types.frozen(), {}),
25
- rpcManager: _mobxStateTree.types.optional(_mobxStateTree.types.frozen(), {}),
26
- configuration: (0, _configuration.ConfigurationSchema)('test', {}),
27
- widget: (0, _.stateModelFactory)(pluginManager)
28
- });
29
-
30
- var model = Session.create({
31
- widget: {
32
- type: 'BaseFeatureWidget'
33
- }
34
- });
35
-
36
- var _render = (0, _react2.render)( /*#__PURE__*/_react.default.createElement(_BaseFeatureDetail.default, {
37
- model: model.widget
38
- })),
39
- container = _render.container,
40
- getByText = _render.getByText;
41
-
42
- model.widget.setFeatureData({
43
- start: 2,
44
- end: 102,
45
- strand: 1,
46
- score: 37,
47
- refName: 'ctgA'
48
- });
49
- expect(container.firstChild).toMatchSnapshot();
50
- expect(getByText('ctgA:3..102 (+)')).toBeTruthy();
51
- });
@@ -1,42 +0,0 @@
1
- "use strict";
2
-
3
- var _typeof = require("@babel/runtime/helpers/typeof");
4
-
5
- var _BaseResults = _interopRequireWildcard(require("./BaseResults"));
6
-
7
- 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); }
8
-
9
- 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; }
10
-
11
- test('create BaseResult', function () {
12
- var baseResult = new _BaseResults.default({
13
- label: 'chr1'
14
- });
15
- expect(baseResult.getLabel()).toEqual('chr1');
16
- expect(baseResult.getLocation()).toEqual('chr1');
17
- });
18
- test('create LocationResult', function () {
19
- var locationResult = new _BaseResults.default({
20
- label: 'location result',
21
- locString: 'chr1:1-900'
22
- });
23
- expect(locationResult.getLabel()).toEqual('location result');
24
- expect(locationResult.getLocation()).toEqual('chr1:1-900');
25
- });
26
- test('create RefSequenceResult', function () {
27
- var refSeqResult = new _BaseResults.RefSequenceResult({
28
- refName: 'chr1',
29
- label: 'chromosome 1'
30
- });
31
- expect(refSeqResult.getLabel()).toEqual('chromosome 1');
32
- expect(refSeqResult.getLocation()).toEqual('chr1');
33
- });
34
- test('can update score of result and throw appropriate errors', function () {
35
- var refSeqResult = new _BaseResults.RefSequenceResult({
36
- refName: 'chr1',
37
- label: 'chromosome 1'
38
- });
39
- expect(refSeqResult.getScore()).toBe(1);
40
- refSeqResult.updateScore(1000);
41
- expect(refSeqResult.getScore()).toBe(1000);
42
- });
@@ -1,266 +0,0 @@
1
- "use strict";
2
-
3
- var _mobxStateTree = require("mobx-state-tree");
4
-
5
- var _configurationSchema = require("./configurationSchema");
6
-
7
- var _util = require("./util");
8
-
9
- var _ = require(".");
10
-
11
- describe('configuration schemas', function () {
12
- test('can make a schema with a color', function () {
13
- var container = _mobxStateTree.types.model({
14
- configuration: (0, _configurationSchema.ConfigurationSchema)('Track', {
15
- backgroundColor: {
16
- description: "the track's background color",
17
- type: 'color',
18
- defaultValue: '#eee'
19
- },
20
- someInteger: {
21
- description: 'an integer slot',
22
- type: 'integer',
23
- defaultValue: 12
24
- }
25
- })
26
- });
27
-
28
- var model = container.create();
29
- expect((0, _util.isConfigurationModel)(model.configuration)).toBe(true);
30
- expect((0, _.getConf)(model, 'backgroundColor')).toBe('#eee');
31
- expect((0, _.getConf)(model, 'someInteger')).toBe(12);
32
- model.configuration.backgroundColor.set("jexl:'#'+a");
33
- expect((0, _.getConf)(model, 'backgroundColor', {
34
- a: 'zonk'
35
- })).toBe('#zonk');
36
- expect((0, _.getConf)(model, 'backgroundColor', {
37
- a: 'bar'
38
- })).toBe('#bar');
39
- model.configuration.backgroundColor.set('hoog');
40
- expect((0, _.getConf)(model, 'backgroundColor', {
41
- a: 'zonk'
42
- })).toBe('hoog');
43
- model.configuration.someInteger.set('jexl:5+a');
44
- expect((0, _.getConf)(model, 'someInteger', {
45
- a: 5
46
- })).toBe(10);
47
- model.configuration.someInteger.set(42);
48
- expect((0, _.getConf)(model, 'someInteger', {
49
- a: 5
50
- })).toBe(42);
51
- });
52
- test('can nest an array of configuration schemas', function () {
53
- var container = _mobxStateTree.types.model({
54
- configuration: (0, _configurationSchema.ConfigurationSchema)('Foo', {
55
- someInteger: {
56
- description: 'an integer slot',
57
- type: 'integer',
58
- defaultValue: 12
59
- },
60
- myArrayOfSubConfigurations: _mobxStateTree.types.array((0, _configurationSchema.ConfigurationSchema)('SubObject', {
61
- someNumber: {
62
- description: 'some number in a subconfiguration',
63
- type: 'number',
64
- defaultValue: 4.3
65
- }
66
- }))
67
- })
68
- });
69
-
70
- var model = container.create();
71
- expect((0, _.getConf)(model, 'someInteger')).toBe(12); // expect(getConf(model, 'myArrayOfSubConfigurations')).toBe(undefined)
72
- });
73
- test('can nest a single subconfiguration schema', function () {
74
- var container = _mobxStateTree.types.model({
75
- configuration: (0, _configurationSchema.ConfigurationSchema)('Foo', {
76
- someInteger: {
77
- description: 'an integer slot',
78
- type: 'integer',
79
- defaultValue: 12
80
- },
81
- mySubConfiguration: (0, _configurationSchema.ConfigurationSchema)('SubObject', {
82
- someNumber: {
83
- description: 'some number in a subconfiguration',
84
- type: 'number',
85
- defaultValue: 4.3
86
- }
87
- })
88
- })
89
- });
90
-
91
- var model = container.create();
92
- expect((0, _util.isConfigurationModel)(model.configuration)).toBe(true);
93
- expect((0, _.getConf)(model, 'someInteger')).toBe(12); // expect(getConf(model, 'mySubConfiguration.someNumber')).toBe(4.3)
94
- });
95
- test('can snapshot a simple schema', function () {
96
- var container = _mobxStateTree.types.model({
97
- configuration: (0, _configurationSchema.ConfigurationSchema)('Foo', {
98
- someInteger: {
99
- description: 'an integer slot',
100
- type: 'integer',
101
- defaultValue: 12
102
- }
103
- })
104
- });
105
-
106
- var model = container.create({
107
- configuration: {
108
- someInteger: 42
109
- }
110
- });
111
- expect((0, _.getConf)(model, 'someInteger')).toEqual(42);
112
- expect((0, _mobxStateTree.getSnapshot)(model)).toEqual({
113
- configuration: {
114
- someInteger: 42
115
- }
116
- });
117
- expect((0, _.getConf)(model, 'someInteger')).toEqual(42);
118
- var model2 = container.create({
119
- configuration: {}
120
- });
121
- expect((0, _mobxStateTree.getSnapshot)(model2)).toEqual({
122
- configuration: {}
123
- });
124
- expect((0, _.getConf)(model2, 'someInteger')).toEqual(12);
125
- });
126
- test('can snapshot a nested schema 1', function () {
127
- var container = _mobxStateTree.types.model({
128
- configuration: (0, _configurationSchema.ConfigurationSchema)('Foo', {
129
- someInteger: {
130
- description: 'an integer slot',
131
- type: 'integer',
132
- defaultValue: 12
133
- },
134
- mySubConfiguration: (0, _configurationSchema.ConfigurationSchema)('SubObject1', {
135
- someNumber: {
136
- description: 'some number in a subconfiguration',
137
- type: 'number',
138
- defaultValue: 4.3
139
- }
140
- }),
141
- myArrayOfSubConfigurations: _mobxStateTree.types.array((0, _configurationSchema.ConfigurationSchema)('SubObject2', {
142
- someNumber: {
143
- description: 'some number in a subconfiguration',
144
- type: 'number',
145
- defaultValue: 3.5
146
- }
147
- }))
148
- })
149
- });
150
-
151
- var model = container.create({
152
- configuration: {
153
- someInteger: 42,
154
- mySubConfiguration: {},
155
- myArrayOfSubConfigurations: [{
156
- someNumber: 3.5
157
- }, {
158
- someNumber: 11.1
159
- }]
160
- }
161
- });
162
- expect((0, _mobxStateTree.getSnapshot)(model)).toEqual({
163
- configuration: {
164
- someInteger: 42,
165
- // mySubConfiguration is set to the default, so doesn't appear in snapshot
166
- myArrayOfSubConfigurations: [{}, {
167
- someNumber: 11.1
168
- }]
169
- }
170
- });
171
- });
172
- test('can snapshot a nested schema 2', function () {
173
- var container = _mobxStateTree.types.model({
174
- configuration: (0, _configurationSchema.ConfigurationSchema)('Foo', {
175
- someInteger: {
176
- description: 'an integer slot',
177
- type: 'integer',
178
- defaultValue: 12
179
- },
180
- myConfigurationMap: _mobxStateTree.types.map((0, _configurationSchema.ConfigurationSchema)('MappedConfiguration', {
181
- mappedValue: {
182
- description: 'something in a mapped configuration',
183
- type: 'number',
184
- defaultValue: 101
185
- }
186
- })),
187
- mySubConfiguration: (0, _configurationSchema.ConfigurationSchema)('SubObject1', {
188
- someNumber: {
189
- description: 'some number in a subconfiguration',
190
- type: 'number',
191
- defaultValue: 4.3
192
- }
193
- }),
194
- myArrayOfSubConfigurations: _mobxStateTree.types.array((0, _configurationSchema.ConfigurationSchema)('SubObject2', {
195
- someNumber: {
196
- description: 'some number in a subconfiguration',
197
- type: 'number',
198
- defaultValue: 3.5
199
- }
200
- }))
201
- })
202
- });
203
-
204
- var model = container.create({
205
- configuration: {
206
- someInteger: 12,
207
- myConfigurationMap: {
208
- nog: {}
209
- },
210
- mySubConfiguration: {
211
- someNumber: 12
212
- }
213
- }
214
- });
215
- expect((0, _mobxStateTree.getSnapshot)(model)).toEqual({
216
- configuration: {
217
- myConfigurationMap: {
218
- nog: {}
219
- },
220
- mySubConfiguration: {
221
- someNumber: 12
222
- }
223
- }
224
- });
225
- expect((0, _.getConf)(model, ['mySubConfiguration', 'someNumber'])).toEqual(12);
226
- });
227
- test('re-check instantiation of slots (issue #797)', function () {
228
- var configSchema = (0, _configurationSchema.ConfigurationSchema)('Gff3TabixAdapter', {
229
- gffGzLocation: {
230
- type: 'fileLocation',
231
- defaultValue: {
232
- uri: '/path/to/my.gff.gz',
233
- locationType: 'UriLocation'
234
- }
235
- },
236
- index: (0, _configurationSchema.ConfigurationSchema)('Gff3TabixIndex', {
237
- indexType: {
238
- model: _mobxStateTree.types.enumeration('IndexType', ['TBI', 'CSI']),
239
- type: 'stringEnum',
240
- defaultValue: 'TBI'
241
- },
242
- location: {
243
- type: 'fileLocation',
244
- defaultValue: {
245
- uri: '/path/to/my.gff.gz.tbi',
246
- locationType: 'UriLocation'
247
- }
248
- }
249
- }),
250
- dontRedispatch: {
251
- type: 'stringArray',
252
- defaultValue: ['chromosome', 'region']
253
- },
254
- thisShouldGetInstantiated: {
255
- type: 'string',
256
- defaultValue: 'Not instantiated'
257
- }
258
- }, {
259
- explicitlyTyped: true
260
- });
261
- var tester = configSchema.create();
262
- expect((0, _.readConfObject)(tester, 'dontRedispatch')[0]).toBe('chromosome');
263
- expect((0, _.readConfObject)(tester, 'thisShouldGetInstantiated')).toBe('Not instantiated');
264
- expect((0, _.readConfObject)(tester, ['index', 'indexType'])).toBe('TBI');
265
- });
266
- });