@jbrowse/core 2.4.2 → 2.6.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 (223) hide show
  1. package/BaseFeatureWidget/BaseFeatureDetail/ArrayValue.d.ts +16 -0
  2. package/BaseFeatureWidget/BaseFeatureDetail/ArrayValue.js +45 -0
  3. package/BaseFeatureWidget/BaseFeatureDetail/Attributes.d.ts +15 -0
  4. package/BaseFeatureWidget/BaseFeatureDetail/Attributes.js +52 -0
  5. package/BaseFeatureWidget/BaseFeatureDetail/BasicValue.d.ts +13 -0
  6. package/BaseFeatureWidget/BaseFeatureDetail/BasicValue.js +27 -0
  7. package/BaseFeatureWidget/BaseFeatureDetail/DataGridDetails.d.ts +15 -0
  8. package/BaseFeatureWidget/BaseFeatureDetail/DataGridDetails.js +98 -0
  9. package/BaseFeatureWidget/BaseFeatureDetail/FieldName.d.ts +16 -0
  10. package/BaseFeatureWidget/BaseFeatureDetail/FieldName.js +32 -0
  11. package/BaseFeatureWidget/BaseFeatureDetail/SimpleField.d.ts +17 -0
  12. package/BaseFeatureWidget/BaseFeatureDetail/SimpleField.js +23 -0
  13. package/BaseFeatureWidget/BaseFeatureDetail/UriField.d.ts +18 -0
  14. package/BaseFeatureWidget/BaseFeatureDetail/UriField.js +31 -0
  15. package/BaseFeatureWidget/BaseFeatureDetail/UriLink.d.ts +7 -0
  16. package/BaseFeatureWidget/BaseFeatureDetail/UriLink.js +13 -0
  17. package/BaseFeatureWidget/BaseFeatureDetail/index.d.ts +33 -0
  18. package/BaseFeatureWidget/BaseFeatureDetail/index.js +170 -0
  19. package/BaseFeatureWidget/BaseFeatureDetail/util.d.ts +5 -0
  20. package/BaseFeatureWidget/BaseFeatureDetail/util.js +46 -0
  21. package/BaseFeatureWidget/SequenceFeatureDetails/CDNASequence.d.ts +13 -0
  22. package/BaseFeatureWidget/SequenceFeatureDetails/CDNASequence.js +25 -0
  23. package/BaseFeatureWidget/SequenceFeatureDetails/CDSSequence.d.ts +6 -0
  24. package/BaseFeatureWidget/SequenceFeatureDetails/CDSSequence.js +12 -0
  25. package/BaseFeatureWidget/SequenceFeatureDetails/GenomicSequence.d.ts +6 -0
  26. package/BaseFeatureWidget/SequenceFeatureDetails/GenomicSequence.js +14 -0
  27. package/BaseFeatureWidget/SequenceFeatureDetails/ProteinSequence.d.ts +9 -0
  28. package/BaseFeatureWidget/SequenceFeatureDetails/ProteinSequence.js +18 -0
  29. package/BaseFeatureWidget/SequenceFeatureDetails/SequenceFeatureDetails.d.ts +3 -0
  30. package/BaseFeatureWidget/SequenceFeatureDetails/SequenceFeatureDetails.js +143 -0
  31. package/BaseFeatureWidget/{SequenceFeatureSettingsDialog.d.ts → SequenceFeatureDetails/SequenceFeatureSettingsDialog.d.ts} +2 -2
  32. package/BaseFeatureWidget/{SequenceFeatureSettingsDialog.js → SequenceFeatureDetails/SequenceFeatureSettingsDialog.js} +1 -1
  33. package/BaseFeatureWidget/{SequenceHelpDialog.d.ts → SequenceFeatureDetails/SequenceHelpDialog.d.ts} +2 -2
  34. package/BaseFeatureWidget/{SequenceHelpDialog.js → SequenceFeatureDetails/SequenceHelpDialog.js} +6 -9
  35. package/BaseFeatureWidget/{SequencePanel.d.ts → SequenceFeatureDetails/SequencePanel.d.ts} +1 -1
  36. package/BaseFeatureWidget/{SequencePanel.js → SequenceFeatureDetails/SequencePanel.js} +10 -8
  37. package/BaseFeatureWidget/SequenceFeatureDetails/hooks.d.ts +10 -0
  38. package/BaseFeatureWidget/SequenceFeatureDetails/hooks.js +73 -0
  39. package/BaseFeatureWidget/SequenceFeatureDetails/index.d.ts +3 -0
  40. package/BaseFeatureWidget/SequenceFeatureDetails/index.js +68 -0
  41. package/BaseFeatureWidget/{test_data → SequenceFeatureDetails/test_data}/DLGAP3.d.ts +17 -17
  42. package/BaseFeatureWidget/{test_data → SequenceFeatureDetails/test_data}/NCDN.d.ts +16 -16
  43. package/BaseFeatureWidget/SequenceFeatureDetails/util.d.ts +6 -0
  44. package/BaseFeatureWidget/SequenceFeatureDetails/util.js +11 -0
  45. package/BaseFeatureWidget/index.d.ts +4 -1
  46. package/BaseFeatureWidget/index.js +29 -17
  47. package/BaseFeatureWidget/types.d.ts +2 -2
  48. package/BaseFeatureWidget/util.js +15 -5
  49. package/Plugin.d.ts +1 -1
  50. package/PluginLoader.js +17 -0
  51. package/PluginManager.d.ts +8 -5
  52. package/PluginManager.js +3 -0
  53. package/README.md +0 -2
  54. package/ReExports/list.js +1 -0
  55. package/ReExports/modules.d.ts +8 -5
  56. package/ReExports/modules.js +7 -7
  57. package/TextSearch/TextSearchManager.d.ts +2 -9
  58. package/assemblyManager/assembly.d.ts +91 -8
  59. package/assemblyManager/assembly.js +92 -8
  60. package/assemblyManager/assemblyConfigSchema.d.ts +52 -1
  61. package/assemblyManager/assemblyConfigSchema.js +1 -0
  62. package/assemblyManager/assemblyManager.d.ts +227 -58
  63. package/assemblyManager/assemblyManager.js +72 -13
  64. package/assemblyManager/index.d.ts +1 -0
  65. package/configuration/configurationSchema.d.ts +14 -16
  66. package/configuration/configurationSchema.js +4 -2
  67. package/configuration/index.d.ts +1 -1
  68. package/configuration/types.d.ts +15 -0
  69. package/configuration/types.js +2 -0
  70. package/configuration/util.d.ts +5 -3
  71. package/configuration/util.js +18 -18
  72. package/data_adapters/BaseAdapter/BaseAdapter.d.ts +23 -0
  73. package/data_adapters/BaseAdapter/BaseAdapter.js +37 -0
  74. package/data_adapters/BaseAdapter/BaseFeatureDataAdapter.d.ts +128 -0
  75. package/data_adapters/{BaseAdapter.js → BaseAdapter/BaseFeatureDataAdapter.js} +58 -88
  76. package/data_adapters/BaseAdapter/BaseOptions.d.ts +16 -0
  77. package/data_adapters/BaseAdapter/BaseOptions.js +2 -0
  78. package/data_adapters/BaseAdapter/BaseRefNameAliasAdapter.d.ts +9 -0
  79. package/data_adapters/BaseAdapter/BaseRefNameAliasAdapter.js +2 -0
  80. package/data_adapters/BaseAdapter/BaseSequenceAdapter.d.ts +13 -0
  81. package/data_adapters/BaseAdapter/BaseSequenceAdapter.js +10 -0
  82. package/data_adapters/BaseAdapter/BaseTextSearchAdapter.d.ts +6 -0
  83. package/data_adapters/BaseAdapter/BaseTextSearchAdapter.js +2 -0
  84. package/data_adapters/BaseAdapter/RegionsAdapter.d.ts +6 -0
  85. package/data_adapters/BaseAdapter/RegionsAdapter.js +2 -0
  86. package/data_adapters/BaseAdapter/index.d.ts +15 -0
  87. package/data_adapters/BaseAdapter/index.js +25 -0
  88. package/data_adapters/BaseAdapter/types.d.ts +21 -0
  89. package/data_adapters/BaseAdapter/types.js +2 -0
  90. package/data_adapters/BaseAdapter/util.d.ts +12 -0
  91. package/data_adapters/BaseAdapter/util.js +23 -0
  92. package/data_adapters/CytobandAdapter/configSchema.d.ts +11 -1
  93. package/package.json +4 -4
  94. package/pluggableElementTypes/AdapterType.d.ts +1 -1
  95. package/pluggableElementTypes/ConnectionType.d.ts +1 -1
  96. package/pluggableElementTypes/DisplayType.d.ts +1 -1
  97. package/pluggableElementTypes/InternetAccountType.d.ts +1 -1
  98. package/pluggableElementTypes/RpcMethodType.d.ts +9 -7
  99. package/pluggableElementTypes/RpcMethodType.js +9 -7
  100. package/pluggableElementTypes/TextSearchAdapterType.d.ts +1 -1
  101. package/pluggableElementTypes/models/BaseConnectionModelFactory.d.ts +18 -0
  102. package/pluggableElementTypes/models/BaseConnectionModelFactory.js +9 -0
  103. package/pluggableElementTypes/models/BaseDisplayModel.d.ts +10 -1
  104. package/pluggableElementTypes/models/BaseDisplayModel.js +9 -1
  105. package/pluggableElementTypes/models/BaseTrackModel.d.ts +2 -1
  106. package/pluggableElementTypes/models/BaseTrackModel.js +4 -2
  107. package/pluggableElementTypes/models/BaseViewModel.d.ts +46 -2
  108. package/pluggableElementTypes/models/BaseViewModel.js +6 -0
  109. package/pluggableElementTypes/models/InternetAccountModel.d.ts +36 -2
  110. package/pluggableElementTypes/models/InternetAccountModel.js +33 -21
  111. package/pluggableElementTypes/models/baseConnectionConfig.d.ts +22 -2
  112. package/pluggableElementTypes/models/baseConnectionConfig.js +2 -1
  113. package/pluggableElementTypes/models/baseInternetAccountConfig.d.ts +42 -1
  114. package/pluggableElementTypes/models/baseInternetAccountConfig.js +1 -1
  115. package/pluggableElementTypes/models/baseTrackConfig.d.ts +120 -3
  116. package/pluggableElementTypes/models/baseTrackConfig.js +7 -5
  117. package/pluggableElementTypes/models/index.d.ts +1 -1
  118. package/pluggableElementTypes/renderers/BoxRendererType.js +1 -2
  119. package/pluggableElementTypes/renderers/CircularChordRendererType.d.ts +2 -2
  120. package/pluggableElementTypes/renderers/FeatureRendererType.d.ts +4 -2
  121. package/pluggableElementTypes/renderers/FeatureRendererType.js +4 -6
  122. package/pluggableElementTypes/renderers/RendererType.d.ts +1 -1
  123. package/pluggableElementTypes/renderers/RpcRenderedSvgGroup.d.ts +2 -2
  124. package/pluggableElementTypes/renderers/ServerSideRenderedContent.d.ts +1 -1
  125. package/pluggableElementTypes/renderers/ServerSideRendererType.d.ts +1 -1
  126. package/rpc/BaseRpcDriver.js +1 -7
  127. package/rpc/RpcManager.d.ts +8 -1
  128. package/rpc/RpcManager.js +1 -1
  129. package/rpc/baseRpcConfig.d.ts +10 -1
  130. package/rpc/configSchema.d.ts +14 -1
  131. package/rpc/coreRpcMethods.d.ts +1 -1
  132. package/rpc/coreRpcMethods.js +3 -3
  133. package/rpc/mainThreadRpcConfig.d.ts +7 -1
  134. package/rpc/methods/{CoreEstimateRegionStats.d.ts → CoreGetFeatureDensityStats.d.ts} +2 -2
  135. package/rpc/methods/{CoreEstimateRegionStats.js → CoreGetFeatureDensityStats.js} +4 -4
  136. package/rpc/methods/CoreGetFeatureDetails.js +5 -5
  137. package/rpc/webWorkerRpcConfig.d.ts +7 -1
  138. package/tsconfig.build.tsbuildinfo +1 -1
  139. package/ui/AppLogo.d.ts +2 -2
  140. package/ui/AssemblySelector.d.ts +2 -2
  141. package/ui/AssemblySelector.js +1 -1
  142. package/ui/CascadingMenu.d.ts +2 -2
  143. package/ui/CascadingMenuButton.d.ts +8 -0
  144. package/ui/CascadingMenuButton.js +20 -0
  145. package/ui/ColorPicker.d.ts +4 -4
  146. package/ui/Dialog.d.ts +5 -5
  147. package/ui/Dialog.js +19 -7
  148. package/ui/DropDownMenu.d.ts +2 -2
  149. package/ui/EditableTypography.js +1 -1
  150. package/ui/ErrorMessage.d.ts +2 -2
  151. package/ui/ErrorMessage.js +6 -2
  152. package/ui/FactoryResetDialog.d.ts +2 -2
  153. package/ui/FatalErrorDialog.d.ts +6 -7
  154. package/ui/FatalErrorDialog.js +7 -7
  155. package/ui/FileSelector/FileSelector.d.ts +2 -2
  156. package/ui/FileSelector/FileSelector.js +3 -2
  157. package/ui/FileSelector/LocalFileChooser.d.ts +2 -2
  158. package/ui/FileSelector/UrlChooser.d.ts +3 -4
  159. package/ui/FileSelector/UrlChooser.js +8 -10
  160. package/ui/Icons.d.ts +10 -10
  161. package/ui/LoadingEllipses.d.ts +2 -2
  162. package/ui/Logo.d.ts +3 -3
  163. package/ui/Menu.d.ts +2 -2
  164. package/ui/PrerenderedCanvas.d.ts +2 -2
  165. package/ui/ResizeBar.d.ts +1 -1
  166. package/ui/ResizeBar.js +1 -1
  167. package/ui/ResizeHandle.d.ts +2 -2
  168. package/ui/ReturnToImportFormDialog.d.ts +2 -2
  169. package/ui/SanitizedHTML.d.ts +2 -2
  170. package/ui/SanitizedHTML.js +6 -0
  171. package/ui/Snackbar.d.ts +7 -9
  172. package/ui/Snackbar.js +12 -17
  173. package/ui/SnackbarModel.d.ts +9 -3
  174. package/ui/SnackbarModel.js +3 -3
  175. package/ui/Tooltip.d.ts +2 -2
  176. package/ui/index.d.ts +0 -1
  177. package/ui/index.js +1 -3
  178. package/ui/react-colorful.d.ts +1 -1
  179. package/ui/theme.js +3 -18
  180. package/util/Base1DUtils.js +2 -1
  181. package/util/QuickLRU.d.ts +1 -1
  182. package/util/blockTypes.js +1 -1
  183. package/util/formatFastaStrings.js +1 -1
  184. package/util/index.d.ts +18 -2
  185. package/util/index.js +77 -11
  186. package/util/io/index.js +1 -1
  187. package/util/layouts/PrecomputedMultiLayout.d.ts +1 -1
  188. package/util/mst-reflection.js +1 -2
  189. package/util/offscreenCanvasUtils.d.ts +2 -2
  190. package/util/stats.d.ts +5 -5
  191. package/util/types/index.d.ts +9 -3
  192. package/util/types/index.js +6 -2
  193. package/util/types/mst.d.ts +12 -9
  194. package/util/types/util.d.ts +0 -3
  195. package/BaseFeatureWidget/BaseFeatureDetail.d.ts +0 -62
  196. package/BaseFeatureWidget/BaseFeatureDetail.js +0 -378
  197. package/BaseFeatureWidget/SequenceBox.d.ts +0 -29
  198. package/BaseFeatureWidget/SequenceBox.js +0 -63
  199. package/BaseFeatureWidget/SequenceFeatureDetails.d.ts +0 -3
  200. package/BaseFeatureWidget/SequenceFeatureDetails.js +0 -230
  201. package/data_adapters/BaseAdapter.d.ts +0 -138
  202. package/ui/AboutDialog.d.ts +0 -12
  203. package/ui/AboutDialog.js +0 -125
  204. package/ui/App.d.ts +0 -18
  205. package/ui/App.js +0 -114
  206. package/ui/AppToolbar.d.ts +0 -19
  207. package/ui/AppToolbar.js +0 -56
  208. package/ui/Drawer.d.ts +0 -8
  209. package/ui/Drawer.js +0 -34
  210. package/ui/DrawerWidget.d.ts +0 -6
  211. package/ui/DrawerWidget.js +0 -130
  212. package/ui/ViewContainer.d.ts +0 -9
  213. package/ui/ViewContainer.js +0 -76
  214. package/ui/ViewContainerTitle.d.ts +0 -6
  215. package/ui/ViewContainerTitle.js +0 -42
  216. package/ui/ViewLauncher.d.ts +0 -18
  217. package/ui/ViewLauncher.js +0 -50
  218. package/ui/ViewMenu.d.ts +0 -9
  219. package/ui/ViewMenu.js +0 -69
  220. package/ui/ViewPanel.d.ts +0 -19
  221. package/ui/ViewPanel.js +0 -49
  222. /package/BaseFeatureWidget/{test_data → SequenceFeatureDetails/test_data}/DLGAP3.js +0 -0
  223. /package/BaseFeatureWidget/{test_data → SequenceFeatureDetails/test_data}/NCDN.js +0 -0
@@ -1,378 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- var __importDefault = (this && this.__importDefault) || function (mod) {
26
- return (mod && mod.__esModule) ? mod : { "default": mod };
27
- };
28
- Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.FeatureDetails = exports.BaseAttributes = exports.Attributes = exports.UriLink = exports.BaseCoreDetails = exports.SimpleValue = exports.BasicValue = exports.FieldName = exports.BaseCard = exports.useStyles = void 0;
30
- /* eslint-disable @typescript-eslint/no-explicit-any */
31
- const react_1 = __importStar(require("react"));
32
- const react_error_boundary_1 = require("react-error-boundary");
33
- const material_1 = require("@mui/material");
34
- const mui_1 = require("tss-react/mui");
35
- const x_data_grid_1 = require("@mui/x-data-grid");
36
- const mobx_react_1 = require("mobx-react");
37
- const is_object_1 = __importDefault(require("is-object"));
38
- // icons
39
- const ExpandMore_1 = __importDefault(require("@mui/icons-material/ExpandMore"));
40
- // locals
41
- const util_1 = require("../util");
42
- const ui_1 = require("../ui");
43
- const SequenceFeatureDetails_1 = __importDefault(require("./SequenceFeatureDetails"));
44
- const util_2 = require("./util");
45
- const MAX_FIELD_NAME_WIDTH = 170;
46
- // these are always omitted as too detailed
47
- const globalOmit = [
48
- '__jbrowsefmt',
49
- 'length',
50
- 'position',
51
- 'subfeatures',
52
- 'uniqueId',
53
- 'exonFrames',
54
- 'parentId',
55
- 'thickStart',
56
- 'thickEnd',
57
- ];
58
- // coreDetails are omitted in some circumstances
59
- const coreDetails = [
60
- 'name',
61
- 'start',
62
- 'end',
63
- 'strand',
64
- 'refName',
65
- 'description',
66
- 'type',
67
- ];
68
- exports.useStyles = (0, mui_1.makeStyles)()(theme => {
69
- var _a;
70
- return ({
71
- expansionPanelDetails: {
72
- display: 'block',
73
- padding: theme.spacing(1),
74
- },
75
- expandIcon: {
76
- color: ((_a = theme.palette.tertiary) === null || _a === void 0 ? void 0 : _a.contrastText) || '#fff',
77
- },
78
- field: {
79
- display: 'flex',
80
- flexWrap: 'wrap',
81
- },
82
- fieldDescription: {
83
- '&:hover': {
84
- background: theme.palette.mode === 'dark' ? '#e65100' : 'yellow',
85
- },
86
- },
87
- fieldName: {
88
- wordBreak: 'break-all',
89
- minWidth: 90,
90
- borderBottom: '1px solid #0003',
91
- fontSize: 12,
92
- background: theme.palette.action.disabledBackground,
93
- marginRight: theme.spacing(1),
94
- padding: theme.spacing(0.5),
95
- },
96
- fieldValue: {
97
- wordBreak: 'break-word',
98
- maxHeight: 300,
99
- fontSize: 12,
100
- padding: theme.spacing(0.5),
101
- overflow: 'auto',
102
- },
103
- fieldSubvalue: {
104
- wordBreak: 'break-word',
105
- maxHeight: 300,
106
- padding: theme.spacing(0.5),
107
- background: theme.palette.action.disabledBackground,
108
- border: `1px solid ${theme.palette.action.disabledBackground}`,
109
- boxSizing: 'border-box',
110
- overflow: 'auto',
111
- },
112
- });
113
- });
114
- function BaseCard({ children, title, defaultExpanded = true, }) {
115
- const { classes } = (0, exports.useStyles)();
116
- const [expanded, setExpanded] = (0, react_1.useState)(defaultExpanded);
117
- return (react_1.default.createElement(material_1.Accordion, { expanded: expanded, onChange: () => setExpanded(s => !s), TransitionProps: { unmountOnExit: true, timeout: 150 } },
118
- react_1.default.createElement(material_1.AccordionSummary, { expandIcon: react_1.default.createElement(ExpandMore_1.default, { className: classes.expandIcon }) },
119
- react_1.default.createElement(material_1.Typography, { variant: "button" },
120
- " ",
121
- title)),
122
- react_1.default.createElement(material_1.AccordionDetails, { className: classes.expansionPanelDetails }, children)));
123
- }
124
- exports.BaseCard = BaseCard;
125
- const FieldName = ({ description, name, width, prefix = [], }) => {
126
- const { classes, cx } = (0, exports.useStyles)();
127
- const val = [...prefix, name].join('.');
128
- return description ? (react_1.default.createElement(material_1.Tooltip, { title: description, placement: "left" },
129
- react_1.default.createElement("div", { className: cx(classes.fieldDescription, classes.fieldName) }, val))) : (react_1.default.createElement("div", { className: classes.fieldName, style: { width: width } }, val));
130
- };
131
- exports.FieldName = FieldName;
132
- const BasicValue = ({ value }) => {
133
- const { classes } = (0, exports.useStyles)();
134
- const isLink = `${value}`.match(/^https?:\/\//);
135
- return (react_1.default.createElement("div", { className: classes.fieldValue }, react_1.default.isValidElement(value) ? (value) : isLink ? (react_1.default.createElement(material_1.Link, { href: `${value}` }, `${value}`)) : (react_1.default.createElement(ui_1.SanitizedHTML, { html: (0, is_object_1.default)(value) ? JSON.stringify(value) : String(value) }))));
136
- };
137
- exports.BasicValue = BasicValue;
138
- function SimpleValue({ name, value, description, prefix, width, }) {
139
- const { classes } = (0, exports.useStyles)();
140
- return value !== null && value !== undefined ? (react_1.default.createElement("div", { className: classes.field },
141
- react_1.default.createElement(exports.FieldName, { prefix: prefix, description: description, name: name, width: width }),
142
- react_1.default.createElement(exports.BasicValue, { value: value }))) : null;
143
- }
144
- exports.SimpleValue = SimpleValue;
145
- function ArrayValue({ name, value, description, prefix = [], }) {
146
- const { classes } = (0, exports.useStyles)();
147
- if (value.length === 1) {
148
- return (0, is_object_1.default)(value[0]) ? (react_1.default.createElement(Attributes, { attributes: value[0], prefix: [...prefix, name] })) : (react_1.default.createElement("div", { className: classes.field },
149
- react_1.default.createElement(exports.FieldName, { prefix: prefix, description: description, name: name }),
150
- react_1.default.createElement(exports.BasicValue, { value: value[0] })));
151
- }
152
- else if (value.every(val => (0, is_object_1.default)(val))) {
153
- return (react_1.default.createElement(react_1.default.Fragment, null, value.map((val, i) => (react_1.default.createElement(Attributes, { key: JSON.stringify(val) + '-' + i, attributes: val, prefix: [...prefix, name + '-' + i] })))));
154
- }
155
- else {
156
- return (react_1.default.createElement("div", { className: classes.field },
157
- react_1.default.createElement(exports.FieldName, { prefix: prefix, description: description, name: name }),
158
- value.map((val, i) => (react_1.default.createElement("div", { key: JSON.stringify(val) + '-' + i, className: classes.fieldSubvalue },
159
- react_1.default.createElement(exports.BasicValue, { value: val }))))));
160
- }
161
- }
162
- const toLocale = (n) => n.toLocaleString('en-US');
163
- function Position(props) {
164
- const { feature } = props;
165
- const strand = feature.strand;
166
- const strandMap = {
167
- '-1': '-',
168
- '0': '',
169
- '1': '+',
170
- };
171
- const str = strandMap[strand] ? `(${strandMap[strand]})` : '';
172
- // @ts-expect-error
173
- const loc = (0, util_1.assembleLocString)(feature);
174
- return react_1.default.createElement(react_1.default.Fragment, null, `${loc} ${str}`);
175
- }
176
- function CoreDetails(props) {
177
- const { feature } = props;
178
- const obj = feature;
179
- // eslint-disable-next-line no-underscore-dangle
180
- const formattedFeat = { ...obj, ...obj.__jbrowsefmt };
181
- const { start, end } = formattedFeat;
182
- const displayedDetails = {
183
- ...formattedFeat,
184
- length: toLocale(end - start),
185
- };
186
- const coreRenderedDetails = {
187
- description: 'Description',
188
- name: 'Name',
189
- length: 'Length',
190
- type: 'Type',
191
- };
192
- return (react_1.default.createElement(react_1.default.Fragment, null,
193
- react_1.default.createElement(SimpleValue, { name: "Position", value: react_1.default.createElement(Position, { ...props, feature: formattedFeat }) }),
194
- Object.entries(coreRenderedDetails)
195
- .map(([key, name]) => [name, displayedDetails[key]])
196
- .filter(([, value]) => value != null)
197
- .map(([name, value]) => (react_1.default.createElement(SimpleValue, { key: name, name: name, value: value })))));
198
- }
199
- const BaseCoreDetails = (props) => {
200
- return (react_1.default.createElement(BaseCard, { ...props, title: "Primary data" },
201
- react_1.default.createElement(CoreDetails, { ...props })));
202
- };
203
- exports.BaseCoreDetails = BaseCoreDetails;
204
- function UriLink({ value, }) {
205
- const href = (0, util_1.getUriLink)(value);
206
- return react_1.default.createElement(ui_1.SanitizedHTML, { html: `<a href="${href}">${href}</a>` });
207
- }
208
- exports.UriLink = UriLink;
209
- function DataGridDetails({ value, prefix, name, }) {
210
- const keys = Object.keys(value[0]).sort();
211
- const unionKeys = new Set(keys);
212
- for (const val of value) {
213
- for (const k of Object.keys(val)) {
214
- unionKeys.add(k);
215
- }
216
- }
217
- if (unionKeys.size < keys.length + 5) {
218
- // avoids key 'id' from being used in row data
219
- const rows = Object.entries(value).map(([k, val]) => {
220
- const { id, ...rest } = val;
221
- return {
222
- id: k,
223
- identifier: id,
224
- ...rest,
225
- };
226
- });
227
- // avoids key 'id' from being used in column names, and tries
228
- // to make it at the start of the colNames array
229
- let colNames;
230
- if (unionKeys.has('id')) {
231
- unionKeys.delete('id');
232
- colNames = ['identifier', ...unionKeys];
233
- }
234
- else {
235
- colNames = [...unionKeys];
236
- }
237
- const columns = colNames.map(val => ({
238
- field: val,
239
- renderCell: (params) => {
240
- const { value } = params;
241
- return (0, util_1.isUriLocation)(value) ? react_1.default.createElement(UriLink, { value: value }) : (0, util_1.getStr)(value);
242
- },
243
- width: (0, util_1.measureGridWidth)(rows.map(r => r[val])),
244
- }));
245
- const rowHeight = 25;
246
- const hideFoot = rows.length < 100;
247
- const headHeight = 80;
248
- const height = Math.min(rows.length, 100) * rowHeight + headHeight + (hideFoot ? 0 : 50);
249
- // disableSelection on click helps avoid
250
- // https://github.com/mui-org/material-ui-x/issues/1197
251
- return (react_1.default.createElement(react_1.default.Fragment, null,
252
- react_1.default.createElement(exports.FieldName, { prefix: prefix, name: name }),
253
- react_1.default.createElement("div", { style: {
254
- height,
255
- width: '100%',
256
- } },
257
- react_1.default.createElement(x_data_grid_1.DataGrid, { disableSelectionOnClick: true, rowHeight: rowHeight, rows: rows, hideFooterSelectedRowCount: true, columns: columns, hideFooter: hideFoot }))));
258
- }
259
- return null;
260
- }
261
- // pick using a path from an object, similar to _.get from lodash with special logic
262
- // for Descriptions from e.g. VCF headers
263
- // @param arr example ['a','b'], obj = {a:{b:'hello}}
264
- // @returns hello (with special addition to grab description also)
265
- function accessNested(arr, obj = {}) {
266
- arr.forEach(elt => {
267
- if (obj) {
268
- obj = obj[elt];
269
- }
270
- });
271
- return typeof obj === 'string'
272
- ? obj
273
- : typeof (obj === null || obj === void 0 ? void 0 : obj.Description) === 'string'
274
- ? obj.Description
275
- : undefined;
276
- }
277
- function generateMaxWidth(array, prefix) {
278
- const arr = [];
279
- array.forEach(key => {
280
- const val = [...prefix, key[0]].join('.');
281
- arr.push((0, util_1.measureText)(val, 12));
282
- });
283
- return Math.ceil(Math.max(...arr)) + 10;
284
- }
285
- function UriAttribute({ value, prefix, name, }) {
286
- const { classes } = (0, exports.useStyles)();
287
- const { uri, baseUri = '' } = value;
288
- let href;
289
- try {
290
- href = new URL(uri, baseUri).href;
291
- }
292
- catch (e) {
293
- href = uri;
294
- }
295
- return (react_1.default.createElement("div", { className: classes.field },
296
- react_1.default.createElement(exports.FieldName, { prefix: prefix, name: name }),
297
- react_1.default.createElement(exports.BasicValue, { value: href })));
298
- }
299
- function Attributes(props) {
300
- const { attributes, omit = [], omitSingleLevel = [], descriptions, formatter = val => val, hideUris, prefix = [], } = props;
301
- const omits = new Set([...omit, ...globalOmit, ...omitSingleLevel]);
302
- const { __jbrowsefmt, ...rest } = attributes;
303
- const formattedAttributes = { ...rest, ...__jbrowsefmt };
304
- const maxLabelWidth = generateMaxWidth(Object.entries(formattedAttributes).filter(([k, v]) => v !== undefined && !omits.has(k)), prefix);
305
- return (react_1.default.createElement(react_1.default.Fragment, null, Object.entries(formattedAttributes)
306
- .filter(([k, v]) => v !== undefined && !omits.has(k))
307
- .map(([key, value]) => {
308
- const description = accessNested([...prefix, key], descriptions);
309
- if (Array.isArray(value)) {
310
- // check if it looks like an array of objects, which could be used
311
- // in data grid
312
- return value.length > 1 && value.every(val => (0, is_object_1.default)(val)) ? (react_1.default.createElement(DataGridDetails, { key: key, name: key, prefix: prefix, value: value })) : (react_1.default.createElement(ArrayValue, { key: key, name: key, value: value, description: description, prefix: prefix }));
313
- }
314
- else if ((0, is_object_1.default)(value)) {
315
- const { omitSingleLevel, ...rest } = props;
316
- return (0, util_1.isUriLocation)(value) ? (hideUris ? null : (react_1.default.createElement(UriAttribute, { key: key, name: key, prefix: prefix, value: value }))) : (react_1.default.createElement(Attributes, { ...rest, key: key, attributes: value, descriptions: descriptions, prefix: [...prefix, key] }));
317
- }
318
- else {
319
- return (react_1.default.createElement(SimpleValue, { key: key, name: key, value: formatter(value, key), description: description, prefix: prefix, width: Math.min(maxLabelWidth, MAX_FIELD_NAME_WIDTH) }));
320
- }
321
- })));
322
- }
323
- exports.Attributes = Attributes;
324
- const BaseAttributes = (props) => {
325
- const { feature } = props;
326
- return (react_1.default.createElement(BaseCard, { ...props, title: "Attributes" },
327
- react_1.default.createElement(Attributes, { ...props, attributes: feature })));
328
- };
329
- exports.BaseAttributes = BaseAttributes;
330
- function isEmpty(obj) {
331
- return Object.keys(obj).length === 0;
332
- }
333
- function generateTitle(name, id, type) {
334
- return [(0, util_2.ellipses)(`${name}` || `${id}`), `${type}`]
335
- .filter(f => !!f)
336
- .join(' - ');
337
- }
338
- function FeatureDetails(props) {
339
- const { omit = [], model, feature, depth = 0 } = props;
340
- const { mate, name = '', id = '', type = '', subfeatures } = feature;
341
- const pm = (0, util_1.getEnv)(model).pluginManager;
342
- const session = (0, util_1.getSession)(model);
343
- const ExtraPanel = pm.evaluateExtensionPoint('Core-extraFeaturePanel', null, {
344
- session,
345
- feature,
346
- model,
347
- });
348
- return (react_1.default.createElement(BaseCard, { title: generateTitle(name, id, type) },
349
- react_1.default.createElement(material_1.Typography, null, "Core details"),
350
- react_1.default.createElement(CoreDetails, { ...props }),
351
- mate ? (react_1.default.createElement(react_1.default.Fragment, null,
352
- react_1.default.createElement(material_1.Divider, null),
353
- react_1.default.createElement(material_1.Typography, null, "Mate details"),
354
- react_1.default.createElement(CoreDetails, { ...props, feature: mate }))) : null,
355
- react_1.default.createElement(material_1.Divider, null),
356
- react_1.default.createElement(material_1.Typography, null, "Attributes"),
357
- react_1.default.createElement(Attributes, { attributes: feature, ...props, omit: omit, omitSingleLevel: coreDetails }),
358
- react_1.default.createElement(react_error_boundary_1.ErrorBoundary, { FallbackComponent: ({ error }) => react_1.default.createElement(ui_1.ErrorMessage, { error: error }) },
359
- react_1.default.createElement(SequenceFeatureDetails_1.default, { ...props })),
360
- ExtraPanel ? (react_1.default.createElement(react_1.default.Fragment, null,
361
- react_1.default.createElement(material_1.Divider, null),
362
- react_1.default.createElement(BaseCard, { title: ExtraPanel.name },
363
- react_1.default.createElement(ExtraPanel.Component, { ...props })))) : null,
364
- (subfeatures === null || subfeatures === void 0 ? void 0 : subfeatures.length) ? (react_1.default.createElement(BaseCard, { title: "Subfeatures", defaultExpanded: depth < 1 }, subfeatures.map(sub => (react_1.default.createElement(FeatureDetails, { key: JSON.stringify(sub), feature: sub, model: model, depth: depth + 1 }))))) : null));
365
- }
366
- exports.FeatureDetails = FeatureDetails;
367
- exports.default = (0, mobx_react_1.observer)(function ({ model }) {
368
- const { featureData } = model;
369
- if (!featureData) {
370
- return null;
371
- }
372
- // replacing undefined with null helps with allowing fields to be hidden,
373
- // setting null is not allowed by jexl so we set it to undefined to hide. see
374
- // config guide. this replacement happens both here and when snapshotting the
375
- // featureData
376
- const g = JSON.parse(JSON.stringify(featureData, (_, v) => (v === undefined ? null : v)));
377
- return isEmpty(g) ? null : react_1.default.createElement(FeatureDetails, { model: model, feature: g });
378
- });
@@ -1,29 +0,0 @@
1
- /// <reference types="react" />
2
- import { Feat } from './util';
3
- export declare function GeneCDS({ cds, sequence }: {
4
- cds: Feat[];
5
- sequence: string;
6
- }): JSX.Element;
7
- export declare function GeneProtein({ cds, sequence, codonTable, }: {
8
- cds: Feat[];
9
- sequence: string;
10
- codonTable: {
11
- [key: string]: string;
12
- };
13
- }): JSX.Element;
14
- export declare function GenecDNA({ utr, cds, exons, sequence, upstream, downstream, includeIntrons, collapseIntron, intronBp, }: {
15
- utr: Feat[];
16
- cds: Feat[];
17
- exons: Feat[];
18
- sequence: string;
19
- upstream?: string;
20
- downstream?: string;
21
- includeIntrons?: boolean;
22
- collapseIntron?: boolean;
23
- intronBp: number;
24
- }): JSX.Element;
25
- export declare function Genomic({ sequence, upstream, downstream, }: {
26
- sequence: string;
27
- upstream?: string;
28
- downstream?: string;
29
- }): JSX.Element;
@@ -1,63 +0,0 @@
1
- "use strict";
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.Genomic = exports.GenecDNA = exports.GeneProtein = exports.GeneCDS = void 0;
7
- const react_1 = __importDefault(require("react"));
8
- const util_1 = require("./util");
9
- // note that these are currently put into the style section instead of being
10
- // defined in classes to aid copy and paste to an external document e.g. word
11
- const proteinColor = 'rgb(220,160,220)';
12
- const intronColor = undefined;
13
- const cdsColor = 'rgb(220,220,180)';
14
- const updownstreamColor = 'rgba(250,200,200)';
15
- const utrColor = 'rgb(200,240,240)';
16
- const genomeColor = 'rgb(200,280,200)';
17
- function GeneCDS({ cds, sequence }) {
18
- return react_1.default.createElement("span", { style: { background: cdsColor } }, (0, util_1.stitch)(cds, sequence));
19
- }
20
- exports.GeneCDS = GeneCDS;
21
- function GeneProtein({ cds, sequence, codonTable, }) {
22
- const str = (0, util_1.stitch)(cds, sequence);
23
- let protein = '';
24
- for (let i = 0; i < str.length; i += 3) {
25
- // use & symbol for undefined codon, or partial slice
26
- protein += codonTable[str.slice(i, i + 3)] || '&';
27
- }
28
- return react_1.default.createElement("span", { style: { background: proteinColor } }, protein);
29
- }
30
- exports.GeneProtein = GeneProtein;
31
- function GenecDNA({ utr, cds, exons, sequence, upstream, downstream, includeIntrons, collapseIntron, intronBp, }) {
32
- const chunks = (cds.length ? [...cds, ...utr].sort((a, b) => a.start - b.start) : exons).filter(f => f.start !== f.end);
33
- return (react_1.default.createElement(react_1.default.Fragment, null,
34
- upstream ? (react_1.default.createElement("span", { style: {
35
- background: updownstreamColor,
36
- } }, upstream)) : null,
37
- chunks.map((chunk, idx) => {
38
- var _a;
39
- const intron = sequence.slice(chunk.end, (_a = chunks[idx + 1]) === null || _a === void 0 ? void 0 : _a.start);
40
- return (react_1.default.createElement(react_1.default.Fragment, { key: JSON.stringify(chunk) },
41
- react_1.default.createElement("span", { style: {
42
- background: chunk.type === 'CDS' ? cdsColor : utrColor,
43
- } }, sequence.slice(chunk.start, chunk.end)),
44
- includeIntrons && idx < chunks.length - 1 ? (react_1.default.createElement("span", { style: { background: intronColor } }, collapseIntron && intron.length > intronBp * 2
45
- ? `${intron.slice(0, intronBp)}...${intron.slice(-intronBp)}`
46
- : intron)) : null));
47
- }),
48
- downstream ? (react_1.default.createElement("span", { style: { background: updownstreamColor } }, downstream)) : null));
49
- }
50
- exports.GenecDNA = GenecDNA;
51
- function Genomic({ sequence, upstream, downstream, }) {
52
- return (react_1.default.createElement(react_1.default.Fragment, null,
53
- upstream ? (react_1.default.createElement("span", { style: {
54
- background: updownstreamColor,
55
- } }, upstream)) : null,
56
- react_1.default.createElement("span", { style: {
57
- background: genomeColor,
58
- } }, sequence),
59
- downstream ? (react_1.default.createElement("span", { style: {
60
- background: updownstreamColor,
61
- } }, downstream)) : null));
62
- }
63
- exports.Genomic = Genomic;
@@ -1,3 +0,0 @@
1
- /// <reference types="react" />
2
- import { BaseProps } from './types';
3
- export default function SequenceFeatureDetails({ model, feature }: BaseProps): JSX.Element | null;