@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.
- package/BaseFeatureWidget/BaseFeatureDetail/ArrayValue.d.ts +16 -0
- package/BaseFeatureWidget/BaseFeatureDetail/ArrayValue.js +45 -0
- package/BaseFeatureWidget/BaseFeatureDetail/Attributes.d.ts +15 -0
- package/BaseFeatureWidget/BaseFeatureDetail/Attributes.js +52 -0
- package/BaseFeatureWidget/BaseFeatureDetail/BasicValue.d.ts +13 -0
- package/BaseFeatureWidget/BaseFeatureDetail/BasicValue.js +27 -0
- package/BaseFeatureWidget/BaseFeatureDetail/DataGridDetails.d.ts +15 -0
- package/BaseFeatureWidget/BaseFeatureDetail/DataGridDetails.js +98 -0
- package/BaseFeatureWidget/BaseFeatureDetail/FieldName.d.ts +16 -0
- package/BaseFeatureWidget/BaseFeatureDetail/FieldName.js +32 -0
- package/BaseFeatureWidget/BaseFeatureDetail/SimpleField.d.ts +17 -0
- package/BaseFeatureWidget/BaseFeatureDetail/SimpleField.js +23 -0
- package/BaseFeatureWidget/BaseFeatureDetail/UriField.d.ts +18 -0
- package/BaseFeatureWidget/BaseFeatureDetail/UriField.js +31 -0
- package/BaseFeatureWidget/BaseFeatureDetail/UriLink.d.ts +7 -0
- package/BaseFeatureWidget/BaseFeatureDetail/UriLink.js +13 -0
- package/BaseFeatureWidget/BaseFeatureDetail/index.d.ts +33 -0
- package/BaseFeatureWidget/BaseFeatureDetail/index.js +170 -0
- package/BaseFeatureWidget/BaseFeatureDetail/util.d.ts +5 -0
- package/BaseFeatureWidget/BaseFeatureDetail/util.js +46 -0
- package/BaseFeatureWidget/SequenceFeatureDetails/CDNASequence.d.ts +13 -0
- package/BaseFeatureWidget/SequenceFeatureDetails/CDNASequence.js +25 -0
- package/BaseFeatureWidget/SequenceFeatureDetails/CDSSequence.d.ts +6 -0
- package/BaseFeatureWidget/SequenceFeatureDetails/CDSSequence.js +12 -0
- package/BaseFeatureWidget/SequenceFeatureDetails/GenomicSequence.d.ts +6 -0
- package/BaseFeatureWidget/SequenceFeatureDetails/GenomicSequence.js +14 -0
- package/BaseFeatureWidget/SequenceFeatureDetails/ProteinSequence.d.ts +9 -0
- package/BaseFeatureWidget/SequenceFeatureDetails/ProteinSequence.js +18 -0
- package/BaseFeatureWidget/SequenceFeatureDetails/SequenceFeatureDetails.d.ts +3 -0
- package/BaseFeatureWidget/SequenceFeatureDetails/SequenceFeatureDetails.js +143 -0
- package/BaseFeatureWidget/{SequenceFeatureSettingsDialog.d.ts → SequenceFeatureDetails/SequenceFeatureSettingsDialog.d.ts} +2 -2
- package/BaseFeatureWidget/{SequenceFeatureSettingsDialog.js → SequenceFeatureDetails/SequenceFeatureSettingsDialog.js} +1 -1
- package/BaseFeatureWidget/{SequenceHelpDialog.d.ts → SequenceFeatureDetails/SequenceHelpDialog.d.ts} +2 -2
- package/BaseFeatureWidget/{SequenceHelpDialog.js → SequenceFeatureDetails/SequenceHelpDialog.js} +6 -9
- package/BaseFeatureWidget/{SequencePanel.d.ts → SequenceFeatureDetails/SequencePanel.d.ts} +1 -1
- package/BaseFeatureWidget/{SequencePanel.js → SequenceFeatureDetails/SequencePanel.js} +10 -8
- package/BaseFeatureWidget/SequenceFeatureDetails/hooks.d.ts +10 -0
- package/BaseFeatureWidget/SequenceFeatureDetails/hooks.js +73 -0
- package/BaseFeatureWidget/SequenceFeatureDetails/index.d.ts +3 -0
- package/BaseFeatureWidget/SequenceFeatureDetails/index.js +68 -0
- package/BaseFeatureWidget/{test_data → SequenceFeatureDetails/test_data}/DLGAP3.d.ts +17 -17
- package/BaseFeatureWidget/{test_data → SequenceFeatureDetails/test_data}/NCDN.d.ts +16 -16
- package/BaseFeatureWidget/SequenceFeatureDetails/util.d.ts +6 -0
- package/BaseFeatureWidget/SequenceFeatureDetails/util.js +11 -0
- package/BaseFeatureWidget/index.d.ts +4 -1
- package/BaseFeatureWidget/index.js +29 -17
- package/BaseFeatureWidget/types.d.ts +2 -2
- package/BaseFeatureWidget/util.js +15 -5
- package/Plugin.d.ts +1 -1
- package/PluginLoader.js +17 -0
- package/PluginManager.d.ts +8 -5
- package/PluginManager.js +3 -0
- package/README.md +0 -2
- package/ReExports/list.js +1 -0
- package/ReExports/modules.d.ts +8 -5
- package/ReExports/modules.js +7 -7
- package/TextSearch/TextSearchManager.d.ts +2 -9
- package/assemblyManager/assembly.d.ts +91 -8
- package/assemblyManager/assembly.js +92 -8
- package/assemblyManager/assemblyConfigSchema.d.ts +52 -1
- package/assemblyManager/assemblyConfigSchema.js +1 -0
- package/assemblyManager/assemblyManager.d.ts +227 -58
- package/assemblyManager/assemblyManager.js +72 -13
- package/assemblyManager/index.d.ts +1 -0
- package/configuration/configurationSchema.d.ts +14 -16
- package/configuration/configurationSchema.js +4 -2
- package/configuration/index.d.ts +1 -1
- package/configuration/types.d.ts +15 -0
- package/configuration/types.js +2 -0
- package/configuration/util.d.ts +5 -3
- package/configuration/util.js +18 -18
- package/data_adapters/BaseAdapter/BaseAdapter.d.ts +23 -0
- package/data_adapters/BaseAdapter/BaseAdapter.js +37 -0
- package/data_adapters/BaseAdapter/BaseFeatureDataAdapter.d.ts +128 -0
- package/data_adapters/{BaseAdapter.js → BaseAdapter/BaseFeatureDataAdapter.js} +58 -88
- package/data_adapters/BaseAdapter/BaseOptions.d.ts +16 -0
- package/data_adapters/BaseAdapter/BaseOptions.js +2 -0
- package/data_adapters/BaseAdapter/BaseRefNameAliasAdapter.d.ts +9 -0
- package/data_adapters/BaseAdapter/BaseRefNameAliasAdapter.js +2 -0
- package/data_adapters/BaseAdapter/BaseSequenceAdapter.d.ts +13 -0
- package/data_adapters/BaseAdapter/BaseSequenceAdapter.js +10 -0
- package/data_adapters/BaseAdapter/BaseTextSearchAdapter.d.ts +6 -0
- package/data_adapters/BaseAdapter/BaseTextSearchAdapter.js +2 -0
- package/data_adapters/BaseAdapter/RegionsAdapter.d.ts +6 -0
- package/data_adapters/BaseAdapter/RegionsAdapter.js +2 -0
- package/data_adapters/BaseAdapter/index.d.ts +15 -0
- package/data_adapters/BaseAdapter/index.js +25 -0
- package/data_adapters/BaseAdapter/types.d.ts +21 -0
- package/data_adapters/BaseAdapter/types.js +2 -0
- package/data_adapters/BaseAdapter/util.d.ts +12 -0
- package/data_adapters/BaseAdapter/util.js +23 -0
- package/data_adapters/CytobandAdapter/configSchema.d.ts +11 -1
- package/package.json +4 -4
- package/pluggableElementTypes/AdapterType.d.ts +1 -1
- package/pluggableElementTypes/ConnectionType.d.ts +1 -1
- package/pluggableElementTypes/DisplayType.d.ts +1 -1
- package/pluggableElementTypes/InternetAccountType.d.ts +1 -1
- package/pluggableElementTypes/RpcMethodType.d.ts +9 -7
- package/pluggableElementTypes/RpcMethodType.js +9 -7
- package/pluggableElementTypes/TextSearchAdapterType.d.ts +1 -1
- package/pluggableElementTypes/models/BaseConnectionModelFactory.d.ts +18 -0
- package/pluggableElementTypes/models/BaseConnectionModelFactory.js +9 -0
- package/pluggableElementTypes/models/BaseDisplayModel.d.ts +10 -1
- package/pluggableElementTypes/models/BaseDisplayModel.js +9 -1
- package/pluggableElementTypes/models/BaseTrackModel.d.ts +2 -1
- package/pluggableElementTypes/models/BaseTrackModel.js +4 -2
- package/pluggableElementTypes/models/BaseViewModel.d.ts +46 -2
- package/pluggableElementTypes/models/BaseViewModel.js +6 -0
- package/pluggableElementTypes/models/InternetAccountModel.d.ts +36 -2
- package/pluggableElementTypes/models/InternetAccountModel.js +33 -21
- package/pluggableElementTypes/models/baseConnectionConfig.d.ts +22 -2
- package/pluggableElementTypes/models/baseConnectionConfig.js +2 -1
- package/pluggableElementTypes/models/baseInternetAccountConfig.d.ts +42 -1
- package/pluggableElementTypes/models/baseInternetAccountConfig.js +1 -1
- package/pluggableElementTypes/models/baseTrackConfig.d.ts +120 -3
- package/pluggableElementTypes/models/baseTrackConfig.js +7 -5
- package/pluggableElementTypes/models/index.d.ts +1 -1
- package/pluggableElementTypes/renderers/BoxRendererType.js +1 -2
- package/pluggableElementTypes/renderers/CircularChordRendererType.d.ts +2 -2
- package/pluggableElementTypes/renderers/FeatureRendererType.d.ts +4 -2
- package/pluggableElementTypes/renderers/FeatureRendererType.js +4 -6
- package/pluggableElementTypes/renderers/RendererType.d.ts +1 -1
- package/pluggableElementTypes/renderers/RpcRenderedSvgGroup.d.ts +2 -2
- package/pluggableElementTypes/renderers/ServerSideRenderedContent.d.ts +1 -1
- package/pluggableElementTypes/renderers/ServerSideRendererType.d.ts +1 -1
- package/rpc/BaseRpcDriver.js +1 -7
- package/rpc/RpcManager.d.ts +8 -1
- package/rpc/RpcManager.js +1 -1
- package/rpc/baseRpcConfig.d.ts +10 -1
- package/rpc/configSchema.d.ts +14 -1
- package/rpc/coreRpcMethods.d.ts +1 -1
- package/rpc/coreRpcMethods.js +3 -3
- package/rpc/mainThreadRpcConfig.d.ts +7 -1
- package/rpc/methods/{CoreEstimateRegionStats.d.ts → CoreGetFeatureDensityStats.d.ts} +2 -2
- package/rpc/methods/{CoreEstimateRegionStats.js → CoreGetFeatureDensityStats.js} +4 -4
- package/rpc/methods/CoreGetFeatureDetails.js +5 -5
- package/rpc/webWorkerRpcConfig.d.ts +7 -1
- package/tsconfig.build.tsbuildinfo +1 -1
- package/ui/AppLogo.d.ts +2 -2
- package/ui/AssemblySelector.d.ts +2 -2
- package/ui/AssemblySelector.js +1 -1
- package/ui/CascadingMenu.d.ts +2 -2
- package/ui/CascadingMenuButton.d.ts +8 -0
- package/ui/CascadingMenuButton.js +20 -0
- package/ui/ColorPicker.d.ts +4 -4
- package/ui/Dialog.d.ts +5 -5
- package/ui/Dialog.js +19 -7
- package/ui/DropDownMenu.d.ts +2 -2
- package/ui/EditableTypography.js +1 -1
- package/ui/ErrorMessage.d.ts +2 -2
- package/ui/ErrorMessage.js +6 -2
- package/ui/FactoryResetDialog.d.ts +2 -2
- package/ui/FatalErrorDialog.d.ts +6 -7
- package/ui/FatalErrorDialog.js +7 -7
- package/ui/FileSelector/FileSelector.d.ts +2 -2
- package/ui/FileSelector/FileSelector.js +3 -2
- package/ui/FileSelector/LocalFileChooser.d.ts +2 -2
- package/ui/FileSelector/UrlChooser.d.ts +3 -4
- package/ui/FileSelector/UrlChooser.js +8 -10
- package/ui/Icons.d.ts +10 -10
- package/ui/LoadingEllipses.d.ts +2 -2
- package/ui/Logo.d.ts +3 -3
- package/ui/Menu.d.ts +2 -2
- package/ui/PrerenderedCanvas.d.ts +2 -2
- package/ui/ResizeBar.d.ts +1 -1
- package/ui/ResizeBar.js +1 -1
- package/ui/ResizeHandle.d.ts +2 -2
- package/ui/ReturnToImportFormDialog.d.ts +2 -2
- package/ui/SanitizedHTML.d.ts +2 -2
- package/ui/SanitizedHTML.js +6 -0
- package/ui/Snackbar.d.ts +7 -9
- package/ui/Snackbar.js +12 -17
- package/ui/SnackbarModel.d.ts +9 -3
- package/ui/SnackbarModel.js +3 -3
- package/ui/Tooltip.d.ts +2 -2
- package/ui/index.d.ts +0 -1
- package/ui/index.js +1 -3
- package/ui/react-colorful.d.ts +1 -1
- package/ui/theme.js +3 -18
- package/util/Base1DUtils.js +2 -1
- package/util/QuickLRU.d.ts +1 -1
- package/util/blockTypes.js +1 -1
- package/util/formatFastaStrings.js +1 -1
- package/util/index.d.ts +18 -2
- package/util/index.js +77 -11
- package/util/io/index.js +1 -1
- package/util/layouts/PrecomputedMultiLayout.d.ts +1 -1
- package/util/mst-reflection.js +1 -2
- package/util/offscreenCanvasUtils.d.ts +2 -2
- package/util/stats.d.ts +5 -5
- package/util/types/index.d.ts +9 -3
- package/util/types/index.js +6 -2
- package/util/types/mst.d.ts +12 -9
- package/util/types/util.d.ts +0 -3
- package/BaseFeatureWidget/BaseFeatureDetail.d.ts +0 -62
- package/BaseFeatureWidget/BaseFeatureDetail.js +0 -378
- package/BaseFeatureWidget/SequenceBox.d.ts +0 -29
- package/BaseFeatureWidget/SequenceBox.js +0 -63
- package/BaseFeatureWidget/SequenceFeatureDetails.d.ts +0 -3
- package/BaseFeatureWidget/SequenceFeatureDetails.js +0 -230
- package/data_adapters/BaseAdapter.d.ts +0 -138
- package/ui/AboutDialog.d.ts +0 -12
- package/ui/AboutDialog.js +0 -125
- package/ui/App.d.ts +0 -18
- package/ui/App.js +0 -114
- package/ui/AppToolbar.d.ts +0 -19
- package/ui/AppToolbar.js +0 -56
- package/ui/Drawer.d.ts +0 -8
- package/ui/Drawer.js +0 -34
- package/ui/DrawerWidget.d.ts +0 -6
- package/ui/DrawerWidget.js +0 -130
- package/ui/ViewContainer.d.ts +0 -9
- package/ui/ViewContainer.js +0 -76
- package/ui/ViewContainerTitle.d.ts +0 -6
- package/ui/ViewContainerTitle.js +0 -42
- package/ui/ViewLauncher.d.ts +0 -18
- package/ui/ViewLauncher.js +0 -50
- package/ui/ViewMenu.d.ts +0 -9
- package/ui/ViewMenu.js +0 -69
- package/ui/ViewPanel.d.ts +0 -19
- package/ui/ViewPanel.js +0 -49
- /package/BaseFeatureWidget/{test_data → SequenceFeatureDetails/test_data}/DLGAP3.js +0 -0
- /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;
|