@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
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export declare const useStyles: (params: void, styleOverrides?: {
|
|
3
|
+
props: any;
|
|
4
|
+
ownerState?: Record<string, unknown> | undefined;
|
|
5
|
+
} | undefined) => {
|
|
6
|
+
classes: Record<"field" | "fieldSubvalue", string>;
|
|
7
|
+
theme: import("@mui/material").Theme;
|
|
8
|
+
css: import("tss-react").Css;
|
|
9
|
+
cx: import("tss-react").Cx;
|
|
10
|
+
};
|
|
11
|
+
export default function ArrayValue({ name, value, description, prefix, }: {
|
|
12
|
+
description?: React.ReactNode;
|
|
13
|
+
name: string;
|
|
14
|
+
value: unknown[];
|
|
15
|
+
prefix?: string[];
|
|
16
|
+
}): React.JSX.Element;
|
|
@@ -0,0 +1,45 @@
|
|
|
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.useStyles = void 0;
|
|
7
|
+
const react_1 = __importDefault(require("react"));
|
|
8
|
+
const is_object_1 = __importDefault(require("is-object"));
|
|
9
|
+
const mui_1 = require("tss-react/mui");
|
|
10
|
+
// locals
|
|
11
|
+
const Attributes_1 = __importDefault(require("./Attributes"));
|
|
12
|
+
const FieldName_1 = __importDefault(require("./FieldName"));
|
|
13
|
+
const BasicValue_1 = __importDefault(require("./BasicValue"));
|
|
14
|
+
exports.useStyles = (0, mui_1.makeStyles)()(theme => ({
|
|
15
|
+
field: {
|
|
16
|
+
display: 'flex',
|
|
17
|
+
flexWrap: 'wrap',
|
|
18
|
+
},
|
|
19
|
+
fieldSubvalue: {
|
|
20
|
+
wordBreak: 'break-word',
|
|
21
|
+
maxHeight: 300,
|
|
22
|
+
padding: theme.spacing(0.5),
|
|
23
|
+
border: `1px solid ${theme.palette.action.selected}`,
|
|
24
|
+
boxSizing: 'border-box',
|
|
25
|
+
overflow: 'auto',
|
|
26
|
+
},
|
|
27
|
+
}));
|
|
28
|
+
function ArrayValue({ name, value, description, prefix = [], }) {
|
|
29
|
+
const { classes } = (0, exports.useStyles)();
|
|
30
|
+
if (value.length === 1) {
|
|
31
|
+
return (0, is_object_1.default)(value[0]) ? (react_1.default.createElement(Attributes_1.default, { attributes: value[0], prefix: [...prefix, name] })) : (react_1.default.createElement("div", { className: classes.field },
|
|
32
|
+
react_1.default.createElement(FieldName_1.default, { prefix: prefix, description: description, name: name }),
|
|
33
|
+
react_1.default.createElement(BasicValue_1.default, { value: value[0] })));
|
|
34
|
+
}
|
|
35
|
+
else if (value.every(val => (0, is_object_1.default)(val))) {
|
|
36
|
+
return (react_1.default.createElement(react_1.default.Fragment, null, value.map((val, i) => (react_1.default.createElement(Attributes_1.default, { key: JSON.stringify(val) + '-' + i, attributes: val, prefix: [...prefix, name + '-' + i] })))));
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
return (react_1.default.createElement("div", { className: classes.field },
|
|
40
|
+
react_1.default.createElement(FieldName_1.default, { prefix: prefix, description: description, name: name }),
|
|
41
|
+
value.map((val, i) => (react_1.default.createElement("div", { key: JSON.stringify(val) + '-' + i, className: classes.fieldSubvalue },
|
|
42
|
+
react_1.default.createElement(BasicValue_1.default, { value: val }))))));
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
exports.default = ArrayValue;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export default function Attributes(props: {
|
|
3
|
+
attributes: {
|
|
4
|
+
[key: string]: unknown;
|
|
5
|
+
__jbrowsefmt?: {
|
|
6
|
+
[key: string]: unknown;
|
|
7
|
+
};
|
|
8
|
+
};
|
|
9
|
+
omit?: string[];
|
|
10
|
+
omitSingleLevel?: string[];
|
|
11
|
+
formatter?: (val: unknown, key: string) => React.ReactNode;
|
|
12
|
+
descriptions?: Record<string, React.ReactNode>;
|
|
13
|
+
prefix?: string[];
|
|
14
|
+
hideUris?: boolean;
|
|
15
|
+
}): React.JSX.Element;
|
|
@@ -0,0 +1,52 @@
|
|
|
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
|
+
const react_1 = __importDefault(require("react"));
|
|
7
|
+
const is_object_1 = __importDefault(require("is-object"));
|
|
8
|
+
// locals
|
|
9
|
+
const util_1 = require("./util");
|
|
10
|
+
const util_2 = require("../../util");
|
|
11
|
+
const DataGridDetails_1 = __importDefault(require("./DataGridDetails"));
|
|
12
|
+
const ArrayValue_1 = __importDefault(require("./ArrayValue"));
|
|
13
|
+
const UriField_1 = __importDefault(require("./UriField"));
|
|
14
|
+
const SimpleField_1 = __importDefault(require("./SimpleField"));
|
|
15
|
+
const MAX_FIELD_NAME_WIDTH = 170;
|
|
16
|
+
// these are always omitted as too detailed
|
|
17
|
+
const globalOmit = [
|
|
18
|
+
'__jbrowsefmt',
|
|
19
|
+
'length',
|
|
20
|
+
'position',
|
|
21
|
+
'subfeatures',
|
|
22
|
+
'uniqueId',
|
|
23
|
+
'exonFrames',
|
|
24
|
+
'parentId',
|
|
25
|
+
'thickStart',
|
|
26
|
+
'thickEnd',
|
|
27
|
+
];
|
|
28
|
+
function Attributes(props) {
|
|
29
|
+
const { attributes, omit = [], omitSingleLevel = [], descriptions, formatter = val => val, hideUris, prefix = [], } = props;
|
|
30
|
+
const omits = new Set([...omit, ...globalOmit, ...omitSingleLevel]);
|
|
31
|
+
const { __jbrowsefmt, ...rest } = attributes;
|
|
32
|
+
const formattedAttributes = { ...rest, ...__jbrowsefmt };
|
|
33
|
+
const maxLabelWidth = (0, util_1.generateMaxWidth)(Object.entries(formattedAttributes).filter(([k, v]) => v !== undefined && !omits.has(k)), prefix);
|
|
34
|
+
return (react_1.default.createElement(react_1.default.Fragment, null, Object.entries(formattedAttributes)
|
|
35
|
+
.filter(([k, v]) => v !== undefined && !omits.has(k))
|
|
36
|
+
.map(([key, value]) => {
|
|
37
|
+
const description = (0, util_1.accessNested)([...prefix, key], descriptions);
|
|
38
|
+
if (Array.isArray(value)) {
|
|
39
|
+
// check if it looks like an array of objects, which could be used
|
|
40
|
+
// in data grid
|
|
41
|
+
return value.length > 1 && value.every(val => (0, is_object_1.default)(val)) ? (react_1.default.createElement(DataGridDetails_1.default, { key: key, name: key, prefix: prefix, value: value })) : (react_1.default.createElement(ArrayValue_1.default, { key: key, name: key, value: value, description: description, prefix: prefix }));
|
|
42
|
+
}
|
|
43
|
+
else if ((0, is_object_1.default)(value)) {
|
|
44
|
+
const { omitSingleLevel, ...rest } = props;
|
|
45
|
+
return (0, util_2.isUriLocation)(value) ? (hideUris ? null : (react_1.default.createElement(UriField_1.default, { key: key, name: key, prefix: prefix, value: value }))) : (react_1.default.createElement(Attributes, { ...rest, key: key, attributes: value, descriptions: descriptions, prefix: [...prefix, key] }));
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
return (react_1.default.createElement(SimpleField_1.default, { key: key, name: key, value: formatter(value, key), description: description, prefix: prefix, width: Math.min(maxLabelWidth, MAX_FIELD_NAME_WIDTH) }));
|
|
49
|
+
}
|
|
50
|
+
})));
|
|
51
|
+
}
|
|
52
|
+
exports.default = Attributes;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export declare const useStyles: (params: void, styleOverrides?: {
|
|
3
|
+
props: any;
|
|
4
|
+
ownerState?: Record<string, unknown> | undefined;
|
|
5
|
+
} | undefined) => {
|
|
6
|
+
classes: Record<"fieldValue", string>;
|
|
7
|
+
theme: import("@mui/material").Theme;
|
|
8
|
+
css: import("tss-react").Css;
|
|
9
|
+
cx: import("tss-react").Cx;
|
|
10
|
+
};
|
|
11
|
+
export default function BasicValue({ value }: {
|
|
12
|
+
value: unknown;
|
|
13
|
+
}): React.JSX.Element;
|
|
@@ -0,0 +1,27 @@
|
|
|
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.useStyles = void 0;
|
|
7
|
+
const react_1 = __importDefault(require("react"));
|
|
8
|
+
const mui_1 = require("tss-react/mui");
|
|
9
|
+
const is_object_1 = __importDefault(require("is-object"));
|
|
10
|
+
const material_1 = require("@mui/material");
|
|
11
|
+
// locals
|
|
12
|
+
const ui_1 = require("../../ui");
|
|
13
|
+
exports.useStyles = (0, mui_1.makeStyles)()(theme => ({
|
|
14
|
+
fieldValue: {
|
|
15
|
+
wordBreak: 'break-word',
|
|
16
|
+
maxHeight: 300,
|
|
17
|
+
fontSize: 12,
|
|
18
|
+
padding: theme.spacing(0.5),
|
|
19
|
+
overflow: 'auto',
|
|
20
|
+
},
|
|
21
|
+
}));
|
|
22
|
+
function BasicValue({ value }) {
|
|
23
|
+
const { classes } = (0, exports.useStyles)();
|
|
24
|
+
const isLink = `${value}`.match(/^https?:\/\//);
|
|
25
|
+
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) }))));
|
|
26
|
+
}
|
|
27
|
+
exports.default = BasicValue;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export declare const useStyles: (params: void, styleOverrides?: {
|
|
3
|
+
props: any;
|
|
4
|
+
ownerState?: Record<string, unknown> | undefined;
|
|
5
|
+
} | undefined) => {
|
|
6
|
+
classes: Record<"margin", string>;
|
|
7
|
+
theme: import("@mui/material").Theme;
|
|
8
|
+
css: import("tss-react").Css;
|
|
9
|
+
cx: import("tss-react").Cx;
|
|
10
|
+
};
|
|
11
|
+
export default function DataGridDetails({ value, prefix, name, }: {
|
|
12
|
+
name: string;
|
|
13
|
+
prefix?: string[];
|
|
14
|
+
value: Record<string, unknown>[];
|
|
15
|
+
}): React.JSX.Element | null;
|
|
@@ -0,0 +1,98 @@
|
|
|
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.useStyles = void 0;
|
|
30
|
+
const react_1 = __importStar(require("react"));
|
|
31
|
+
const mui_1 = require("tss-react/mui");
|
|
32
|
+
const x_data_grid_1 = require("@mui/x-data-grid");
|
|
33
|
+
const material_1 = require("@mui/material");
|
|
34
|
+
// locals
|
|
35
|
+
const util_1 = require("../../util");
|
|
36
|
+
const ResizeBar_1 = __importStar(require("../../ui/ResizeBar"));
|
|
37
|
+
const FieldName_1 = __importDefault(require("./FieldName"));
|
|
38
|
+
const UriLink_1 = __importDefault(require("./UriLink"));
|
|
39
|
+
exports.useStyles = (0, mui_1.makeStyles)()(theme => ({
|
|
40
|
+
margin: {
|
|
41
|
+
margin: theme.spacing(1),
|
|
42
|
+
width: '100%',
|
|
43
|
+
},
|
|
44
|
+
}));
|
|
45
|
+
function DataGridDetails({ value, prefix, name, }) {
|
|
46
|
+
const { classes } = (0, exports.useStyles)();
|
|
47
|
+
const { ref, scrollLeft } = (0, ResizeBar_1.useResizeBar)();
|
|
48
|
+
const [checked, setChecked] = (0, react_1.useState)(false);
|
|
49
|
+
const keys = Object.keys(value[0]).sort();
|
|
50
|
+
const unionKeys = new Set(keys);
|
|
51
|
+
// avoids key 'id' from being used in row data
|
|
52
|
+
const rows = Object.entries(value).map(([k, val]) => {
|
|
53
|
+
const { id, ...rest } = val;
|
|
54
|
+
return {
|
|
55
|
+
id: k,
|
|
56
|
+
identifier: id,
|
|
57
|
+
...rest,
|
|
58
|
+
};
|
|
59
|
+
});
|
|
60
|
+
for (const val of value) {
|
|
61
|
+
for (const k of Object.keys(val)) {
|
|
62
|
+
unionKeys.add(k);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
// avoids key 'id' from being used in column names, and tries
|
|
66
|
+
// to make it at the start of the colNames array
|
|
67
|
+
let colNames;
|
|
68
|
+
if (unionKeys.has('id')) {
|
|
69
|
+
unionKeys.delete('id');
|
|
70
|
+
colNames = ['identifier', ...unionKeys];
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
colNames = [...unionKeys];
|
|
74
|
+
}
|
|
75
|
+
const [widths, setWidths] = (0, react_1.useState)(colNames.map(e => (0, util_1.measureGridWidth)(rows.map(r => r[e]))));
|
|
76
|
+
if (unionKeys.size < keys.length + 5) {
|
|
77
|
+
return (react_1.default.createElement(react_1.default.Fragment, null,
|
|
78
|
+
react_1.default.createElement(FieldName_1.default, { prefix: prefix, name: name }),
|
|
79
|
+
react_1.default.createElement(material_1.FormControlLabel, { control: react_1.default.createElement(material_1.Checkbox, { checked: checked, onChange: event => setChecked(event.target.checked) }), label: react_1.default.createElement(material_1.Typography, { variant: "body2" }, "Show options") }),
|
|
80
|
+
react_1.default.createElement("div", { className: classes.margin, ref: ref },
|
|
81
|
+
react_1.default.createElement(ResizeBar_1.default, { widths: widths, setWidths: setWidths, scrollLeft: scrollLeft }),
|
|
82
|
+
react_1.default.createElement(x_data_grid_1.DataGrid, { disableRowSelectionOnClick: true,
|
|
83
|
+
// @ts-expect-error the rows gets confused by the renderCell of the
|
|
84
|
+
// columns below
|
|
85
|
+
rows: rows, rowCount: 25, rowHeight: 25, columnHeaderHeight: 35, hideFooter: rows.length < 25, slots: { toolbar: checked ? x_data_grid_1.GridToolbar : null }, slotProps: {
|
|
86
|
+
toolbar: { printOptions: { disableToolbarButton: true } },
|
|
87
|
+
}, columns: colNames.map((val, index) => ({
|
|
88
|
+
field: val,
|
|
89
|
+
renderCell: params => {
|
|
90
|
+
const value = params.value;
|
|
91
|
+
return (0, util_1.isUriLocation)(value) ? (react_1.default.createElement(UriLink_1.default, { value: value })) : (react_1.default.createElement(react_1.default.Fragment, null, (0, util_1.getStr)(value)));
|
|
92
|
+
},
|
|
93
|
+
width: widths[index],
|
|
94
|
+
})) }))));
|
|
95
|
+
}
|
|
96
|
+
return null;
|
|
97
|
+
}
|
|
98
|
+
exports.default = DataGridDetails;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export declare const useStyles: (params: void, styleOverrides?: {
|
|
3
|
+
props: any;
|
|
4
|
+
ownerState?: Record<string, unknown> | undefined;
|
|
5
|
+
} | undefined) => {
|
|
6
|
+
classes: Record<"fieldDescription" | "fieldName", string>;
|
|
7
|
+
theme: import("@mui/material").Theme;
|
|
8
|
+
css: import("tss-react").Css;
|
|
9
|
+
cx: import("tss-react").Cx;
|
|
10
|
+
};
|
|
11
|
+
export default function FieldName({ description, name, width, prefix, }: {
|
|
12
|
+
description?: React.ReactNode;
|
|
13
|
+
name: string;
|
|
14
|
+
prefix?: string[];
|
|
15
|
+
width?: number;
|
|
16
|
+
}): React.JSX.Element;
|
|
@@ -0,0 +1,32 @@
|
|
|
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.useStyles = void 0;
|
|
7
|
+
const react_1 = __importDefault(require("react"));
|
|
8
|
+
const material_1 = require("@mui/material");
|
|
9
|
+
const mui_1 = require("tss-react/mui");
|
|
10
|
+
exports.useStyles = (0, mui_1.makeStyles)()(theme => ({
|
|
11
|
+
fieldDescription: {
|
|
12
|
+
'&:hover': {
|
|
13
|
+
background: theme.palette.mode === 'dark' ? '#e65100' : 'yellow',
|
|
14
|
+
},
|
|
15
|
+
},
|
|
16
|
+
fieldName: {
|
|
17
|
+
wordBreak: 'break-all',
|
|
18
|
+
minWidth: 90,
|
|
19
|
+
borderBottom: '1px solid #0003',
|
|
20
|
+
fontSize: 12,
|
|
21
|
+
background: theme.palette.action.disabledBackground,
|
|
22
|
+
marginRight: theme.spacing(1),
|
|
23
|
+
padding: theme.spacing(0.5),
|
|
24
|
+
},
|
|
25
|
+
}));
|
|
26
|
+
function FieldName({ description, name, width, prefix = [], }) {
|
|
27
|
+
const { classes, cx } = (0, exports.useStyles)();
|
|
28
|
+
const val = [...prefix, name].join('.');
|
|
29
|
+
return description ? (react_1.default.createElement(material_1.Tooltip, { title: description, placement: "left" },
|
|
30
|
+
react_1.default.createElement("div", { className: cx(classes.fieldDescription, classes.fieldName) }, val))) : (react_1.default.createElement("div", { className: classes.fieldName, style: { width: width } }, val));
|
|
31
|
+
}
|
|
32
|
+
exports.default = FieldName;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export declare const useStyles: (params: void, styleOverrides?: {
|
|
3
|
+
props: any;
|
|
4
|
+
ownerState?: Record<string, unknown> | undefined;
|
|
5
|
+
} | undefined) => {
|
|
6
|
+
classes: Record<"field", string>;
|
|
7
|
+
theme: import("@mui/material").Theme;
|
|
8
|
+
css: import("tss-react").Css;
|
|
9
|
+
cx: import("tss-react").Cx;
|
|
10
|
+
};
|
|
11
|
+
export default function SimpleField({ name, value, description, prefix, width, }: {
|
|
12
|
+
description?: React.ReactNode;
|
|
13
|
+
name: string;
|
|
14
|
+
value: unknown;
|
|
15
|
+
prefix?: string[];
|
|
16
|
+
width?: number;
|
|
17
|
+
}): React.JSX.Element | null;
|
|
@@ -0,0 +1,23 @@
|
|
|
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.useStyles = void 0;
|
|
7
|
+
const react_1 = __importDefault(require("react"));
|
|
8
|
+
const mui_1 = require("tss-react/mui");
|
|
9
|
+
const FieldName_1 = __importDefault(require("./FieldName"));
|
|
10
|
+
const BasicValue_1 = __importDefault(require("./BasicValue"));
|
|
11
|
+
exports.useStyles = (0, mui_1.makeStyles)()({
|
|
12
|
+
field: {
|
|
13
|
+
display: 'flex',
|
|
14
|
+
flexWrap: 'wrap',
|
|
15
|
+
},
|
|
16
|
+
});
|
|
17
|
+
function SimpleField({ name, value, description, prefix, width, }) {
|
|
18
|
+
const { classes } = (0, exports.useStyles)();
|
|
19
|
+
return value !== null && value !== undefined ? (react_1.default.createElement("div", { className: classes.field },
|
|
20
|
+
react_1.default.createElement(FieldName_1.default, { prefix: prefix, description: description, name: name, width: width }),
|
|
21
|
+
react_1.default.createElement(BasicValue_1.default, { value: value }))) : null;
|
|
22
|
+
}
|
|
23
|
+
exports.default = SimpleField;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export declare const useStyles: (params: void, styleOverrides?: {
|
|
3
|
+
props: any;
|
|
4
|
+
ownerState?: Record<string, unknown> | undefined;
|
|
5
|
+
} | undefined) => {
|
|
6
|
+
classes: Record<"field", string>;
|
|
7
|
+
theme: import("@mui/material").Theme;
|
|
8
|
+
css: import("tss-react").Css;
|
|
9
|
+
cx: import("tss-react").Cx;
|
|
10
|
+
};
|
|
11
|
+
export default function UriField({ value, prefix, name, }: {
|
|
12
|
+
value: {
|
|
13
|
+
uri: string;
|
|
14
|
+
baseUri?: string;
|
|
15
|
+
};
|
|
16
|
+
name: string;
|
|
17
|
+
prefix: string[];
|
|
18
|
+
}): React.JSX.Element;
|
|
@@ -0,0 +1,31 @@
|
|
|
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.useStyles = void 0;
|
|
7
|
+
const react_1 = __importDefault(require("react"));
|
|
8
|
+
const FieldName_1 = __importDefault(require("./FieldName"));
|
|
9
|
+
const mui_1 = require("tss-react/mui");
|
|
10
|
+
const BasicValue_1 = __importDefault(require("./BasicValue"));
|
|
11
|
+
exports.useStyles = (0, mui_1.makeStyles)()({
|
|
12
|
+
field: {
|
|
13
|
+
display: 'flex',
|
|
14
|
+
flexWrap: 'wrap',
|
|
15
|
+
},
|
|
16
|
+
});
|
|
17
|
+
function UriField({ value, prefix, name, }) {
|
|
18
|
+
const { classes } = (0, exports.useStyles)();
|
|
19
|
+
const { uri, baseUri = '' } = value;
|
|
20
|
+
let href;
|
|
21
|
+
try {
|
|
22
|
+
href = new URL(uri, baseUri).href;
|
|
23
|
+
}
|
|
24
|
+
catch (e) {
|
|
25
|
+
href = uri;
|
|
26
|
+
}
|
|
27
|
+
return (react_1.default.createElement("div", { className: classes.field },
|
|
28
|
+
react_1.default.createElement(FieldName_1.default, { prefix: prefix, name: name }),
|
|
29
|
+
react_1.default.createElement(BasicValue_1.default, { value: href })));
|
|
30
|
+
}
|
|
31
|
+
exports.default = UriField;
|
|
@@ -0,0 +1,13 @@
|
|
|
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
|
+
const react_1 = __importDefault(require("react"));
|
|
7
|
+
const util_1 = require("../../util");
|
|
8
|
+
const ui_1 = require("../../ui");
|
|
9
|
+
function UriLink({ value, }) {
|
|
10
|
+
const href = (0, util_1.getUriLink)(value);
|
|
11
|
+
return react_1.default.createElement(ui_1.SanitizedHTML, { html: `<a href="${href}">${href}</a>` });
|
|
12
|
+
}
|
|
13
|
+
exports.default = UriLink;
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { IAnyStateTreeNode } from 'mobx-state-tree';
|
|
3
|
+
import { BaseCardProps, BaseProps } from '../types';
|
|
4
|
+
import { SimpleFeatureSerialized } from '../../util';
|
|
5
|
+
export declare const useStyles: (params: void, styleOverrides?: {
|
|
6
|
+
props: any;
|
|
7
|
+
ownerState?: Record<string, unknown> | undefined;
|
|
8
|
+
} | undefined) => {
|
|
9
|
+
classes: Record<"expandIcon" | "expansionPanelDetails", string>;
|
|
10
|
+
theme: import("@mui/material").Theme;
|
|
11
|
+
css: import("tss-react").Css;
|
|
12
|
+
cx: import("tss-react").Cx;
|
|
13
|
+
};
|
|
14
|
+
export declare function BaseCard({ children, title, defaultExpanded, }: BaseCardProps): React.JSX.Element;
|
|
15
|
+
export declare const BaseCoreDetails: (props: BaseProps) => React.JSX.Element;
|
|
16
|
+
export declare const BaseAttributes: (props: BaseProps) => React.JSX.Element;
|
|
17
|
+
export interface BaseInputProps extends BaseCardProps {
|
|
18
|
+
omit?: string[];
|
|
19
|
+
model: any;
|
|
20
|
+
descriptions?: Record<string, React.ReactNode>;
|
|
21
|
+
formatter?: (val: unknown, key: string) => React.ReactNode;
|
|
22
|
+
}
|
|
23
|
+
export declare function FeatureDetails(props: {
|
|
24
|
+
model: IAnyStateTreeNode;
|
|
25
|
+
feature: SimpleFeatureSerialized;
|
|
26
|
+
depth?: number;
|
|
27
|
+
omit?: string[];
|
|
28
|
+
descriptions?: Record<string, React.ReactNode>;
|
|
29
|
+
formatter?: (val: unknown, key: string) => React.ReactNode;
|
|
30
|
+
}): React.JSX.Element;
|
|
31
|
+
declare const _default: ({ model }: BaseInputProps) => React.JSX.Element | null;
|
|
32
|
+
export default _default;
|
|
33
|
+
export { default as Attributes } from './Attributes';
|