@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
@@ -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,7 @@
1
+ import React from 'react';
2
+ export default function UriLink({ value, }: {
3
+ value: {
4
+ uri: string;
5
+ baseUri?: string;
6
+ };
7
+ }): React.JSX.Element;
@@ -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';