jbrowse-plugin-mafviewer 1.0.8 → 1.1.2
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/README.md +54 -20
- package/dist/{TaffyAdapter/TaffyAdapter.d.ts → BgzipTaffyAdapter/BgzipTaffyAdapter.d.ts} +11 -7
- package/dist/BgzipTaffyAdapter/BgzipTaffyAdapter.js +204 -0
- package/dist/BgzipTaffyAdapter/BgzipTaffyAdapter.js.map +1 -0
- package/dist/{TaffyAdapter → BgzipTaffyAdapter}/configSchema.d.ts +14 -1
- package/dist/{TaffyAdapter → BgzipTaffyAdapter}/configSchema.js +21 -6
- package/dist/BgzipTaffyAdapter/configSchema.js.map +1 -0
- package/dist/BgzipTaffyAdapter/index.d.ts +2 -0
- package/dist/BgzipTaffyAdapter/index.js +11 -0
- package/dist/BgzipTaffyAdapter/index.js.map +1 -0
- package/dist/BgzipTaffyAdapter/rowInstructions.d.ts +35 -0
- package/dist/BgzipTaffyAdapter/rowInstructions.js +55 -0
- package/dist/BgzipTaffyAdapter/rowInstructions.js.map +1 -0
- package/dist/BgzipTaffyAdapter/types.d.ts +13 -0
- package/dist/BgzipTaffyAdapter/types.js +2 -0
- package/dist/BgzipTaffyAdapter/types.js.map +1 -0
- package/dist/BgzipTaffyAdapter/virtualOffset.d.ts +8 -0
- package/dist/BgzipTaffyAdapter/virtualOffset.js +23 -0
- package/dist/BgzipTaffyAdapter/virtualOffset.js.map +1 -0
- package/dist/BigMafAdapter/BigMafAdapter.js +1 -1
- package/dist/BigMafAdapter/BigMafAdapter.js.map +1 -1
- package/dist/BigMafAdapter/configSchema.d.ts +11 -0
- package/dist/BigMafAdapter/configSchema.js +11 -0
- package/dist/BigMafAdapter/configSchema.js.map +1 -1
- package/dist/BigMafAdapter/index.js +1 -1
- package/dist/BigMafAdapter/index.js.map +1 -1
- package/dist/LinearMafDisplay/components/ColorLegend.js +10 -6
- package/dist/LinearMafDisplay/components/ColorLegend.js.map +1 -1
- package/dist/LinearMafDisplay/components/ReactComponent.js +39 -4
- package/dist/LinearMafDisplay/components/ReactComponent.js.map +1 -1
- package/dist/LinearMafDisplay/components/SetRowHeight.js +7 -7
- package/dist/LinearMafDisplay/components/SetRowHeight.js.map +1 -1
- package/dist/LinearMafDisplay/components/SvgWrapper.d.ts +8 -0
- package/dist/LinearMafDisplay/components/SvgWrapper.js +21 -0
- package/dist/LinearMafDisplay/components/SvgWrapper.js.map +1 -0
- package/dist/LinearMafDisplay/components/Tree.d.ts +5 -0
- package/dist/LinearMafDisplay/components/Tree.js +22 -0
- package/dist/LinearMafDisplay/components/Tree.js.map +1 -0
- package/dist/LinearMafDisplay/components/YScaleBars.d.ts +0 -1
- package/dist/LinearMafDisplay/components/YScaleBars.js +6 -27
- package/dist/LinearMafDisplay/components/YScaleBars.js.map +1 -1
- package/dist/LinearMafDisplay/components/util.d.ts +1 -0
- package/dist/LinearMafDisplay/components/util.js +8 -0
- package/dist/LinearMafDisplay/components/util.js.map +1 -0
- package/dist/LinearMafDisplay/index.js +1 -1
- package/dist/LinearMafDisplay/index.js.map +1 -1
- package/dist/LinearMafDisplay/renderSvg.js +1 -0
- package/dist/LinearMafDisplay/renderSvg.js.map +1 -1
- package/dist/LinearMafDisplay/stateModel.d.ts +76 -14
- package/dist/LinearMafDisplay/stateModel.js +118 -18
- package/dist/LinearMafDisplay/stateModel.js.map +1 -1
- package/dist/LinearMafDisplay/types.d.ts +17 -0
- package/dist/LinearMafDisplay/types.js +16 -0
- package/dist/LinearMafDisplay/types.js.map +1 -0
- package/dist/LinearMafRenderer/LinearMafRenderer.d.ts +3 -3
- package/dist/LinearMafRenderer/LinearMafRenderer.js +11 -9
- package/dist/LinearMafRenderer/LinearMafRenderer.js.map +1 -1
- package/dist/LinearMafRenderer/components/ReactComponent.js +1 -1
- package/dist/LinearMafRenderer/components/ReactComponent.js.map +1 -1
- package/dist/LinearMafRenderer/index.js +1 -1
- package/dist/LinearMafRenderer/index.js.map +1 -1
- package/dist/MafAddTrackWorkflow/AddTrackWorkflow.js +42 -25
- package/dist/MafAddTrackWorkflow/AddTrackWorkflow.js.map +1 -1
- package/dist/MafRPC/index.d.ts +16 -0
- package/dist/MafRPC/index.js +19 -0
- package/dist/MafRPC/index.js.map +1 -0
- package/dist/MafTabixAdapter/MafTabixAdapter.d.ts +8 -0
- package/dist/MafTabixAdapter/MafTabixAdapter.js +18 -19
- package/dist/MafTabixAdapter/MafTabixAdapter.js.map +1 -1
- package/dist/MafTabixAdapter/configSchema.d.ts +17 -0
- package/dist/MafTabixAdapter/configSchema.js +17 -1
- package/dist/MafTabixAdapter/configSchema.js.map +1 -1
- package/dist/MafTabixAdapter/index.js +1 -1
- package/dist/MafTabixAdapter/index.js.map +1 -1
- package/dist/MafTrack/index.js.map +1 -1
- package/dist/index.js +6 -4
- package/dist/index.js.map +1 -1
- package/dist/jbrowse-plugin-mafviewer.umd.production.min.js +65 -4
- package/dist/jbrowse-plugin-mafviewer.umd.production.min.js.map +4 -4
- package/dist/parseNewick.d.ts +60 -0
- package/dist/parseNewick.js +95 -0
- package/dist/parseNewick.js.map +1 -0
- package/dist/util.d.ts +9 -0
- package/dist/util.js +9 -0
- package/dist/util.js.map +1 -0
- package/package.json +18 -5
- package/src/BgzipTaffyAdapter/BgzipTaffyAdapter.ts +235 -0
- package/src/{TaffyAdapter → BgzipTaffyAdapter}/configSchema.ts +21 -6
- package/src/{TaffyAdapter → BgzipTaffyAdapter}/index.ts +5 -4
- package/src/BgzipTaffyAdapter/rowInstructions.ts +91 -0
- package/src/BgzipTaffyAdapter/types.ts +16 -0
- package/src/BgzipTaffyAdapter/virtualOffset.ts +29 -0
- package/src/BigMafAdapter/BigMafAdapter.ts +11 -11
- package/src/BigMafAdapter/configSchema.ts +11 -0
- package/src/BigMafAdapter/index.ts +2 -1
- package/src/LinearMafDisplay/components/ColorLegend.tsx +36 -25
- package/src/LinearMafDisplay/components/ReactComponent.tsx +68 -3
- package/src/LinearMafDisplay/components/SetRowHeight.tsx +6 -5
- package/src/LinearMafDisplay/components/SvgWrapper.tsx +39 -0
- package/src/LinearMafDisplay/components/Tree.tsx +33 -0
- package/src/LinearMafDisplay/components/YScaleBars.tsx +8 -43
- package/src/LinearMafDisplay/components/util.ts +7 -0
- package/src/LinearMafDisplay/index.ts +2 -1
- package/src/LinearMafDisplay/renderSvg.tsx +2 -1
- package/src/LinearMafDisplay/stateModel.ts +139 -18
- package/src/LinearMafDisplay/types.ts +41 -0
- package/src/LinearMafRenderer/LinearMafRenderer.ts +13 -10
- package/src/LinearMafRenderer/components/ReactComponent.tsx +2 -1
- package/src/LinearMafRenderer/index.ts +2 -1
- package/src/MafAddTrackWorkflow/AddTrackWorkflow.tsx +109 -65
- package/src/MafRPC/index.ts +39 -0
- package/src/MafTabixAdapter/MafTabixAdapter.ts +31 -25
- package/src/MafTabixAdapter/configSchema.ts +17 -1
- package/src/MafTabixAdapter/index.ts +2 -1
- package/src/MafTrack/index.ts +1 -0
- package/src/index.ts +6 -4
- package/src/parseNewick.ts +94 -0
- package/src/util.ts +11 -0
- package/LICENSE +0 -201
- package/dist/TaffyAdapter/TaffyAdapter.js +0 -89
- package/dist/TaffyAdapter/TaffyAdapter.js.map +0 -1
- package/dist/TaffyAdapter/configSchema.js.map +0 -1
- package/dist/TaffyAdapter/index.d.ts +0 -2
- package/dist/TaffyAdapter/index.js +0 -11
- package/dist/TaffyAdapter/index.js.map +0 -1
- package/src/TaffyAdapter/TaffyAdapter.ts +0 -112
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BigMafAdapter.js","sourceRoot":"","sources":["../../src/BigMafAdapter/BigMafAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,yCAAyC,CAAA;AAChF,OAAO,
|
|
1
|
+
{"version":3,"file":"BigMafAdapter.js","sourceRoot":"","sources":["../../src/BigMafAdapter/BigMafAdapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -17,5 +17,16 @@ declare const configSchema: import("@jbrowse/core/configuration/configurationSch
|
|
|
17
17
|
locationType: string;
|
|
18
18
|
};
|
|
19
19
|
};
|
|
20
|
+
/**
|
|
21
|
+
* #slot
|
|
22
|
+
*/
|
|
23
|
+
nhLocation: {
|
|
24
|
+
type: string;
|
|
25
|
+
description: string;
|
|
26
|
+
defaultValue: {
|
|
27
|
+
uri: string;
|
|
28
|
+
locationType: string;
|
|
29
|
+
};
|
|
30
|
+
};
|
|
20
31
|
}, import("@jbrowse/core/configuration/configurationSchema").ConfigurationSchemaOptions<undefined, undefined>>;
|
|
21
32
|
export default configSchema;
|
|
@@ -23,6 +23,17 @@ const configSchema = ConfigurationSchema('BigMafAdapter', {
|
|
|
23
23
|
locationType: 'UriLocation',
|
|
24
24
|
},
|
|
25
25
|
},
|
|
26
|
+
/**
|
|
27
|
+
* #slot
|
|
28
|
+
*/
|
|
29
|
+
nhLocation: {
|
|
30
|
+
type: 'fileLocation',
|
|
31
|
+
description: 'newick tree',
|
|
32
|
+
defaultValue: {
|
|
33
|
+
uri: '/path/to/my.nh',
|
|
34
|
+
locationType: 'UriLocation',
|
|
35
|
+
},
|
|
36
|
+
},
|
|
26
37
|
}, { explicitlyTyped: true });
|
|
27
38
|
export default configSchema;
|
|
28
39
|
//# sourceMappingURL=configSchema.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/BigMafAdapter/configSchema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AAEjE;;;GAGG;AACH,SAAS,CAAC,KAAI,CAAC,CAAC,wDAAwD;AAExE,MAAM,YAAY,GAAG,mBAAmB,CACtC,eAAe,EACf;IACE;;OAEG;IACH,OAAO,EAAE;QACP,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,sDAAsD;QACnE,YAAY,EAAE,EAAE;KACjB;IACD;;OAEG;IACH,cAAc,EAAE;QACd,IAAI,EAAE,cAAc;QACpB,YAAY,EAAE;YACZ,GAAG,EAAE,gBAAgB;YACrB,YAAY,EAAE,aAAa;SAC5B;KACF;CACF,EACD,EAAE,eAAe,EAAE,IAAI,EAAE,CAC1B,CAAA;AAED,eAAe,YAAY,CAAA"}
|
|
1
|
+
{"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/BigMafAdapter/configSchema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AAEjE;;;GAGG;AACH,SAAS,CAAC,KAAI,CAAC,CAAC,wDAAwD;AAExE,MAAM,YAAY,GAAG,mBAAmB,CACtC,eAAe,EACf;IACE;;OAEG;IACH,OAAO,EAAE;QACP,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,sDAAsD;QACnE,YAAY,EAAE,EAAE;KACjB;IACD;;OAEG;IACH,cAAc,EAAE;QACd,IAAI,EAAE,cAAc;QACpB,YAAY,EAAE;YACZ,GAAG,EAAE,gBAAgB;YACrB,YAAY,EAAE,aAAa;SAC5B;KACF;IACD;;OAEG;IACH,UAAU,EAAE;QACV,IAAI,EAAE,cAAc;QACpB,WAAW,EAAE,aAAa;QAC1B,YAAY,EAAE;YACZ,GAAG,EAAE,gBAAgB;YACrB,YAAY,EAAE,aAAa;SAC5B;KACF;CACF,EACD,EAAE,eAAe,EAAE,IAAI,EAAE,CAC1B,CAAA;AAED,eAAe,YAAY,CAAA"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { AdapterType } from '@jbrowse/core/pluggableElementTypes';
|
|
2
|
-
import configSchema from './configSchema';
|
|
3
2
|
import BigMafAdapter from './BigMafAdapter';
|
|
3
|
+
import configSchema from './configSchema';
|
|
4
4
|
export default function BigMafAdapterF(pluginManager) {
|
|
5
5
|
return pluginManager.addAdapterType(() => new AdapterType({
|
|
6
6
|
name: 'BigMafAdapter',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/BigMafAdapter/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAA;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/BigMafAdapter/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAA;AAEjE,OAAO,aAAa,MAAM,iBAAiB,CAAA;AAC3C,OAAO,YAAY,MAAM,gBAAgB,CAAA;AAEzC,MAAM,CAAC,OAAO,UAAU,cAAc,CAAC,aAA4B;IACjE,OAAO,aAAa,CAAC,cAAc,CACjC,GAAG,EAAE,CACH,IAAI,WAAW,CAAC;QACd,IAAI,EAAE,eAAe;QACrB,YAAY,EAAE,aAAa;QAC3B,YAAY;KACb,CAAC,CACL,CAAA;AACH,CAAC"}
|
|
@@ -1,15 +1,19 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { observer } from 'mobx-react';
|
|
3
3
|
import RectBg from './RectBg';
|
|
4
|
+
import Tree from './Tree';
|
|
4
5
|
const ColorLegend = observer(function ({ model, labelWidth, svgFontSize, }) {
|
|
5
|
-
const { samples, rowHeight } = model;
|
|
6
|
-
const canDisplayLabel = rowHeight >=
|
|
6
|
+
const { totalHeight, treeWidth, samples, rowHeight } = model;
|
|
7
|
+
const canDisplayLabel = rowHeight >= 8;
|
|
7
8
|
const boxHeight = Math.min(20, rowHeight);
|
|
8
9
|
return (React.createElement(React.Fragment, null,
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
:
|
|
10
|
+
React.createElement(RectBg, { y: 0, x: 0, width: labelWidth + 5 + treeWidth, height: totalHeight }),
|
|
11
|
+
React.createElement(Tree, { model: model }),
|
|
12
|
+
React.createElement("g", { transform: `translate(${treeWidth + 5},0)` },
|
|
13
|
+
samples.map((sample, idx) => (React.createElement(RectBg, { key: `${sample.id}-${idx}`, y: idx * rowHeight, x: 0, width: labelWidth + 5, height: boxHeight, color: sample.color }))),
|
|
14
|
+
canDisplayLabel
|
|
15
|
+
? samples.map((sample, idx) => (React.createElement("text", { key: `${sample.id}-${idx}`, y: idx * rowHeight + rowHeight / 2, dominantBaseline: "middle", x: 2, fontSize: svgFontSize }, sample.label)))
|
|
16
|
+
: null)));
|
|
13
17
|
});
|
|
14
18
|
export default ColorLegend;
|
|
15
19
|
//# sourceMappingURL=ColorLegend.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ColorLegend.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/ColorLegend.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;
|
|
1
|
+
{"version":3,"file":"ColorLegend.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/ColorLegend.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAIrC,OAAO,MAAM,MAAM,UAAU,CAAA;AAC7B,OAAO,IAAI,MAAM,QAAQ,CAAA;AAEzB,MAAM,WAAW,GAAG,QAAQ,CAAC,UAAU,EACrC,KAAK,EACL,UAAU,EACV,WAAW,GAKZ;IACC,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,KAAK,CAAA;IAC5D,MAAM,eAAe,GAAG,SAAS,IAAI,CAAC,CAAA;IACtC,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,SAAS,CAAC,CAAA;IAEzC,OAAO,CACL;QACE,oBAAC,MAAM,IACL,CAAC,EAAE,CAAC,EACJ,CAAC,EAAE,CAAC,EACJ,KAAK,EAAE,UAAU,GAAG,CAAC,GAAG,SAAS,EACjC,MAAM,EAAE,WAAW,GACnB;QACF,oBAAC,IAAI,IAAC,KAAK,EAAE,KAAK,GAAI;QACtB,2BAAG,SAAS,EAAE,aAAa,SAAS,GAAG,CAAC,KAAK;YAC1C,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE,CAAC,CAC5B,oBAAC,MAAM,IACL,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,IAAI,GAAG,EAAE,EAC1B,CAAC,EAAE,GAAG,GAAG,SAAS,EAClB,CAAC,EAAE,CAAC,EACJ,KAAK,EAAE,UAAU,GAAG,CAAC,EACrB,MAAM,EAAE,SAAS,EACjB,KAAK,EAAE,MAAM,CAAC,KAAK,GACnB,CACH,CAAC;YACD,eAAe;gBACd,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE,CAAC,CAC3B,8BACE,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,IAAI,GAAG,EAAE,EAC1B,CAAC,EAAE,GAAG,GAAG,SAAS,GAAG,SAAS,GAAG,CAAC,EAClC,gBAAgB,EAAC,QAAQ,EACzB,CAAC,EAAE,CAAC,EACJ,QAAQ,EAAE,WAAW,IAEpB,MAAM,CAAC,KAAK,CACR,CACR,CAAC;gBACJ,CAAC,CAAC,IAAI,CACN,CACH,CACJ,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,WAAW,CAAA"}
|
|
@@ -1,15 +1,50 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import
|
|
1
|
+
import React, { useRef, useState } from 'react';
|
|
2
|
+
import BaseTooltip from '@jbrowse/core/ui/BaseTooltip';
|
|
3
|
+
import SanitizedHTML from '@jbrowse/core/ui/SanitizedHTML';
|
|
4
|
+
import { getContainingView, getEnv } from '@jbrowse/core/util';
|
|
3
5
|
import { observer } from 'mobx-react';
|
|
6
|
+
import { makeStyles } from 'tss-react/mui';
|
|
4
7
|
import YScaleBars from './YScaleBars';
|
|
8
|
+
const useStyles = makeStyles()({
|
|
9
|
+
cursor: {
|
|
10
|
+
pointerEvents: 'none',
|
|
11
|
+
},
|
|
12
|
+
});
|
|
5
13
|
const LinearMafDisplay = observer(function (props) {
|
|
6
14
|
const { model } = props;
|
|
15
|
+
const { classes } = useStyles();
|
|
7
16
|
const { pluginManager } = getEnv(model);
|
|
17
|
+
const { rowHeight, height, scrollTop, samples: sources } = model;
|
|
18
|
+
const ref = useRef(null);
|
|
8
19
|
const LinearGenomePlugin = pluginManager.getPlugin('LinearGenomeViewPlugin');
|
|
9
20
|
const { BaseLinearDisplayComponent } = LinearGenomePlugin.exports;
|
|
10
|
-
|
|
21
|
+
const [mouseY, setMouseY] = useState();
|
|
22
|
+
const [mouseX, setMouseX] = useState();
|
|
23
|
+
const { width } = getContainingView(model);
|
|
24
|
+
return (React.createElement("div", { ref: ref, onMouseMove: event => {
|
|
25
|
+
const rect = ref.current?.getBoundingClientRect();
|
|
26
|
+
const top = rect?.top || 0;
|
|
27
|
+
const left = rect?.left || 0;
|
|
28
|
+
setMouseY(event.clientY - top);
|
|
29
|
+
setMouseX(event.clientX - left);
|
|
30
|
+
}, onMouseLeave: () => {
|
|
31
|
+
setMouseY(undefined);
|
|
32
|
+
setMouseX(undefined);
|
|
33
|
+
} },
|
|
11
34
|
React.createElement(BaseLinearDisplayComponent, { ...props }),
|
|
12
|
-
React.createElement(YScaleBars, { model: model })
|
|
35
|
+
React.createElement(YScaleBars, { model: model }),
|
|
36
|
+
mouseY ? (React.createElement("div", { style: { position: 'relative' } },
|
|
37
|
+
React.createElement("svg", { className: classes.cursor, width: width, height: height, style: {
|
|
38
|
+
position: 'absolute',
|
|
39
|
+
top: scrollTop,
|
|
40
|
+
} },
|
|
41
|
+
React.createElement("line", { x1: 0, x2: width, y1: mouseY - scrollTop, y2: mouseY - scrollTop, stroke: "black" }),
|
|
42
|
+
React.createElement("line", { x1: mouseX, x2: mouseX, y1: 0, y2: height, stroke: "black" })),
|
|
43
|
+
React.createElement(BaseTooltip, null,
|
|
44
|
+
React.createElement(SanitizedHTML, { html: Object.entries(sources[Math.floor(mouseY / rowHeight)] || {})
|
|
45
|
+
.filter(([key]) => key !== 'color' && key !== 'id')
|
|
46
|
+
.map(([key, value]) => `${key}:${value}`)
|
|
47
|
+
.join('\n') })))) : null));
|
|
13
48
|
});
|
|
14
49
|
export default LinearMafDisplay;
|
|
15
50
|
//# sourceMappingURL=ReactComponent.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ReactComponent.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/ReactComponent.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;
|
|
1
|
+
{"version":3,"file":"ReactComponent.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/ReactComponent.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import React, { useState } from 'react';
|
|
2
|
-
import { observer } from 'mobx-react';
|
|
3
|
-
import { Button, DialogActions, DialogContent, TextField, Typography, } from '@mui/material';
|
|
4
2
|
import { Dialog } from '@jbrowse/core/ui';
|
|
3
|
+
import { Button, DialogActions, DialogContent, TextField, Typography, } from '@mui/material';
|
|
4
|
+
import { observer } from 'mobx-react';
|
|
5
5
|
import { makeStyles } from 'tss-react/mui';
|
|
6
6
|
const useStyles = makeStyles()({
|
|
7
7
|
root: {
|
|
@@ -13,15 +13,15 @@ const SetRowHeightDialog = observer(function (props) {
|
|
|
13
13
|
const { classes } = useStyles();
|
|
14
14
|
const [rowHeight, setRowHeight] = useState(`${model.rowHeight}`);
|
|
15
15
|
const [rowProportion, setRowProportion] = useState(`${model.rowProportion}`);
|
|
16
|
-
return (React.createElement(Dialog, { open: true, onClose: handleClose, title: "
|
|
16
|
+
return (React.createElement(Dialog, { open: true, onClose: handleClose, title: "Set row height" },
|
|
17
17
|
React.createElement(DialogContent, { className: classes.root },
|
|
18
18
|
React.createElement(Typography, null, "Set row height and the proportion of the row height to use for drawing each row"),
|
|
19
|
-
React.createElement(TextField, { value: rowHeight, onChange: event => {
|
|
19
|
+
React.createElement(TextField, { value: rowHeight, helperText: "Enter row height", onChange: event => {
|
|
20
20
|
setRowHeight(event.target.value);
|
|
21
|
-
}
|
|
22
|
-
React.createElement(TextField, { value: rowProportion, onChange: event => {
|
|
21
|
+
} }),
|
|
22
|
+
React.createElement(TextField, { value: rowProportion, helperText: "Enter row proportion", onChange: event => {
|
|
23
23
|
setRowProportion(event.target.value);
|
|
24
|
-
}
|
|
24
|
+
} }),
|
|
25
25
|
React.createElement(DialogActions, null,
|
|
26
26
|
React.createElement(Button, { variant: "contained", color: "primary", type: "submit", autoFocus: true, onClick: () => {
|
|
27
27
|
model.setRowProportion(+rowProportion);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SetRowHeight.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/SetRowHeight.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;
|
|
1
|
+
{"version":3,"file":"SetRowHeight.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/SetRowHeight.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEvC,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AACzC,OAAO,EACL,MAAM,EACN,aAAa,EACb,aAAa,EACb,SAAS,EACT,UAAU,GACX,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAE1C,MAAM,SAAS,GAAG,UAAU,EAAE,CAAC;IAC7B,IAAI,EAAE;QACJ,KAAK,EAAE,GAAG;KACX;CACF,CAAC,CAAA;AAEF,MAAM,kBAAkB,GAAG,QAAQ,CAAC,UAAU,KAQ7C;IACC,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,GAAG,KAAK,CAAA;IACpC,MAAM,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,CAAA;IAC/B,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC,CAAA;IAChE,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAC,GAAG,KAAK,CAAC,aAAa,EAAE,CAAC,CAAA;IAE5E,OAAO,CACL,oBAAC,MAAM,IAAC,IAAI,QAAC,OAAO,EAAE,WAAW,EAAE,KAAK,EAAC,gBAAgB;QACvD,oBAAC,aAAa,IAAC,SAAS,EAAE,OAAO,CAAC,IAAI;YACpC,oBAAC,UAAU,0FAGE;YACb,oBAAC,SAAS,IACR,KAAK,EAAE,SAAS,EAChB,UAAU,EAAC,kBAAkB,EAC7B,QAAQ,EAAE,KAAK,CAAC,EAAE;oBAChB,YAAY,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;gBAClC,CAAC,GACD;YACF,oBAAC,SAAS,IACR,KAAK,EAAE,aAAa,EACpB,UAAU,EAAC,sBAAsB,EACjC,QAAQ,EAAE,KAAK,CAAC,EAAE;oBAChB,gBAAgB,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;gBACtC,CAAC,GACD;YACF,oBAAC,aAAa;gBACZ,oBAAC,MAAM,IACL,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,SAAS,EACf,IAAI,EAAC,QAAQ,EACb,SAAS,QACT,OAAO,EAAE,GAAG,EAAE;wBACZ,KAAK,CAAC,gBAAgB,CAAC,CAAC,aAAa,CAAC,CAAA;wBACtC,KAAK,CAAC,YAAY,CAAC,CAAC,SAAS,CAAC,CAAA;wBAC9B,WAAW,EAAE,CAAA;oBACf,CAAC,aAGM;gBACT,oBAAC,MAAM,IACL,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,WAAW,EACjB,OAAO,EAAE,GAAG,EAAE;wBACZ,WAAW,EAAE,CAAA;oBACf,CAAC,aAGM,CACK,CACF,CACT,CACV,CAAA;AACH,CAAC,CAAC,CAAA;AACF,eAAe,kBAAkB,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { LinearMafDisplayModel } from '../stateModel';
|
|
3
|
+
declare const SvgWrapper: ({ children, model, exportSVG, }: {
|
|
4
|
+
model: LinearMafDisplayModel;
|
|
5
|
+
children: React.ReactNode;
|
|
6
|
+
exportSVG?: boolean;
|
|
7
|
+
}) => React.JSX.Element;
|
|
8
|
+
export default SvgWrapper;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { getContainingView } from '@jbrowse/core/util';
|
|
3
|
+
import { observer } from 'mobx-react';
|
|
4
|
+
const SvgWrapper = observer(function ({ children, model, exportSVG, }) {
|
|
5
|
+
if (exportSVG) {
|
|
6
|
+
return React.createElement(React.Fragment, null, children);
|
|
7
|
+
}
|
|
8
|
+
else {
|
|
9
|
+
const { rowHeight, samples } = model;
|
|
10
|
+
return (React.createElement("svg", { style: {
|
|
11
|
+
position: 'absolute',
|
|
12
|
+
top: 0,
|
|
13
|
+
left: 0,
|
|
14
|
+
pointerEvents: 'none',
|
|
15
|
+
height: samples.length * rowHeight,
|
|
16
|
+
width: getContainingView(model).width,
|
|
17
|
+
} }, children));
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
export default SvgWrapper;
|
|
21
|
+
//# sourceMappingURL=SvgWrapper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SvgWrapper.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/SvgWrapper.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAA;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAKrC,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,EACpC,QAAQ,EACR,KAAK,EACL,SAAS,GAKV;IACC,IAAI,SAAS,EAAE,CAAC;QACd,OAAO,0CAAG,QAAQ,CAAI,CAAA;IACxB,CAAC;SAAM,CAAC;QACN,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,KAAK,CAAA;QACpC,OAAO,CACL,6BACE,KAAK,EAAE;gBACL,QAAQ,EAAE,UAAU;gBACpB,GAAG,EAAE,CAAC;gBACN,IAAI,EAAE,CAAC;gBACP,aAAa,EAAE,MAAM;gBACrB,MAAM,EAAE,OAAO,CAAC,MAAM,GAAG,SAAS;gBAClC,KAAK,EAAE,iBAAiB,CAAC,KAAK,CAAC,CAAC,KAAK;aACtC,IAEA,QAAQ,CACL,CACP,CAAA;IACH,CAAC;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,UAAU,CAAA"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { observer } from 'mobx-react';
|
|
3
|
+
const Tree = observer(function ({ model }) {
|
|
4
|
+
const { hierarchy, showBranchLen } = model;
|
|
5
|
+
return (React.createElement(React.Fragment, null, hierarchy
|
|
6
|
+
? [...hierarchy.links()].map(link => {
|
|
7
|
+
const { source, target } = link;
|
|
8
|
+
const sy = source.x;
|
|
9
|
+
const ty = target.x;
|
|
10
|
+
const tx = showBranchLen ? target.len : target.y;
|
|
11
|
+
const sx = showBranchLen ? source.len : source.y;
|
|
12
|
+
// 1d line intersection to check if line crosses block at all, this is
|
|
13
|
+
// an optimization that allows us to skip drawing most tree links
|
|
14
|
+
// outside the block
|
|
15
|
+
return (React.createElement(React.Fragment, { key: [sy, ty, tx, sx].join('-') },
|
|
16
|
+
React.createElement("line", { stroke: "black", x1: sx, y1: sy, x2: sx, y2: ty }),
|
|
17
|
+
React.createElement("line", { stroke: "black", x1: sx, y1: ty, x2: tx, y2: ty })));
|
|
18
|
+
})
|
|
19
|
+
: null));
|
|
20
|
+
});
|
|
21
|
+
export default Tree;
|
|
22
|
+
//# sourceMappingURL=Tree.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Tree.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/Tree.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,MAAM,IAAI,GAAG,QAAQ,CAAC,UAAU,EAAE,KAAK,EAAkB;IACvD,MAAM,EAAE,SAAS,EAAE,aAAa,EAAE,GAAG,KAAK,CAAA;IAE1C,OAAO,CACL,0CACG,SAAS;QACR,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;YAChC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAA;YAC/B,MAAM,EAAE,GAAG,MAAM,CAAC,CAAE,CAAA;YACpB,MAAM,EAAE,GAAG,MAAM,CAAC,CAAE,CAAA;YACpB,MAAM,EAAE,GAAG,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAA;YAChD,MAAM,EAAE,GAAG,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAA;YAEhD,sEAAsE;YACtE,iEAAiE;YACjE,oBAAoB;YACpB,OAAO,CACL,oBAAC,KAAK,CAAC,QAAQ,IAAC,GAAG,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;gBAC7C,8BAAM,MAAM,EAAC,OAAO,EAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAI;gBACvD,8BAAM,MAAM,EAAC,OAAO,EAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAI,CACxC,CAClB,CAAA;QACH,CAAC,CAAC;QACJ,CAAC,CAAC,IAAI,CACP,CACJ,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,IAAI,CAAA"}
|
|
@@ -1,40 +1,19 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import { measureText
|
|
2
|
+
import { measureText } from '@jbrowse/core/util';
|
|
3
3
|
import { observer } from 'mobx-react';
|
|
4
4
|
import ColorLegend from './ColorLegend';
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
return React.createElement(React.Fragment, null, children);
|
|
8
|
-
}
|
|
9
|
-
else {
|
|
10
|
-
const { rowHeight, samples } = model;
|
|
11
|
-
return (React.createElement("svg", { style: {
|
|
12
|
-
position: 'absolute',
|
|
13
|
-
top: 0,
|
|
14
|
-
left: 0,
|
|
15
|
-
pointerEvents: 'none',
|
|
16
|
-
height: samples.length * rowHeight,
|
|
17
|
-
width: getContainingView(model).width,
|
|
18
|
-
} }, children));
|
|
19
|
-
}
|
|
20
|
-
});
|
|
21
|
-
export function max(arr, init = Number.NEGATIVE_INFINITY) {
|
|
22
|
-
let max = init;
|
|
23
|
-
for (const entry of arr) {
|
|
24
|
-
max = Math.max(entry, max);
|
|
25
|
-
}
|
|
26
|
-
return max;
|
|
27
|
-
}
|
|
5
|
+
import SvgWrapper from './SvgWrapper';
|
|
6
|
+
import { max } from './util';
|
|
28
7
|
export const YScaleBars = observer(function (props) {
|
|
29
8
|
const { model } = props;
|
|
30
9
|
const { rowHeight, samples } = model;
|
|
31
|
-
const svgFontSize = Math.min(Math.max(rowHeight,
|
|
32
|
-
const canDisplayLabel = rowHeight >=
|
|
10
|
+
const svgFontSize = Math.min(Math.max(rowHeight, 8), 14);
|
|
11
|
+
const canDisplayLabel = rowHeight >= 8;
|
|
33
12
|
const minWidth = 20;
|
|
34
13
|
const labelWidth = max(samples
|
|
35
14
|
.map(s => measureText(s.label, svgFontSize))
|
|
36
15
|
.map(width => (canDisplayLabel ? width : minWidth)));
|
|
37
|
-
return (React.createElement(
|
|
16
|
+
return (React.createElement(SvgWrapper, { ...props },
|
|
38
17
|
React.createElement(ColorLegend, { model: model, labelWidth: labelWidth, svgFontSize: svgFontSize })));
|
|
39
18
|
});
|
|
40
19
|
export default YScaleBars;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"YScaleBars.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/YScaleBars.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;
|
|
1
|
+
{"version":3,"file":"YScaleBars.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/YScaleBars.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAA;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAIrC,OAAO,WAAW,MAAM,eAAe,CAAA;AACvC,OAAO,UAAU,MAAM,cAAc,CAAA;AACrC,OAAO,EAAE,GAAG,EAAE,MAAM,QAAQ,CAAA;AAE5B,MAAM,CAAC,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,KAI5C;IACC,MAAM,EAAE,KAAK,EAAE,GAAG,KAAK,CAAA;IACvB,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,KAAK,CAAA;IACpC,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAA;IACxD,MAAM,eAAe,GAAG,SAAS,IAAI,CAAC,CAAA;IACtC,MAAM,QAAQ,GAAG,EAAE,CAAA;IAEnB,MAAM,UAAU,GAAG,GAAG,CACpB,OAAO;SACJ,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;SAC3C,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CACtD,CAAA;IAED,OAAO,CACL,oBAAC,UAAU,OAAK,KAAK;QACnB,oBAAC,WAAW,IACV,KAAK,EAAE,KAAK,EACZ,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,WAAW,GACxB,CACS,CACd,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,UAAU,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function max(arr: number[], init?: number): number;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/util.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,GAAG,CAAC,GAAa,EAAE,IAAI,GAAG,MAAM,CAAC,iBAAiB;IAChE,IAAI,GAAG,GAAG,IAAI,CAAA;IACd,KAAK,MAAM,KAAK,IAAI,GAAG,EAAE,CAAC;QACxB,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,GAAG,CAAC,CAAA;IAC5B,CAAC;IACD,OAAO,GAAG,CAAA;AACZ,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { DisplayType } from '@jbrowse/core/pluggableElementTypes';
|
|
2
|
+
import ReactComponent from './components/ReactComponent';
|
|
2
3
|
import configSchemaF from './configSchema';
|
|
3
4
|
import stateModelFactory from './stateModel';
|
|
4
|
-
import ReactComponent from './components/ReactComponent';
|
|
5
5
|
export default function LinearMafDisplayF(pluginManager) {
|
|
6
6
|
pluginManager.addDisplayType(() => {
|
|
7
7
|
const configSchema = configSchemaF(pluginManager);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/LinearMafDisplay/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAA;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/LinearMafDisplay/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAA;AAEjE,OAAO,cAAc,MAAM,6BAA6B,CAAA;AACxD,OAAO,aAAa,MAAM,gBAAgB,CAAA;AAC1C,OAAO,iBAAiB,MAAM,cAAc,CAAA;AAE5C,MAAM,CAAC,OAAO,UAAU,iBAAiB,CAAC,aAA4B;IACpE,aAAa,CAAC,cAAc,CAAC,GAAG,EAAE;QAChC,MAAM,YAAY,GAAG,aAAa,CAAC,aAAa,CAAC,CAAA;QACjD,MAAM,UAAU,GAAG,iBAAiB,CAAC,YAAY,EAAE,aAAa,CAAC,CAAA;QACjE,OAAO,IAAI,WAAW,CAAC;YACrB,IAAI,EAAE,kBAAkB;YACxB,YAAY;YACZ,UAAU;YACV,cAAc;YACd,QAAQ,EAAE,kBAAkB;YAC5B,SAAS,EAAE,UAAU;YACrB,WAAW,EAAE,aAAa;SAC3B,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"renderSvg.js","sourceRoot":"","sources":["../../src/LinearMafDisplay/renderSvg.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;
|
|
1
|
+
{"version":3,"file":"renderSvg.js","sourceRoot":"","sources":["../../src/LinearMafDisplay/renderSvg.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAA;AAMtD,SAAS;AACT,OAAO,UAAU,MAAM,yBAAyB,CAAA;AAGhD,MAAM,CAAC,KAAK,UAAU,SAAS,CAC7B,IAA2B,EAC3B,IAA6B,EAC7B,cAA2E;IAE3E,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,GAAG,IAAI,CAAA;IAC3B,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,iBAAiB,CAAC,IAAI,CAA0B,CAAA;IAC5E,MAAM,MAAM,GAAG,WAAW,EAAE,EAAE,CAAA;IAC9B,OAAO,CACL;QACE;YACE,kCAAU,EAAE,EAAE,MAAM;gBAClB,8BAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,GAAI,CACzC,CACN;QACP,2BAAG,QAAQ,EAAE,QAAQ,MAAM,GAAG;YAC5B,2BAAG,EAAE,EAAC,QAAQ,IAAE,MAAM,cAAc,CAAC,IAAI,CAAC,CAAK;YAC/C,2BAAG,SAAS,EAAE,aAAa,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,GAAG;gBAClD,oBAAC,UAAU,IAAC,KAAK,EAAE,IAAI,EAAE,WAAW,EAAC,MAAM,EAAC,SAAS,SAAG,CACtD,CACF,CACH,CACJ,CAAA;AACH,CAAC"}
|
|
@@ -1,7 +1,14 @@
|
|
|
1
|
-
import { Instance } from 'mobx-state-tree';
|
|
2
|
-
import { AnyConfigurationModel, AnyConfigurationSchemaType } from '@jbrowse/core/configuration';
|
|
3
1
|
import PluginManager from '@jbrowse/core/PluginManager';
|
|
2
|
+
import { AnyConfigurationModel, AnyConfigurationSchemaType } from '@jbrowse/core/configuration';
|
|
4
3
|
import { ExportSvgDisplayOptions } from '@jbrowse/plugin-linear-genome-view';
|
|
4
|
+
import { type HierarchyNode } from 'd3-hierarchy';
|
|
5
|
+
import { Instance } from 'mobx-state-tree';
|
|
6
|
+
import { NodeWithIdsAndLength } from './types';
|
|
7
|
+
interface Sample {
|
|
8
|
+
id: string;
|
|
9
|
+
label: string;
|
|
10
|
+
color?: string;
|
|
11
|
+
}
|
|
5
12
|
/**
|
|
6
13
|
* #stateModel LinearMafDisplay
|
|
7
14
|
* extends LinearBasicDisplay
|
|
@@ -18,7 +25,9 @@ export default function stateModelFactory(configSchema: AnyConfigurationSchemaTy
|
|
|
18
25
|
} & {
|
|
19
26
|
blockState: import("mobx-state-tree").IMapType<import("mobx-state-tree").IModelType<{
|
|
20
27
|
key: import("mobx-state-tree").ISimpleType<string>;
|
|
21
|
-
region: import("mobx-state-tree"
|
|
28
|
+
region: import("mobx-state-tree" /**
|
|
29
|
+
* #property
|
|
30
|
+
*/).IType<import("@jbrowse/core/util").Region, import("@jbrowse/core/util").Region, import("@jbrowse/core/util").Region>;
|
|
22
31
|
reloadFlag: import("mobx-state-tree").IType<number | undefined, number, number>;
|
|
23
32
|
isLeftEndOfDisplayedRegion: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
|
|
24
33
|
isRightEndOfDisplayedRegion: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
|
|
@@ -41,7 +50,7 @@ export default function stateModelFactory(configSchema: AnyConfigurationSchemaTy
|
|
|
41
50
|
status?: string;
|
|
42
51
|
reactElement?: React.ReactElement;
|
|
43
52
|
};
|
|
44
|
-
}) => import("react").JSX.Element | undefined;
|
|
53
|
+
}) => import("react/jsx-runtime").JSX.Element | undefined;
|
|
45
54
|
renderProps: any;
|
|
46
55
|
} & {
|
|
47
56
|
doReload(): void;
|
|
@@ -49,7 +58,9 @@ export default function stateModelFactory(configSchema: AnyConfigurationSchemaTy
|
|
|
49
58
|
setStatus(message: string): void;
|
|
50
59
|
setLoading(newStopToken: string): void;
|
|
51
60
|
setMessage(messageText: string): void;
|
|
52
|
-
setRendered(props: import("@jbrowse/plugin-linear-genome-view/dist/BaseLinearDisplay/models/serverSideRenderedBlock"
|
|
61
|
+
setRendered(props: import("@jbrowse/plugin-linear-genome-view/dist/BaseLinearDisplay/models/serverSideRenderedBlock" /**
|
|
62
|
+
* #getter
|
|
63
|
+
*/).RenderedProps | undefined): void;
|
|
53
64
|
setError(error: unknown): void;
|
|
54
65
|
reload(): void;
|
|
55
66
|
beforeDestroy(): void;
|
|
@@ -89,6 +100,8 @@ export default function stateModelFactory(configSchema: AnyConfigurationSchemaTy
|
|
|
89
100
|
rowProportion: import("mobx-state-tree").IType<number | undefined, number, number>;
|
|
90
101
|
showAllLetters: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
|
|
91
102
|
mismatchRendering: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
|
|
103
|
+
showBranchLen: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
|
|
104
|
+
treeAreaWidth: import("mobx-state-tree").IType<number | undefined, number, number>;
|
|
92
105
|
}, {
|
|
93
106
|
rendererTypeName: string;
|
|
94
107
|
error: unknown;
|
|
@@ -104,7 +117,9 @@ export default function stateModelFactory(configSchema: AnyConfigurationSchemaTy
|
|
|
104
117
|
error: unknown;
|
|
105
118
|
message: string | undefined;
|
|
106
119
|
} & import("mobx-state-tree").IStateTreeNode<import("mobx-state-tree").IModelType<{
|
|
107
|
-
id: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree"
|
|
120
|
+
id: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree" /**
|
|
121
|
+
* #getter
|
|
122
|
+
*/).ISimpleType<string>, [undefined]>;
|
|
108
123
|
type: import("mobx-state-tree").ISimpleType<string>;
|
|
109
124
|
rpcDriverName: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<string>>;
|
|
110
125
|
}, {
|
|
@@ -115,7 +130,9 @@ export default function stateModelFactory(configSchema: AnyConfigurationSchemaTy
|
|
|
115
130
|
onHorizontalScroll?: () => void;
|
|
116
131
|
blockState?: Record<string, any>;
|
|
117
132
|
}>;
|
|
118
|
-
readonly DisplayBlurb: React.FC
|
|
133
|
+
readonly DisplayBlurb: React.FC /**
|
|
134
|
+
* #method
|
|
135
|
+
*/<{
|
|
119
136
|
model: {
|
|
120
137
|
id: string;
|
|
121
138
|
type: string;
|
|
@@ -180,13 +197,13 @@ export default function stateModelFactory(configSchema: AnyConfigurationSchemaTy
|
|
|
180
197
|
} & {
|
|
181
198
|
readonly statsReadyAndRegionNotTooLarge: boolean;
|
|
182
199
|
regionCannotBeRenderedText(_region: import("@jbrowse/core/util").Region): "" | "Force load to see features";
|
|
183
|
-
regionCannotBeRendered(_region: import("@jbrowse/core/util").Region): import("react").JSX.Element | null;
|
|
200
|
+
regionCannotBeRendered(_region: import("@jbrowse/core/util").Region): import("react/jsx-runtime").JSX.Element | null;
|
|
184
201
|
} & {
|
|
185
202
|
featureIdUnderMouse: undefined | string;
|
|
186
203
|
contextMenuFeature: undefined | import("@jbrowse/core/util").Feature;
|
|
187
204
|
} & {
|
|
188
|
-
readonly DisplayMessageComponent:
|
|
189
|
-
readonly blockType: "
|
|
205
|
+
readonly DisplayMessageComponent: undefined | React.FC<any>;
|
|
206
|
+
readonly blockType: "staticBlocks" | "dynamicBlocks";
|
|
190
207
|
readonly blockDefinitions: import("@jbrowse/core/util/blockTypes").BlockSet;
|
|
191
208
|
} & {
|
|
192
209
|
readonly renderDelay: number;
|
|
@@ -213,13 +230,21 @@ export default function stateModelFactory(configSchema: AnyConfigurationSchemaTy
|
|
|
213
230
|
contextMenuItems(): import("@jbrowse/core/ui").MenuItem[];
|
|
214
231
|
renderProps(): any;
|
|
215
232
|
} & {
|
|
216
|
-
renderSvg(opts: import("@jbrowse/plugin-linear-genome-view/dist/BaseLinearDisplay").ExportSvgDisplayOptions): Promise<import("react").JSX.Element>;
|
|
233
|
+
renderSvg(opts: import("@jbrowse/plugin-linear-genome-view/dist/BaseLinearDisplay").ExportSvgDisplayOptions): Promise<import("react/jsx-runtime").JSX.Element>;
|
|
217
234
|
afterAttach(): void;
|
|
218
235
|
} & {
|
|
219
236
|
/**
|
|
220
237
|
* #volatile
|
|
221
238
|
*/
|
|
222
239
|
prefersOffset: boolean;
|
|
240
|
+
/**
|
|
241
|
+
* #volatile
|
|
242
|
+
*/
|
|
243
|
+
volatileSamples: Sample[];
|
|
244
|
+
/**
|
|
245
|
+
* #volatile
|
|
246
|
+
*/
|
|
247
|
+
tree: any;
|
|
223
248
|
} & {
|
|
224
249
|
/**
|
|
225
250
|
* #action
|
|
@@ -237,7 +262,33 @@ export default function stateModelFactory(configSchema: AnyConfigurationSchemaTy
|
|
|
237
262
|
* #action
|
|
238
263
|
*/
|
|
239
264
|
setMismatchRendering(f: boolean): void;
|
|
265
|
+
/**
|
|
266
|
+
* #action
|
|
267
|
+
*/
|
|
268
|
+
setSamples({ samples, tree }: {
|
|
269
|
+
samples: Sample[];
|
|
270
|
+
tree: unknown;
|
|
271
|
+
}): void;
|
|
272
|
+
} & {
|
|
273
|
+
/**
|
|
274
|
+
* #getter
|
|
275
|
+
*/
|
|
276
|
+
readonly rendererTypeName: string;
|
|
277
|
+
/**
|
|
278
|
+
* #getter
|
|
279
|
+
*/
|
|
280
|
+
readonly rendererConfig: AnyConfigurationModel;
|
|
240
281
|
} & {
|
|
282
|
+
/**
|
|
283
|
+
* #getter
|
|
284
|
+
*/
|
|
285
|
+
readonly root: HierarchyNode<any> | undefined;
|
|
286
|
+
} & {
|
|
287
|
+
/**
|
|
288
|
+
* #getter
|
|
289
|
+
* generates a new tree that is clustered with x,y positions
|
|
290
|
+
*/
|
|
291
|
+
readonly hierarchy: HierarchyNode<NodeWithIdsAndLength> | undefined;
|
|
241
292
|
/**
|
|
242
293
|
* #getter
|
|
243
294
|
*/
|
|
@@ -249,12 +300,20 @@ export default function stateModelFactory(configSchema: AnyConfigurationSchemaTy
|
|
|
249
300
|
/**
|
|
250
301
|
* #getter
|
|
251
302
|
*/
|
|
252
|
-
readonly
|
|
303
|
+
readonly totalHeight: number;
|
|
253
304
|
/**
|
|
254
305
|
* #getter
|
|
255
306
|
*/
|
|
256
|
-
readonly
|
|
307
|
+
readonly leaves: HierarchyNode<any>[] | undefined;
|
|
308
|
+
/**
|
|
309
|
+
* #getter
|
|
310
|
+
*/
|
|
311
|
+
readonly rowNames: string[] | undefined;
|
|
257
312
|
} & {
|
|
313
|
+
/**
|
|
314
|
+
* #getter
|
|
315
|
+
*/
|
|
316
|
+
readonly treeWidth: number;
|
|
258
317
|
/**
|
|
259
318
|
* #method
|
|
260
319
|
*/
|
|
@@ -268,6 +327,8 @@ export default function stateModelFactory(configSchema: AnyConfigurationSchemaTy
|
|
|
268
327
|
checked: boolean;
|
|
269
328
|
onClick: () => void;
|
|
270
329
|
})[];
|
|
330
|
+
} & {
|
|
331
|
+
afterCreate(): void;
|
|
271
332
|
} & {
|
|
272
333
|
/**
|
|
273
334
|
* #action
|
|
@@ -310,7 +371,7 @@ export default function stateModelFactory(configSchema: AnyConfigurationSchemaTy
|
|
|
310
371
|
status?: string;
|
|
311
372
|
reactElement?: React.ReactElement;
|
|
312
373
|
};
|
|
313
|
-
}) => import("react").JSX.Element | undefined;
|
|
374
|
+
}) => import("react/jsx-runtime").JSX.Element | undefined;
|
|
314
375
|
renderProps: any;
|
|
315
376
|
} & {
|
|
316
377
|
doReload(): void;
|
|
@@ -362,3 +423,4 @@ export default function stateModelFactory(configSchema: AnyConfigurationSchemaTy
|
|
|
362
423
|
} & import("mobx-state-tree")._NotCustomized>;
|
|
363
424
|
export type LinearMafDisplayStateModel = ReturnType<typeof stateModelFactory>;
|
|
364
425
|
export type LinearMafDisplayModel = Instance<LinearMafDisplayStateModel>;
|
|
426
|
+
export {};
|