react-msaview 5.0.4 → 5.0.5
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/bundle/index.js +3 -3
- package/bundle/index.js.map +1 -1
- package/dist/components/ConservationTrack.js +9 -9
- package/dist/components/ConservationTrack.js.map +1 -1
- package/dist/components/MSAView.js +13 -6
- package/dist/components/MSAView.js.map +1 -1
- package/dist/components/TextTrack.js +12 -17
- package/dist/components/TextTrack.js.map +1 -1
- package/dist/components/msa/MSAMouseoverCanvas.js +2 -1
- package/dist/components/msa/MSAMouseoverCanvas.js.map +1 -1
- package/dist/components/msa/renderMSAMouseover.js +2 -1
- package/dist/components/msa/renderMSAMouseover.js.map +1 -1
- package/dist/components/tracks/renderTracksSvg.d.ts +19 -0
- package/dist/components/tracks/renderTracksSvg.js +48 -29
- package/dist/components/tracks/renderTracksSvg.js.map +1 -1
- package/dist/version.d.ts +1 -1
- package/dist/version.js +1 -1
- package/package.json +3 -3
- package/src/components/ConservationTrack.tsx +10 -11
- package/src/components/MSAView.tsx +17 -6
- package/src/components/TextTrack.tsx +12 -17
- package/src/components/msa/MSAMouseoverCanvas.tsx +2 -1
- package/src/components/msa/renderMSAMouseover.ts +3 -1
- package/src/components/tracks/renderTracksSvg.ts +86 -34
- package/src/version.ts +1 -1
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import React, { useEffect, useRef } from 'react';
|
|
2
2
|
import { observer } from 'mobx-react';
|
|
3
|
+
import { drawConservationBars } from "./tracks/renderTracksSvg.js";
|
|
3
4
|
const ConservationBlock = observer(function ({ model, offsetX, trackHeight, }) {
|
|
4
5
|
const { blockSize, scrollX, colWidth, highResScaleFactor, conservation } = model;
|
|
5
6
|
const ref = useRef(null);
|
|
@@ -15,15 +16,14 @@ const ConservationBlock = observer(function ({ model, offsetX, trackHeight, }) {
|
|
|
15
16
|
ctx.scale(highResScaleFactor, highResScaleFactor);
|
|
16
17
|
ctx.clearRect(0, 0, blockSize, trackHeight);
|
|
17
18
|
ctx.translate(-offsetX, 0);
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
}
|
|
19
|
+
drawConservationBars({
|
|
20
|
+
ctx,
|
|
21
|
+
conservation,
|
|
22
|
+
colWidth,
|
|
23
|
+
trackHeight,
|
|
24
|
+
offsetX,
|
|
25
|
+
blockSize,
|
|
26
|
+
});
|
|
27
27
|
}, [
|
|
28
28
|
blockSize,
|
|
29
29
|
colWidth,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ConservationTrack.js","sourceRoot":"","sources":["../../src/components/ConservationTrack.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,OAAO,CAAA;AAEhD,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;
|
|
1
|
+
{"version":3,"file":"ConservationTrack.js","sourceRoot":"","sources":["../../src/components/ConservationTrack.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,OAAO,CAAA;AAEhD,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAA;AAKlE,MAAM,iBAAiB,GAAG,QAAQ,CAAC,UAAU,EAC3C,KAAK,EACL,OAAO,EACP,WAAW,GAKZ;IACC,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,kBAAkB,EAAE,YAAY,EAAE,GACtE,KAAK,CAAA;IAEP,MAAM,GAAG,GAAG,MAAM,CAAoB,IAAI,CAAC,CAAA;IAE3C,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;YACjB,OAAM;QACR,CAAC;QAED,MAAM,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA;QACxC,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,OAAM;QACR,CAAC;QAED,GAAG,CAAC,cAAc,EAAE,CAAA;QACpB,GAAG,CAAC,KAAK,CAAC,kBAAkB,EAAE,kBAAkB,CAAC,CAAA;QACjD,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,SAAS,EAAE,WAAW,CAAC,CAAA;QAC3C,GAAG,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAA;QAE1B,oBAAoB,CAAC;YACnB,GAAG;YACH,YAAY;YACZ,QAAQ;YACR,WAAW;YACX,OAAO;YACP,SAAS;SACV,CAAC,CAAA;IACJ,CAAC,EAAE;QACD,SAAS;QACT,QAAQ;QACR,WAAW;QACX,OAAO;QACP,kBAAkB;QAClB,YAAY;KACb,CAAC,CAAA;IAEF,OAAO,CACL,gCACE,GAAG,EAAE,GAAG,EACR,MAAM,EAAE,WAAW,GAAG,kBAAkB,EACxC,KAAK,EAAE,SAAS,GAAG,kBAAkB,EACrC,KAAK,EAAE;YACL,QAAQ,EAAE,UAAU;YACpB,IAAI,EAAE,OAAO,GAAG,OAAO;YACvB,KAAK,EAAE,SAAS;YAChB,MAAM,EAAE,WAAW;SACpB,GACD,CACH,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,MAAM,iBAAiB,GAAG,QAAQ,CAAC,UAAU,EAC3C,KAAK,EACL,KAAK,GAIN;IACC,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,GAAG,KAAK,CAAA;IACvC,MAAM,WAAW,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAA;IAEtC,OAAO,CACL,6BACE,KAAK,EAAE;YACL,QAAQ,EAAE,UAAU;YACpB,MAAM,EAAE,WAAW;YACnB,KAAK,EAAE,YAAY;YACnB,QAAQ,EAAE,QAAQ;SACnB,IAEA,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,CACjB,oBAAC,iBAAiB,IAChB,GAAG,EAAE,EAAE,EACP,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,EAAE,EACX,WAAW,EAAE,WAAW,GACxB,CACH,CAAC,CACE,CACP,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,iBAAiB,CAAA"}
|
|
@@ -15,27 +15,34 @@ const TopArea = observer(function ({ model }) {
|
|
|
15
15
|
showHorizontalScrollbar ? React.createElement(Minimap, { model: model }) : null));
|
|
16
16
|
});
|
|
17
17
|
const TrackColumnIndicator = observer(function ({ model, }) {
|
|
18
|
-
const { mouseCol, mouseClickCol, colWidth, scrollX, treeAreaWidth, resizeHandleWidth, totalTrackAreaHeight, } = model;
|
|
18
|
+
const { mouseCol, mouseClickCol, colWidth, scrollX, treeAreaWidth, resizeHandleWidth, totalTrackAreaHeight, msaAreaWidth, verticalScrollbarWidth, } = model;
|
|
19
19
|
const left = treeAreaWidth + resizeHandleWidth;
|
|
20
|
-
|
|
20
|
+
const clipWidth = msaAreaWidth - verticalScrollbarWidth;
|
|
21
|
+
return (React.createElement("div", { style: {
|
|
22
|
+
position: 'absolute',
|
|
23
|
+
left,
|
|
24
|
+
top: 0,
|
|
25
|
+
width: clipWidth,
|
|
26
|
+
height: totalTrackAreaHeight,
|
|
27
|
+
overflow: 'hidden',
|
|
28
|
+
pointerEvents: 'none',
|
|
29
|
+
} },
|
|
21
30
|
mouseCol !== undefined ? (React.createElement("div", { style: {
|
|
22
31
|
position: 'absolute',
|
|
23
|
-
left:
|
|
32
|
+
left: mouseCol * colWidth + scrollX,
|
|
24
33
|
top: 0,
|
|
25
34
|
width: colWidth,
|
|
26
35
|
height: totalTrackAreaHeight,
|
|
27
36
|
backgroundColor: 'rgba(0,0,0,0.15)',
|
|
28
|
-
pointerEvents: 'none',
|
|
29
37
|
zIndex: 100,
|
|
30
38
|
} })) : null,
|
|
31
39
|
mouseClickCol !== undefined ? (React.createElement("div", { style: {
|
|
32
40
|
position: 'absolute',
|
|
33
|
-
left:
|
|
41
|
+
left: mouseClickCol * colWidth + scrollX,
|
|
34
42
|
top: 0,
|
|
35
43
|
width: colWidth,
|
|
36
44
|
height: totalTrackAreaHeight,
|
|
37
45
|
backgroundColor: 'rgba(128,128,0,0.2)',
|
|
38
|
-
pointerEvents: 'none',
|
|
39
46
|
zIndex: 100,
|
|
40
47
|
} })) : null));
|
|
41
48
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MSAView.js","sourceRoot":"","sources":["../../src/components/MSAView.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEvC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,OAAO,EACL,sBAAsB,EACtB,oBAAoB,GACrB,MAAM,oBAAqB,CAAA;AAC5B,OAAO,KAAK,MAAM,YAAa,CAAA;AAC/B,OAAO,iBAAiB,MAAM,wBAAyB,CAAA;AACvD,OAAO,MAAM,MAAM,oBAAqB,CAAA;AACxC,OAAO,OAAO,MAAM,sBAAuB,CAAA;AAC3C,OAAO,QAAQ,MAAM,mBAAoB,CAAA;AACzC,OAAO,SAAS,MAAM,qBAAsB,CAAA;AAC5C,OAAO,SAAS,MAAM,qBAAsB,CAAA;AAI5C,MAAM,OAAO,GAAG,QAAQ,CAAC,UAAU,EAAE,KAAK,EAA2B;IACnE,MAAM,EAAE,uBAAuB,EAAE,GAAG,KAAK,CAAA;IACzC,OAAO,CACL,6BAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE;QAC7B,oBAAC,SAAS,IAAC,KAAK,EAAE,KAAK,GAAI;QAC1B,uBAAuB,CAAC,CAAC,CAAC,oBAAC,OAAO,IAAC,KAAK,EAAE,KAAK,GAAI,CAAC,CAAC,CAAC,IAAI,CACvD,CACP,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,MAAM,oBAAoB,GAAG,QAAQ,CAAC,UAAU,EAC9C,KAAK,GAGN;IACC,MAAM,EACJ,QAAQ,EACR,aAAa,EACb,QAAQ,EACR,OAAO,EACP,aAAa,EACb,iBAAiB,EACjB,oBAAoB,
|
|
1
|
+
{"version":3,"file":"MSAView.js","sourceRoot":"","sources":["../../src/components/MSAView.tsx"],"names":[],"mappings":"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"}
|
|
@@ -2,6 +2,7 @@ import React, { useEffect, useMemo, useRef } from 'react';
|
|
|
2
2
|
import { useTheme } from '@mui/material';
|
|
3
3
|
import { observer } from 'mobx-react';
|
|
4
4
|
import { colorContrast } from "../util.js";
|
|
5
|
+
import { drawTextTrackContent } from "./tracks/renderTracksSvg.js";
|
|
5
6
|
const AnnotationBlock = observer(function ({ track, model, offsetX, }) {
|
|
6
7
|
const { blockSize, scrollX, bgColor, colorScheme: modelColorScheme, colWidth, fontSize, rowHeight, highResScaleFactor, } = model;
|
|
7
8
|
const { model: { customColorScheme, data }, } = track;
|
|
@@ -17,29 +18,23 @@ const AnnotationBlock = observer(function ({ track, model, offsetX, }) {
|
|
|
17
18
|
if (!ctx) {
|
|
18
19
|
return;
|
|
19
20
|
}
|
|
20
|
-
// this logic is very similar to MSACanvas
|
|
21
21
|
ctx.resetTransform();
|
|
22
22
|
ctx.scale(highResScaleFactor, highResScaleFactor);
|
|
23
23
|
ctx.clearRect(0, 0, blockSize, rowHeight);
|
|
24
24
|
ctx.translate(-offsetX, 0);
|
|
25
25
|
ctx.textAlign = 'center';
|
|
26
26
|
ctx.font = ctx.font.replace(/\d+px/, `${fontSize}px`);
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
ctx.fillStyle = contrastScheme[letter.toUpperCase()] || 'black';
|
|
39
|
-
ctx.fillText(letter, x + colWidth / 2, rowHeight / 2 + 1); // +1 to avoid cutoff at height:10
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
}
|
|
27
|
+
drawTextTrackContent({
|
|
28
|
+
ctx,
|
|
29
|
+
data,
|
|
30
|
+
colorScheme,
|
|
31
|
+
contrastScheme,
|
|
32
|
+
bgColor,
|
|
33
|
+
colWidth,
|
|
34
|
+
rowHeight,
|
|
35
|
+
offsetX,
|
|
36
|
+
blockSize,
|
|
37
|
+
});
|
|
43
38
|
}, [
|
|
44
39
|
fontSize,
|
|
45
40
|
bgColor,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TextTrack.js","sourceRoot":"","sources":["../../src/components/TextTrack.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,OAAO,CAAA;AAEzD,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;
|
|
1
|
+
{"version":3,"file":"TextTrack.js","sourceRoot":"","sources":["../../src/components/TextTrack.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,OAAO,CAAA;AAEzD,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;AAC1C,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAA;AAKlE,MAAM,eAAe,GAAG,QAAQ,CAAC,UAAU,EACzC,KAAK,EACL,KAAK,EACL,OAAO,GAKR;IACC,MAAM,EACJ,SAAS,EACT,OAAO,EACP,OAAO,EACP,WAAW,EAAE,gBAAgB,EAC7B,QAAQ,EACR,QAAQ,EACR,SAAS,EACT,kBAAkB,GACnB,GAAG,KAAK,CAAA;IACT,MAAM,EACJ,KAAK,EAAE,EAAE,iBAAiB,EAAE,IAAI,EAAE,GACnC,GAAG,KAAK,CAAA;IAET,MAAM,WAAW,GAAG,iBAAiB,IAAI,gBAAgB,CAAA;IACzD,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAA;IACxB,MAAM,GAAG,GAAG,MAAM,CAAoB,IAAI,CAAC,CAAA;IAC3C,MAAM,cAAc,GAAG,OAAO,CAC5B,GAAG,EAAE,CAAC,aAAa,CAAC,WAAW,EAAE,KAAK,CAAC,EACvC,CAAC,WAAW,EAAE,KAAK,CAAC,CACrB,CAAA;IACD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;YACjB,OAAM;QACR,CAAC;QAED,MAAM,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA;QACxC,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,OAAM;QACR,CAAC;QAED,GAAG,CAAC,cAAc,EAAE,CAAA;QACpB,GAAG,CAAC,KAAK,CAAC,kBAAkB,EAAE,kBAAkB,CAAC,CAAA;QACjD,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,SAAS,EAAE,SAAS,CAAC,CAAA;QACzC,GAAG,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAA;QAC1B,GAAG,CAAC,SAAS,GAAG,QAAQ,CAAA;QACxB,GAAG,CAAC,IAAI,GAAG,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,GAAG,QAAQ,IAAI,CAAC,CAAA;QAErD,oBAAoB,CAAC;YACnB,GAAG;YACH,IAAI;YACJ,WAAW;YACX,cAAc;YACd,OAAO;YACP,QAAQ;YACR,SAAS;YACT,OAAO;YACP,SAAS;SACV,CAAC,CAAA;IACJ,CAAC,EAAE;QACD,QAAQ;QACR,OAAO;QACP,SAAS;QACT,QAAQ;QACR,SAAS;QACT,OAAO;QACP,cAAc;QACd,WAAW;QACX,kBAAkB;QAClB,IAAI;KACL,CAAC,CAAA;IACF,OAAO,CACL,gCACE,GAAG,EAAE,GAAG,EACR,MAAM,EAAE,SAAS,GAAG,kBAAkB,EACtC,KAAK,EAAE,SAAS,GAAG,kBAAkB,EACrC,KAAK,EAAE;YACL,QAAQ,EAAE,UAAU;YACpB,IAAI,EAAE,OAAO,GAAG,OAAO;YACvB,KAAK,EAAE,SAAS;YAChB,MAAM,EAAE,SAAS;SAClB,GACD,CACH,CAAA;AACH,CAAC,CAAC,CAAA;AACF,MAAM,eAAe,GAAG,QAAQ,CAAC,UAAU,EACzC,KAAK,EACL,KAAK,GAIN;IACC,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,GAAG,KAAK,CAAA;IAClD,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;QACtB,OAAO,IAAI,CAAA;IACb,CAAC;IACD,OAAO,CACL,6BACE,KAAK,EAAE;YACL,QAAQ,EAAE,UAAU;YACpB,MAAM,EAAE,SAAS;YACjB,KAAK,EAAE,YAAY;YACnB,QAAQ,EAAE,QAAQ;SACnB,IAEA,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,CACjB,oBAAC,eAAe,IAAC,GAAG,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE,GAAI,CACtE,CAAC,CACE,CACP,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,eAAe,CAAA"}
|
|
@@ -5,7 +5,8 @@ import { observer } from 'mobx-react';
|
|
|
5
5
|
import { renderMouseover } from "./renderMSAMouseover.js";
|
|
6
6
|
const MSAMouseoverCanvas = observer(function ({ model, }) {
|
|
7
7
|
const ref = useRef(null);
|
|
8
|
-
const { height,
|
|
8
|
+
const { height, msaAreaWidth, verticalScrollbarWidth } = model;
|
|
9
|
+
const width = msaAreaWidth - verticalScrollbarWidth;
|
|
9
10
|
useEffect(() => {
|
|
10
11
|
const ctx = ref.current?.getContext('2d');
|
|
11
12
|
return ctx
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MSAMouseoverCanvas.js","sourceRoot":"","sources":["../../../src/components/msa/MSAMouseoverCanvas.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,OAAO,CAAA;AAEhD,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAA;AAClD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAA;AAC9B,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAA;AAIzD,MAAM,kBAAkB,GAAG,QAAQ,CAAC,UAAU,EAC5C,KAAK,GAGN;IACC,MAAM,GAAG,GAAG,MAAM,CAAoB,IAAI,CAAC,CAAA;IAC3C,MAAM,EAAE,MAAM,EAAE,
|
|
1
|
+
{"version":3,"file":"MSAMouseoverCanvas.js","sourceRoot":"","sources":["../../../src/components/msa/MSAMouseoverCanvas.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,OAAO,CAAA;AAEhD,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAA;AAClD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAA;AAC9B,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAA;AAIzD,MAAM,kBAAkB,GAAG,QAAQ,CAAC,UAAU,EAC5C,KAAK,GAGN;IACC,MAAM,GAAG,GAAG,MAAM,CAAoB,IAAI,CAAC,CAAA;IAC3C,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,sBAAsB,EAAE,GAAG,KAAK,CAAA;IAC9D,MAAM,KAAK,GAAG,YAAY,GAAG,sBAAsB,CAAA;IACnD,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,GAAG,GAAG,GAAG,CAAC,OAAO,EAAE,UAAU,CAAC,IAAI,CAAC,CAAA;QACzC,OAAO,GAAG;YACR,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE;gBACX,IAAI,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;oBACnB,eAAe,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAA;gBACjC,CAAC;YACH,CAAC,CAAC;YACJ,CAAC,CAAC,SAAS,CAAA;IACf,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAA;IAEX,OAAO,CACL,gCACE,GAAG,EAAE,GAAG,EACR,EAAE,EAAC,WAAW,EACd,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,MAAM,EACd,KAAK,EAAE;YACL,QAAQ,EAAE,UAAU;YACpB,GAAG,EAAE,CAAC;YACN,IAAI,EAAE,CAAC;YACP,KAAK;YACL,MAAM;YACN,MAAM,EAAE,IAAI;YACZ,aAAa,EAAE,MAAM;SACtB,GACD,CACH,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,kBAAkB,CAAA"}
|
|
@@ -3,9 +3,10 @@ const highlightColor = 'rgba(128,128,0,0.2)';
|
|
|
3
3
|
const referenceColor = 'rgba(0,128,255,0.3)'; // Blue highlight for reference row
|
|
4
4
|
const multiRowHoverColor = 'rgba(255,165,0,0.15)'; // Orange highlight for multi-row tree hover
|
|
5
5
|
export function renderMouseover({ ctx, model, }) {
|
|
6
|
-
const { mouseCol, colWidth,
|
|
6
|
+
const { mouseCol, colWidth, msaAreaWidth, verticalScrollbarWidth, height, rowHeight, scrollX, scrollY, mouseRow,
|
|
7
7
|
// @ts-expect-error
|
|
8
8
|
mouseCol2, mouseClickRow, mouseClickCol, relativeTo, rowNamesSet, hoveredTreeNode, highlightedColumns, } = model;
|
|
9
|
+
const width = msaAreaWidth - verticalScrollbarWidth;
|
|
9
10
|
ctx.resetTransform();
|
|
10
11
|
ctx.clearRect(0, 0, width, height);
|
|
11
12
|
// Highlight reference row (relativeTo) persistently
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"renderMSAMouseover.js","sourceRoot":"","sources":["../../../src/components/msa/renderMSAMouseover.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,GAAG,kBAAkB,CAAA;AACrC,MAAM,cAAc,GAAG,qBAAqB,CAAA;AAC5C,MAAM,cAAc,GAAG,qBAAqB,CAAA,CAAC,mCAAmC;AAChF,MAAM,kBAAkB,GAAG,sBAAsB,CAAA,CAAC,4CAA4C;AAE9F,MAAM,UAAU,eAAe,CAAC,EAC9B,GAAG,EACH,KAAK,GAIN;IACC,MAAM,EACJ,QAAQ,EACR,QAAQ,EACR,
|
|
1
|
+
{"version":3,"file":"renderMSAMouseover.js","sourceRoot":"","sources":["../../../src/components/msa/renderMSAMouseover.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,24 @@
|
|
|
1
1
|
import type { MsaViewModel } from '../../model.ts';
|
|
2
2
|
import type { BasicTrack } from '../../types.ts';
|
|
3
|
+
export declare function drawConservationBars({ ctx, conservation, colWidth, trackHeight, offsetX, blockSize, }: {
|
|
4
|
+
ctx: CanvasRenderingContext2D;
|
|
5
|
+
conservation: number[];
|
|
6
|
+
colWidth: number;
|
|
7
|
+
trackHeight: number;
|
|
8
|
+
offsetX: number;
|
|
9
|
+
blockSize: number;
|
|
10
|
+
}): void;
|
|
11
|
+
export declare function drawTextTrackContent({ ctx, data, colorScheme, contrastScheme, bgColor, colWidth, rowHeight, offsetX, blockSize, }: {
|
|
12
|
+
ctx: CanvasRenderingContext2D;
|
|
13
|
+
data: string | undefined;
|
|
14
|
+
colorScheme: Record<string, string>;
|
|
15
|
+
contrastScheme: Record<string, string>;
|
|
16
|
+
bgColor: boolean;
|
|
17
|
+
colWidth: number;
|
|
18
|
+
rowHeight: number;
|
|
19
|
+
offsetX: number;
|
|
20
|
+
blockSize: number;
|
|
21
|
+
}): void;
|
|
3
22
|
export declare function renderConservationTrack({ model, ctx, offsetX, offsetY, trackHeight, blockSizeXOverride, highResScaleFactorOverride, }: {
|
|
4
23
|
model: MsaViewModel;
|
|
5
24
|
ctx: CanvasRenderingContext2D;
|
|
@@ -1,20 +1,47 @@
|
|
|
1
|
-
export function
|
|
2
|
-
const { blockSize, colWidth, highResScaleFactor, conservation } = model;
|
|
3
|
-
const bx = blockSizeXOverride ?? blockSize;
|
|
4
|
-
const k = highResScaleFactorOverride ?? highResScaleFactor;
|
|
5
|
-
ctx.resetTransform();
|
|
6
|
-
ctx.scale(k, k);
|
|
7
|
-
ctx.translate(-offsetX, offsetY);
|
|
1
|
+
export function drawConservationBars({ ctx, conservation, colWidth, trackHeight, offsetX, blockSize, }) {
|
|
8
2
|
const xStart = Math.max(0, Math.floor(offsetX / colWidth));
|
|
9
|
-
const xEnd = Math.max(0, Math.ceil((offsetX +
|
|
3
|
+
const xEnd = Math.max(0, Math.ceil((offsetX + blockSize) / colWidth));
|
|
4
|
+
ctx.fillStyle = 'gray';
|
|
10
5
|
for (let i = xStart; i < xEnd && i < conservation.length; i++) {
|
|
11
6
|
const value = conservation[i];
|
|
12
7
|
const barHeight = value * trackHeight;
|
|
13
8
|
const x = i * colWidth;
|
|
14
|
-
const hue = value * 120;
|
|
15
|
-
ctx.fillStyle = `hsl(${hue}, 70%, 50%)`;
|
|
16
9
|
ctx.fillRect(x, trackHeight - barHeight, colWidth, barHeight);
|
|
17
10
|
}
|
|
11
|
+
}
|
|
12
|
+
export function drawTextTrackContent({ ctx, data, colorScheme, contrastScheme, bgColor, colWidth, rowHeight, offsetX, blockSize, }) {
|
|
13
|
+
const xStart = Math.max(0, Math.floor(offsetX / colWidth));
|
|
14
|
+
const xEnd = Math.max(0, Math.ceil((offsetX + blockSize) / colWidth));
|
|
15
|
+
const str = data?.slice(xStart, xEnd);
|
|
16
|
+
for (let i = 0; str && i < str.length; i++) {
|
|
17
|
+
const letter = str[i];
|
|
18
|
+
const color = colorScheme[letter.toUpperCase()];
|
|
19
|
+
if (bgColor) {
|
|
20
|
+
const x = i * colWidth + offsetX - (offsetX % colWidth);
|
|
21
|
+
ctx.fillStyle = color || 'white';
|
|
22
|
+
ctx.fillRect(x, 0, colWidth, rowHeight);
|
|
23
|
+
if (rowHeight >= 10 && colWidth >= rowHeight / 2) {
|
|
24
|
+
ctx.fillStyle = contrastScheme[letter.toUpperCase()] || 'black';
|
|
25
|
+
ctx.fillText(letter, x + colWidth / 2, rowHeight / 2 + 1);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
export function renderConservationTrack({ model, ctx, offsetX, offsetY, trackHeight, blockSizeXOverride, highResScaleFactorOverride, }) {
|
|
31
|
+
const { blockSize, colWidth, highResScaleFactor, conservation } = model;
|
|
32
|
+
const bx = blockSizeXOverride ?? blockSize;
|
|
33
|
+
const k = highResScaleFactorOverride ?? highResScaleFactor;
|
|
34
|
+
ctx.resetTransform();
|
|
35
|
+
ctx.scale(k, k);
|
|
36
|
+
ctx.translate(-offsetX, offsetY);
|
|
37
|
+
drawConservationBars({
|
|
38
|
+
ctx,
|
|
39
|
+
conservation,
|
|
40
|
+
colWidth,
|
|
41
|
+
trackHeight,
|
|
42
|
+
offsetX,
|
|
43
|
+
blockSize: bx,
|
|
44
|
+
});
|
|
18
45
|
ctx.resetTransform();
|
|
19
46
|
}
|
|
20
47
|
export function renderTextTrack({ model, ctx, track, offsetX, offsetY, contrastScheme, blockSizeXOverride, highResScaleFactorOverride, }) {
|
|
@@ -28,25 +55,17 @@ export function renderTextTrack({ model, ctx, track, offsetX, offsetY, contrastS
|
|
|
28
55
|
ctx.translate(-offsetX, offsetY);
|
|
29
56
|
ctx.textAlign = 'center';
|
|
30
57
|
ctx.font = ctx.font.replace(/\d+px/, `${fontSize}px`);
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
if (rowHeight >= 10 && colWidth >= rowHeight / 2) {
|
|
43
|
-
ctx.fillStyle =
|
|
44
|
-
bgColor && color
|
|
45
|
-
? (contrastScheme[letter.toUpperCase()] ?? 'black')
|
|
46
|
-
: 'black';
|
|
47
|
-
ctx.fillText(letter, x + colWidth / 2, rowHeight / 2 + 1);
|
|
48
|
-
}
|
|
49
|
-
}
|
|
58
|
+
drawTextTrackContent({
|
|
59
|
+
ctx,
|
|
60
|
+
data,
|
|
61
|
+
colorScheme,
|
|
62
|
+
contrastScheme,
|
|
63
|
+
bgColor,
|
|
64
|
+
colWidth,
|
|
65
|
+
rowHeight,
|
|
66
|
+
offsetX,
|
|
67
|
+
blockSize: bx,
|
|
68
|
+
});
|
|
50
69
|
ctx.resetTransform();
|
|
51
70
|
}
|
|
52
71
|
export function renderAllTracks({ model, ctx, offsetX, contrastScheme, blockSizeXOverride, highResScaleFactorOverride, }) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"renderTracksSvg.js","sourceRoot":"","sources":["../../../src/components/tracks/renderTracksSvg.ts"],"names":[],"mappings":"AAGA,MAAM,UAAU,
|
|
1
|
+
{"version":3,"file":"renderTracksSvg.js","sourceRoot":"","sources":["../../../src/components/tracks/renderTracksSvg.ts"],"names":[],"mappings":"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"}
|
package/dist/version.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export declare const version = "5.0.
|
|
1
|
+
export declare const version = "5.0.5";
|
package/dist/version.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export const version = '5.0.
|
|
1
|
+
export const version = '5.0.5';
|
|
2
2
|
//# sourceMappingURL=version.js.map
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "react-msaview",
|
|
3
3
|
"author": "Colin",
|
|
4
|
-
"version": "5.0.
|
|
4
|
+
"version": "5.0.5",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"type": "module",
|
|
7
7
|
"repository": {
|
|
@@ -44,8 +44,8 @@
|
|
|
44
44
|
"d3-hierarchy": "^3.1.2",
|
|
45
45
|
"flatbush": "^4.4.0",
|
|
46
46
|
"pako": "^2.1.0",
|
|
47
|
-
"@jbrowse/svgcanvas": "5.0.
|
|
48
|
-
"msa-parsers": "5.0.
|
|
47
|
+
"@jbrowse/svgcanvas": "5.0.5",
|
|
48
|
+
"msa-parsers": "5.0.5"
|
|
49
49
|
},
|
|
50
50
|
"scripts": {
|
|
51
51
|
"clean": "rimraf dist bundle",
|
|
@@ -2,6 +2,8 @@ import React, { useEffect, useRef } from 'react'
|
|
|
2
2
|
|
|
3
3
|
import { observer } from 'mobx-react'
|
|
4
4
|
|
|
5
|
+
import { drawConservationBars } from './tracks/renderTracksSvg.ts'
|
|
6
|
+
|
|
5
7
|
import type { MsaViewModel } from '../model.ts'
|
|
6
8
|
import type { BasicTrack } from '../types.ts'
|
|
7
9
|
|
|
@@ -34,17 +36,14 @@ const ConservationBlock = observer(function ({
|
|
|
34
36
|
ctx.clearRect(0, 0, blockSize, trackHeight)
|
|
35
37
|
ctx.translate(-offsetX, 0)
|
|
36
38
|
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
ctx.fillStyle = 'gray'
|
|
46
|
-
ctx.fillRect(x, trackHeight - barHeight, colWidth, barHeight)
|
|
47
|
-
}
|
|
39
|
+
drawConservationBars({
|
|
40
|
+
ctx,
|
|
41
|
+
conservation,
|
|
42
|
+
colWidth,
|
|
43
|
+
trackHeight,
|
|
44
|
+
offsetX,
|
|
45
|
+
blockSize,
|
|
46
|
+
})
|
|
48
47
|
}, [
|
|
49
48
|
blockSize,
|
|
50
49
|
colWidth,
|
|
@@ -39,22 +39,34 @@ const TrackColumnIndicator = observer(function ({
|
|
|
39
39
|
treeAreaWidth,
|
|
40
40
|
resizeHandleWidth,
|
|
41
41
|
totalTrackAreaHeight,
|
|
42
|
+
msaAreaWidth,
|
|
43
|
+
verticalScrollbarWidth,
|
|
42
44
|
} = model
|
|
43
45
|
|
|
44
46
|
const left = treeAreaWidth + resizeHandleWidth
|
|
47
|
+
const clipWidth = msaAreaWidth - verticalScrollbarWidth
|
|
45
48
|
|
|
46
49
|
return (
|
|
47
|
-
|
|
50
|
+
<div
|
|
51
|
+
style={{
|
|
52
|
+
position: 'absolute',
|
|
53
|
+
left,
|
|
54
|
+
top: 0,
|
|
55
|
+
width: clipWidth,
|
|
56
|
+
height: totalTrackAreaHeight,
|
|
57
|
+
overflow: 'hidden',
|
|
58
|
+
pointerEvents: 'none',
|
|
59
|
+
}}
|
|
60
|
+
>
|
|
48
61
|
{mouseCol !== undefined ? (
|
|
49
62
|
<div
|
|
50
63
|
style={{
|
|
51
64
|
position: 'absolute',
|
|
52
|
-
left:
|
|
65
|
+
left: mouseCol * colWidth + scrollX,
|
|
53
66
|
top: 0,
|
|
54
67
|
width: colWidth,
|
|
55
68
|
height: totalTrackAreaHeight,
|
|
56
69
|
backgroundColor: 'rgba(0,0,0,0.15)',
|
|
57
|
-
pointerEvents: 'none',
|
|
58
70
|
zIndex: 100,
|
|
59
71
|
}}
|
|
60
72
|
/>
|
|
@@ -63,17 +75,16 @@ const TrackColumnIndicator = observer(function ({
|
|
|
63
75
|
<div
|
|
64
76
|
style={{
|
|
65
77
|
position: 'absolute',
|
|
66
|
-
left:
|
|
78
|
+
left: mouseClickCol * colWidth + scrollX,
|
|
67
79
|
top: 0,
|
|
68
80
|
width: colWidth,
|
|
69
81
|
height: totalTrackAreaHeight,
|
|
70
82
|
backgroundColor: 'rgba(128,128,0,0.2)',
|
|
71
|
-
pointerEvents: 'none',
|
|
72
83
|
zIndex: 100,
|
|
73
84
|
}}
|
|
74
85
|
/>
|
|
75
86
|
) : null}
|
|
76
|
-
|
|
87
|
+
</div>
|
|
77
88
|
)
|
|
78
89
|
})
|
|
79
90
|
|
|
@@ -4,6 +4,7 @@ import { useTheme } from '@mui/material'
|
|
|
4
4
|
import { observer } from 'mobx-react'
|
|
5
5
|
|
|
6
6
|
import { colorContrast } from '../util.ts'
|
|
7
|
+
import { drawTextTrackContent } from './tracks/renderTracksSvg.ts'
|
|
7
8
|
|
|
8
9
|
import type { MsaViewModel } from '../model.ts'
|
|
9
10
|
import type { BasicTrack } from '../types.ts'
|
|
@@ -48,7 +49,6 @@ const AnnotationBlock = observer(function ({
|
|
|
48
49
|
return
|
|
49
50
|
}
|
|
50
51
|
|
|
51
|
-
// this logic is very similar to MSACanvas
|
|
52
52
|
ctx.resetTransform()
|
|
53
53
|
ctx.scale(highResScaleFactor, highResScaleFactor)
|
|
54
54
|
ctx.clearRect(0, 0, blockSize, rowHeight)
|
|
@@ -56,22 +56,17 @@ const AnnotationBlock = observer(function ({
|
|
|
56
56
|
ctx.textAlign = 'center'
|
|
57
57
|
ctx.font = ctx.font.replace(/\d+px/, `${fontSize}px`)
|
|
58
58
|
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
ctx.fillStyle = contrastScheme[letter.toUpperCase()] || 'black'
|
|
71
|
-
ctx.fillText(letter, x + colWidth / 2, rowHeight / 2 + 1) // +1 to avoid cutoff at height:10
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
}
|
|
59
|
+
drawTextTrackContent({
|
|
60
|
+
ctx,
|
|
61
|
+
data,
|
|
62
|
+
colorScheme,
|
|
63
|
+
contrastScheme,
|
|
64
|
+
bgColor,
|
|
65
|
+
colWidth,
|
|
66
|
+
rowHeight,
|
|
67
|
+
offsetX,
|
|
68
|
+
blockSize,
|
|
69
|
+
})
|
|
75
70
|
}, [
|
|
76
71
|
fontSize,
|
|
77
72
|
bgColor,
|
|
@@ -14,7 +14,8 @@ const MSAMouseoverCanvas = observer(function ({
|
|
|
14
14
|
model: MsaViewModel
|
|
15
15
|
}) {
|
|
16
16
|
const ref = useRef<HTMLCanvasElement>(null)
|
|
17
|
-
const { height,
|
|
17
|
+
const { height, msaAreaWidth, verticalScrollbarWidth } = model
|
|
18
|
+
const width = msaAreaWidth - verticalScrollbarWidth
|
|
18
19
|
useEffect(() => {
|
|
19
20
|
const ctx = ref.current?.getContext('2d')
|
|
20
21
|
return ctx
|
|
@@ -15,7 +15,8 @@ export function renderMouseover({
|
|
|
15
15
|
const {
|
|
16
16
|
mouseCol,
|
|
17
17
|
colWidth,
|
|
18
|
-
|
|
18
|
+
msaAreaWidth,
|
|
19
|
+
verticalScrollbarWidth,
|
|
19
20
|
height,
|
|
20
21
|
rowHeight,
|
|
21
22
|
scrollX,
|
|
@@ -30,6 +31,7 @@ export function renderMouseover({
|
|
|
30
31
|
hoveredTreeNode,
|
|
31
32
|
highlightedColumns,
|
|
32
33
|
} = model
|
|
34
|
+
const width = msaAreaWidth - verticalScrollbarWidth
|
|
33
35
|
ctx.resetTransform()
|
|
34
36
|
ctx.clearRect(0, 0, width, height)
|
|
35
37
|
|