@datagrok-libraries/bio 4.4.0 → 4.4.4
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/package.json +3 -3
- package/src/consts/index.d.ts +6 -0
- package/src/consts/index.d.ts.map +1 -0
- package/src/consts/index.js +7 -0
- package/src/types/index.d.ts +7 -0
- package/src/types/index.d.ts.map +1 -0
- package/src/types/index.js +3 -0
- package/src/typings/index.d.ts +12 -0
- package/src/unknown.d.ts.map +1 -1
- package/src/unknown.js +24 -2
- package/src/utils/cell-renderer.d.ts +6 -3
- package/src/utils/cell-renderer.d.ts.map +1 -1
- package/src/utils/cell-renderer.js +30 -15
- package/src/viewers/vd-regions-viewer.d.ts +9 -0
- package/src/viewers/vd-regions-viewer.d.ts.map +1 -0
- package/src/viewers/vd-regions-viewer.js +2 -0
- package/src/viewers/web-logo.d.ts +51 -13
- package/src/viewers/web-logo.d.ts.map +1 -1
- package/src/viewers/web-logo.js +225 -145
package/package.json
CHANGED
|
@@ -3,14 +3,14 @@
|
|
|
3
3
|
"publishConfig": {
|
|
4
4
|
"access": "public"
|
|
5
5
|
},
|
|
6
|
-
"beta": true,
|
|
7
6
|
"friendlyName": "Datagrok bio library",
|
|
8
|
-
"version": "4.4.
|
|
7
|
+
"version": "4.4.4",
|
|
9
8
|
"description": "",
|
|
10
9
|
"dependencies": {
|
|
11
10
|
"@datagrok-libraries/utils": "^1.6.2",
|
|
11
|
+
"@phylocanvas/phylocanvas.gl": "^1.44.0",
|
|
12
12
|
"cash-dom": "latest",
|
|
13
|
-
"datagrok-api": "^1.6.
|
|
13
|
+
"datagrok-api": "^1.6.12",
|
|
14
14
|
"dayjs": "latest",
|
|
15
15
|
"rxjs": "^6.5.5",
|
|
16
16
|
"wu": "latest"
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAGA,QAAA,MAAM,MAAM;;CAAc,CAAC;AAG3B,QAAA,MAAM,SAAS,KAAiB,CAAC;AAEjC,OAAO,EAAC,MAAM,EAAE,SAAS,EAAC,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import * as pcgl from '@phylocanvas/phylocanvas.gl';
|
|
2
|
+
//@ts-ignore
|
|
3
|
+
const Shapes = pcgl.Shapes;
|
|
4
|
+
//@ts-ignore
|
|
5
|
+
const TreeTypes = pcgl.TreeTypes;
|
|
6
|
+
export { Shapes, TreeTypes };
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssSUFBSSxNQUFNLDZCQUE2QixDQUFDO0FBRXBELFlBQVk7QUFDWixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDO0FBRTNCLFlBQVk7QUFDWixNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO0FBRWpDLE9BQU8sRUFBQyxNQUFNLEVBQUUsU0FBUyxFQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBwY2dsIGZyb20gJ0BwaHlsb2NhbnZhcy9waHlsb2NhbnZhcy5nbCc7XG5cbi8vQHRzLWlnbm9yZVxuY29uc3QgU2hhcGVzID0gcGNnbC5TaGFwZXM7XG5cbi8vQHRzLWlnbm9yZVxuY29uc3QgVHJlZVR5cGVzID0gcGNnbC5UcmVlVHlwZXM7XG5cbmV4cG9ydCB7U2hhcGVzLCBUcmVlVHlwZXN9O1xuIl19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAEA,UAAU,QAAQ;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,QAAQ,EAAE,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;CACvB;AAED,OAAO,EAAC,QAAQ,IAAI,QAAQ,EAAC,CAAC"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
// import {NodeType} from '@phylocanvas/phylocanvas.gl';
|
|
2
|
+
export {};
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx3REFBd0QiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBpbXBvcnQge05vZGVUeXBlfSBmcm9tICdAcGh5bG9jYW52YXMvcGh5bG9jYW52YXMuZ2wnO1xuXG5pbnRlcmZhY2UgTm9kZVR5cGUge1xuICBuYW1lOiBzdHJpbmc7XG4gIGNoaWxkcmVuOiBOb2RlVHlwZVtdO1xuICBicmFuY2hfbGVuZ3RoOiBudW1iZXI7XG59XG5cbmV4cG9ydCB7Tm9kZVR5cGUgYXMgTm9kZVR5cGV9OyJdfQ==
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
declare module '@phylocanvas/phylocanvas.gl' {
|
|
2
|
+
import {Deck} from '@deck.gl/core/typed';
|
|
3
|
+
|
|
4
|
+
export const TreeTypes;
|
|
5
|
+
export const Shapes: { [key: string]: string };
|
|
6
|
+
|
|
7
|
+
// export interface NodeType {
|
|
8
|
+
// name: string;
|
|
9
|
+
// children: NodeType[];
|
|
10
|
+
// branch_length: number;
|
|
11
|
+
// }
|
|
12
|
+
}
|
package/src/unknown.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"unknown.d.ts","sourceRoot":"","sources":["unknown.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"unknown.d.ts","sourceRoot":"","sources":["unknown.ts"],"names":[],"mappings":"AA2BA,qBAAa,WAAW;WACR,QAAQ,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;CAW1C;AAED,OAAO,EAAC,UAAU,EAAE,cAAc,EAAC,MAAM,gBAAgB,CAAC;AAE1D,8BAAsB,iBAAkB,YAAW,UAAU;aAC3C,GAAG,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;CACvC;AAED,qBAAa,cAAe,SAAQ,iBAAiB;IAC5C,GAAG,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;CAG9B;AAGD,qBAAa,mBAAoB,SAAQ,iBAAiB;IACxD,OAAc,OAAO,EAAE,MAAM,EAAE,CAAsC;IAErE,OAAO,CAAC,MAAM,CAAC,YAAY;IAKpB,GAAG,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;CAK9B;AAED,qBAAa,kBAAmB,SAAQ,cAAc;IACpD,OAAO,CAAC,MAAM,CAAC,IAAI,CAAa;IAEhC,WAAkB,IAAI,IAAI,UAAU,CAInC;IAED,OAAO,CAAC,MAAM,CAAC,KAAK,CAAa;IAEjC,WAAkB,KAAK,IAAI,UAAU,CAIpC;CACF"}
|
package/src/unknown.js
CHANGED
|
@@ -1,3 +1,25 @@
|
|
|
1
|
+
import * as DG from 'datagrok-api/dg';
|
|
2
|
+
/** makes the color less white, makes the transparency effect always perceptible
|
|
3
|
+
* @param {string} color x coordinate.
|
|
4
|
+
* */
|
|
5
|
+
function correctColor(color) {
|
|
6
|
+
if (color == null)
|
|
7
|
+
return 'rgb(100,100,100)';
|
|
8
|
+
const dgColor = DG.Color.fromHtml(color);
|
|
9
|
+
const g = DG.Color.g(dgColor);
|
|
10
|
+
const r = DG.Color.r(dgColor);
|
|
11
|
+
const b = DG.Color.b(dgColor);
|
|
12
|
+
// calculate euclidean distance to white
|
|
13
|
+
const distToBlack = Math.sqrt(Math.pow(0 - r, 2) + Math.pow(0 - g, 2) + Math.pow(0 - b, 2));
|
|
14
|
+
// normalize vector r g b
|
|
15
|
+
const normR = r / distToBlack;
|
|
16
|
+
const normG = g / distToBlack;
|
|
17
|
+
const normB = b / distToBlack;
|
|
18
|
+
if (distToBlack > 210) {
|
|
19
|
+
return `rgb(${normR * 210},${normG * 210},${normB * 210})`;
|
|
20
|
+
}
|
|
21
|
+
return DG.Color.toRgb(dgColor);
|
|
22
|
+
}
|
|
1
23
|
export class StringUtils {
|
|
2
24
|
static hashCode(s) {
|
|
3
25
|
let hash = 0;
|
|
@@ -27,7 +49,7 @@ export class UnknownColorPalette extends UnknownSeqPalette {
|
|
|
27
49
|
get(m) {
|
|
28
50
|
const hash = StringUtils.hashCode(m);
|
|
29
51
|
const pI = hash % UnknownColorPalette.palette.length;
|
|
30
|
-
return UnknownColorPalette.palette[pI];
|
|
52
|
+
return correctColor(UnknownColorPalette.palette[pI]);
|
|
31
53
|
}
|
|
32
54
|
}
|
|
33
55
|
UnknownColorPalette.palette = UnknownColorPalette.buildPalette();
|
|
@@ -43,4 +65,4 @@ export class UnknownSeqPalettes extends SeqPaletteBase {
|
|
|
43
65
|
return this.color;
|
|
44
66
|
}
|
|
45
67
|
}
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5rbm93bi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInVua25vd24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxLQUFLLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUV0Qzs7S0FFSztBQUNMLFNBQVMsWUFBWSxDQUFDLEtBQW9CO0lBQ3hDLElBQUksS0FBSyxJQUFJLElBQUk7UUFDZixPQUFPLGtCQUFrQixDQUFDO0lBRTVCLE1BQU0sT0FBTyxHQUFXLEVBQUUsQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2pELE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzlCLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzlCLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzlCLHdDQUF3QztJQUN4QyxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDNUYseUJBQXlCO0lBQ3pCLE1BQU0sS0FBSyxHQUFHLENBQUMsR0FBRyxXQUFXLENBQUM7SUFDOUIsTUFBTSxLQUFLLEdBQUcsQ0FBQyxHQUFHLFdBQVcsQ0FBQztJQUM5QixNQUFNLEtBQUssR0FBRyxDQUFDLEdBQUcsV0FBVyxDQUFDO0lBQzlCLElBQUksV0FBVyxHQUFHLEdBQUcsRUFBRTtRQUNyQixPQUFPLE9BQU8sS0FBSyxHQUFHLEdBQUcsSUFBSSxLQUFLLEdBQUcsR0FBRyxJQUFJLEtBQUssR0FBRyxHQUFHLEdBQUcsQ0FBQztLQUM1RDtJQUNELE9BQU8sRUFBRSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7QUFDakMsQ0FBQztBQUVELE1BQU0sT0FBTyxXQUFXO0lBQ2YsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFTO1FBQzlCLElBQUksSUFBSSxHQUFXLENBQUMsQ0FBQztRQUNyQixJQUFJLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQztZQUNoQixPQUFPLElBQUksQ0FBQztRQUNkLEtBQUssSUFBSSxDQUFDLEdBQVcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFO1lBQ3pDLE1BQU0sR0FBRyxHQUFXLENBQUMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDcEMsSUFBSSxHQUFHLENBQUMsQ0FBQyxJQUFJLElBQUksQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsR0FBRyxDQUFDO1lBQ2xDLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQywyQkFBMkI7U0FDdkM7UUFDRCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7Q0FDRjtBQUVELE9BQU8sRUFBYSxjQUFjLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUUxRCxNQUFNLE9BQWdCLGlCQUFpQjtDQUV0QztBQUVELE1BQU0sT0FBTyxjQUFlLFNBQVEsaUJBQWlCO0lBQzVDLEdBQUcsQ0FBQyxDQUFTO1FBQ2xCLE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7Q0FDRjtBQUdELE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxpQkFBaUI7SUFHaEQsTUFBTSxDQUFDLFlBQVk7UUFDekIsTUFBTSxHQUFHLEdBQUksRUFBZSxDQUFDLE1BQU0sQ0FBQyxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsY0FBYyxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUM7UUFDcEYsT0FBTyxHQUFHLENBQUM7SUFDYixDQUFDO0lBRU0sR0FBRyxDQUFDLENBQVM7UUFDbEIsTUFBTSxJQUFJLEdBQVcsV0FBVyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUM3QyxNQUFNLEVBQUUsR0FBRyxJQUFJLEdBQUcsbUJBQW1CLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQztRQUNyRCxPQUFPLFlBQVksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUN2RCxDQUFDOztBQVhhLDJCQUFPLEdBQWEsbUJBQW1CLENBQUMsWUFBWSxFQUFFLENBQUM7QUFjdkUsTUFBTSxPQUFPLGtCQUFtQixTQUFRLGNBQWM7SUFHN0MsTUFBTSxLQUFLLElBQUk7UUFDcEIsSUFBSSxJQUFJLENBQUMsSUFBSSxLQUFLLEtBQUssQ0FBQztZQUN0QixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksY0FBYyxFQUFFLENBQUM7UUFDbkMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ25CLENBQUM7SUFJTSxNQUFNLEtBQUssS0FBSztRQUNyQixJQUFJLElBQUksQ0FBQyxLQUFLLEtBQUssS0FBSyxDQUFDO1lBQ3ZCLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxtQkFBbUIsRUFBRSxDQUFDO1FBQ3pDLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQztJQUNwQixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBncm9rIGZyb20gJ2RhdGFncm9rLWFwaS9ncm9rJztcbmltcG9ydCAqIGFzIHVpIGZyb20gJ2RhdGFncm9rLWFwaS91aSc7XG5pbXBvcnQgKiBhcyBERyBmcm9tICdkYXRhZ3Jvay1hcGkvZGcnO1xuXG4vKiogbWFrZXMgdGhlIGNvbG9yIGxlc3Mgd2hpdGUsIG1ha2VzIHRoZSB0cmFuc3BhcmVuY3kgZWZmZWN0IGFsd2F5cyBwZXJjZXB0aWJsZVxuICogQHBhcmFtIHtzdHJpbmd9IGNvbG9yIHggY29vcmRpbmF0ZS5cbiAqICovXG5mdW5jdGlvbiBjb3JyZWN0Q29sb3IoY29sb3I6IHN0cmluZyB8IG51bGwpOiBzdHJpbmcge1xuICBpZiAoY29sb3IgPT0gbnVsbClcbiAgICByZXR1cm4gJ3JnYigxMDAsMTAwLDEwMCknO1xuXG4gIGNvbnN0IGRnQ29sb3I6IG51bWJlciA9IERHLkNvbG9yLmZyb21IdG1sKGNvbG9yKTtcbiAgY29uc3QgZyA9IERHLkNvbG9yLmcoZGdDb2xvcik7XG4gIGNvbnN0IHIgPSBERy5Db2xvci5yKGRnQ29sb3IpO1xuICBjb25zdCBiID0gREcuQ29sb3IuYihkZ0NvbG9yKTtcbiAgLy8gY2FsY3VsYXRlIGV1Y2xpZGVhbiBkaXN0YW5jZSB0byB3aGl0ZVxuICBjb25zdCBkaXN0VG9CbGFjayA9IE1hdGguc3FydChNYXRoLnBvdygwIC0gciwgMikgKyBNYXRoLnBvdygwIC0gZywgMikgKyBNYXRoLnBvdygwIC0gYiwgMikpO1xuICAvLyBub3JtYWxpemUgdmVjdG9yIHIgZyBiXG4gIGNvbnN0IG5vcm1SID0gciAvIGRpc3RUb0JsYWNrO1xuICBjb25zdCBub3JtRyA9IGcgLyBkaXN0VG9CbGFjaztcbiAgY29uc3Qgbm9ybUIgPSBiIC8gZGlzdFRvQmxhY2s7XG4gIGlmIChkaXN0VG9CbGFjayA+IDIxMCkge1xuICAgIHJldHVybiBgcmdiKCR7bm9ybVIgKiAyMTB9LCR7bm9ybUcgKiAyMTB9LCR7bm9ybUIgKiAyMTB9KWA7XG4gIH1cbiAgcmV0dXJuIERHLkNvbG9yLnRvUmdiKGRnQ29sb3IpO1xufVxuXG5leHBvcnQgY2xhc3MgU3RyaW5nVXRpbHMge1xuICBwdWJsaWMgc3RhdGljIGhhc2hDb2RlKHM6IHN0cmluZyk6IG51bWJlciB7XG4gICAgbGV0IGhhc2g6IG51bWJlciA9IDA7XG4gICAgaWYgKHMubGVuZ3RoID09PSAwKVxuICAgICAgcmV0dXJuIGhhc2g7XG4gICAgZm9yIChsZXQgaTogbnVtYmVyID0gMDsgaSA8IHMubGVuZ3RoOyBpKyspIHtcbiAgICAgIGNvbnN0IGNocjogbnVtYmVyID0gcy5jaGFyQ29kZUF0KGkpO1xuICAgICAgaGFzaCA9ICgoaGFzaCA8PCA1KSAtIGhhc2gpICsgY2hyO1xuICAgICAgaGFzaCB8PSAwOyAvLyBDb252ZXJ0IHRvIDMyYml0IGludGVnZXJcbiAgICB9XG4gICAgcmV0dXJuIGhhc2g7XG4gIH1cbn1cblxuaW1wb3J0IHtTZXFQYWxldHRlLCBTZXFQYWxldHRlQmFzZX0gZnJvbSAnLi9zZXEtcGFsZXR0ZXMnO1xuXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgVW5rbm93blNlcVBhbGV0dGUgaW1wbGVtZW50cyBTZXFQYWxldHRlIHtcbiAgcHVibGljIGFic3RyYWN0IGdldChtOiBzdHJpbmcpOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjbGFzcyBHcmF5QWxsUGFsZXR0ZSBleHRlbmRzIFVua25vd25TZXFQYWxldHRlIHtcbiAgcHVibGljIGdldChtOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiAnIzY2NjY2Nic7XG4gIH1cbn1cblxuXG5leHBvcnQgY2xhc3MgVW5rbm93bkNvbG9yUGFsZXR0ZSBleHRlbmRzIFVua25vd25TZXFQYWxldHRlIHtcbiAgcHVibGljIHN0YXRpYyBwYWxldHRlOiBzdHJpbmdbXSA9IFVua25vd25Db2xvclBhbGV0dGUuYnVpbGRQYWxldHRlKCk7XG5cbiAgcHJpdmF0ZSBzdGF0aWMgYnVpbGRQYWxldHRlKCk6IHN0cmluZ1tdIHtcbiAgICBjb25zdCByZXMgPSAoW10gYXMgc3RyaW5nW10pLmNvbmNhdCguLi5PYmplY3QudmFsdWVzKFNlcVBhbGV0dGVCYXNlLmNvbG91clBhbGV0dGUpKTtcbiAgICByZXR1cm4gcmVzO1xuICB9XG5cbiAgcHVibGljIGdldChtOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIGNvbnN0IGhhc2g6IG51bWJlciA9IFN0cmluZ1V0aWxzLmhhc2hDb2RlKG0pO1xuICAgIGNvbnN0IHBJID0gaGFzaCAlIFVua25vd25Db2xvclBhbGV0dGUucGFsZXR0ZS5sZW5ndGg7XG4gICAgcmV0dXJuIGNvcnJlY3RDb2xvcihVbmtub3duQ29sb3JQYWxldHRlLnBhbGV0dGVbcEldKTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgVW5rbm93blNlcVBhbGV0dGVzIGV4dGVuZHMgU2VxUGFsZXR0ZUJhc2Uge1xuICBwcml2YXRlIHN0YXRpYyBncmF5OiBTZXFQYWxldHRlO1xuXG4gIHB1YmxpYyBzdGF0aWMgZ2V0IEdyYXkoKTogU2VxUGFsZXR0ZSB7XG4gICAgaWYgKHRoaXMuZ3JheSA9PT0gdm9pZCAwKVxuICAgICAgdGhpcy5ncmF5ID0gbmV3IEdyYXlBbGxQYWxldHRlKCk7XG4gICAgcmV0dXJuIHRoaXMuZ3JheTtcbiAgfVxuXG4gIHByaXZhdGUgc3RhdGljIGNvbG9yOiBTZXFQYWxldHRlO1xuXG4gIHB1YmxpYyBzdGF0aWMgZ2V0IENvbG9yKCk6IFNlcVBhbGV0dGUge1xuICAgIGlmICh0aGlzLmNvbG9yID09PSB2b2lkIDApXG4gICAgICB0aGlzLmNvbG9yID0gbmV3IFVua25vd25Db2xvclBhbGV0dGUoKTtcbiAgICByZXR1cm4gdGhpcy5jb2xvcjtcbiAgfVxufVxuIl19
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import * as DG from 'datagrok-api/dg';
|
|
1
2
|
export declare enum DrawStyle {
|
|
2
3
|
MSA = "MSA",
|
|
3
4
|
classic = "classic"
|
|
@@ -19,11 +20,13 @@ export declare enum DrawStyle {
|
|
|
19
20
|
* @param {boolean} [last=false] Is checker if element last or not.
|
|
20
21
|
* @param drawStyle Is draw style. MSA - for multicharSeq, classic - for other seq.
|
|
21
22
|
* @param maxWord Is array of max words for each line.
|
|
22
|
-
* @param
|
|
23
|
-
* @param gridCell Is grid cell
|
|
23
|
+
* @param wordIdx Is index of word we currently draw.
|
|
24
|
+
* @param gridCell Is grid cell.
|
|
25
|
+
* @param referenceSequence Is reference sequence for diff mode.
|
|
26
|
+
* @param maxLengthOfMonomer Is max length of monomer.
|
|
24
27
|
* @return {number} x coordinate to start printing at.
|
|
25
28
|
*/
|
|
26
29
|
export declare function printLeftOrCentered(x: number, y: number, w: number, h: number, g: CanvasRenderingContext2D, s: string, color?: string, pivot?: number, left?: boolean, transparencyRate?: number, separator?: string, last?: boolean, drawStyle?: DrawStyle, maxWord?: {
|
|
27
30
|
[index: string]: number;
|
|
28
|
-
},
|
|
31
|
+
}, wordIdx?: number, gridCell?: DG.GridCell | null, referenceSequence?: string[], maxLengthOfMonomer?: number | null): number;
|
|
29
32
|
//# sourceMappingURL=cell-renderer.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cell-renderer.d.ts","sourceRoot":"","sources":["cell-renderer.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"cell-renderer.d.ts","sourceRoot":"","sources":["cell-renderer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAQtC,oBAAY,SAAS;IACnB,GAAG,QAAQ;IACX,OAAO,YAAY;CACpB;AAED;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,wBAAgB,mBAAmB,CACjC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAC1C,CAAC,EAAE,wBAAwB,EAAE,CAAC,EAAE,MAAM,EAAE,KAAK,GAAE,MAAuB,EACtE,KAAK,GAAE,MAAU,EAAE,IAAI,UAAQ,EAAE,gBAAgB,GAAE,MAAY,EAC/D,SAAS,GAAE,MAAW,EAAE,IAAI,GAAE,OAAe,EAAE,SAAS,GAAE,SAA6B,EAAE,OAAO,GAAE;IAAE,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAAA;CAAO,EAAE,OAAO,GAAE,MAAU,EAAE,QAAQ,GAAE,EAAE,CAAC,QAAQ,GAAG,IAAW,EAAE,iBAAiB,GAAE,MAAM,EAAO,EAAE,kBAAkB,GAAE,MAAM,GAAG,IAAW,GAAG,MAAM,CA0DlR"}
|
|
@@ -1,5 +1,8 @@
|
|
|
1
|
+
import { WebLogo } from '../viewers/web-logo';
|
|
1
2
|
const undefinedColor = 'rgb(100,100,100)';
|
|
2
3
|
const grayColor = '#808080';
|
|
4
|
+
const blackColor = 'rgb(0,0,0)';
|
|
5
|
+
const monomerToShortFunction = WebLogo.monomerToShort;
|
|
3
6
|
export var DrawStyle;
|
|
4
7
|
(function (DrawStyle) {
|
|
5
8
|
DrawStyle["MSA"] = "MSA";
|
|
@@ -22,18 +25,33 @@ export var DrawStyle;
|
|
|
22
25
|
* @param {boolean} [last=false] Is checker if element last or not.
|
|
23
26
|
* @param drawStyle Is draw style. MSA - for multicharSeq, classic - for other seq.
|
|
24
27
|
* @param maxWord Is array of max words for each line.
|
|
25
|
-
* @param
|
|
26
|
-
* @param gridCell Is grid cell
|
|
28
|
+
* @param wordIdx Is index of word we currently draw.
|
|
29
|
+
* @param gridCell Is grid cell.
|
|
30
|
+
* @param referenceSequence Is reference sequence for diff mode.
|
|
31
|
+
* @param maxLengthOfMonomer Is max length of monomer.
|
|
27
32
|
* @return {number} x coordinate to start printing at.
|
|
28
33
|
*/
|
|
29
|
-
export function printLeftOrCentered(x, y, w, h, g, s, color = undefinedColor, pivot = 0, left = false, transparencyRate = 1.0, separator = '', last = false, drawStyle = DrawStyle.classic, maxWord = {},
|
|
30
|
-
var _a;
|
|
34
|
+
export function printLeftOrCentered(x, y, w, h, g, s, color = undefinedColor, pivot = 0, left = false, transparencyRate = 1.0, separator = '', last = false, drawStyle = DrawStyle.classic, maxWord = {}, wordIdx = 0, gridCell = null, referenceSequence = [], maxLengthOfMonomer = null) {
|
|
35
|
+
var _a, _b;
|
|
31
36
|
g.textAlign = 'start';
|
|
32
|
-
|
|
37
|
+
let colorPart = s.substring(0);
|
|
33
38
|
let grayPart = last ? '' : separator;
|
|
34
39
|
if (drawStyle === DrawStyle.MSA) {
|
|
35
40
|
grayPart = '';
|
|
36
41
|
}
|
|
42
|
+
let colorCode = true;
|
|
43
|
+
let compareWithCurrent = true;
|
|
44
|
+
if (gridCell != null) {
|
|
45
|
+
colorCode = (((_a = gridCell.cell.column) === null || _a === void 0 ? void 0 : _a.temp['color-code']) != null) ? gridCell.cell.column.temp['color-code'] : true;
|
|
46
|
+
compareWithCurrent = (((_b = gridCell.cell.column) === null || _b === void 0 ? void 0 : _b.temp['compare-with-current']) != null) ? gridCell.cell.column.temp['compare-with-current'] : true;
|
|
47
|
+
}
|
|
48
|
+
const currentMonomer = referenceSequence[wordIdx];
|
|
49
|
+
if (compareWithCurrent && (referenceSequence.length > 0)) {
|
|
50
|
+
transparencyRate = (colorPart == currentMonomer) ? 0.3 : transparencyRate;
|
|
51
|
+
}
|
|
52
|
+
if (maxLengthOfMonomer != null) {
|
|
53
|
+
colorPart = monomerToShortFunction(colorPart, maxLengthOfMonomer);
|
|
54
|
+
}
|
|
37
55
|
let textSize = g.measureText(colorPart + grayPart);
|
|
38
56
|
const indent = 5;
|
|
39
57
|
let maxColorTextSize = g.measureText(colorPart).width;
|
|
@@ -41,15 +59,12 @@ export function printLeftOrCentered(x, y, w, h, g, s, color = undefinedColor, pi
|
|
|
41
59
|
const dy = (textSize.fontBoundingBoxAscent + textSize.fontBoundingBoxDescent) / 2;
|
|
42
60
|
textSize = textSize.width;
|
|
43
61
|
if (drawStyle === DrawStyle.MSA) {
|
|
44
|
-
maxColorTextSize = maxWord[
|
|
45
|
-
textSize = maxWord[
|
|
46
|
-
if (maxWordIdx > ((_a = maxWord['bio-maxIndex']) !== null && _a !== void 0 ? _a : 0)) {
|
|
47
|
-
maxWord['bio-maxIndex'] = maxWordIdx;
|
|
48
|
-
gridCell.cell.column.temp = maxWord;
|
|
49
|
-
}
|
|
62
|
+
maxColorTextSize = maxWord[wordIdx];
|
|
63
|
+
textSize = maxWord[wordIdx];
|
|
50
64
|
}
|
|
51
65
|
function draw(dx1, dx2) {
|
|
52
|
-
|
|
66
|
+
const drawColor = colorCode ? color : blackColor;
|
|
67
|
+
g.fillStyle = drawColor;
|
|
53
68
|
g.globalAlpha = transparencyRate;
|
|
54
69
|
if (drawStyle === DrawStyle.classic) {
|
|
55
70
|
g.fillText(colorPart, x + dx1, y + dy);
|
|
@@ -57,8 +72,8 @@ export function printLeftOrCentered(x, y, w, h, g, s, color = undefinedColor, pi
|
|
|
57
72
|
g.fillText(grayPart, x + dx2, y + dy);
|
|
58
73
|
}
|
|
59
74
|
if (drawStyle === DrawStyle.MSA) {
|
|
60
|
-
g.fillStyle =
|
|
61
|
-
g.fillText(colorPart, x + dx1 + ((maxWord[
|
|
75
|
+
g.fillStyle = drawColor;
|
|
76
|
+
g.fillText(colorPart, x + dx1 + ((maxWord[wordIdx] - colorTextSize) / 2), y + dy);
|
|
62
77
|
}
|
|
63
78
|
}
|
|
64
79
|
if (left || textSize > w) {
|
|
@@ -71,4 +86,4 @@ export function printLeftOrCentered(x, y, w, h, g, s, color = undefinedColor, pi
|
|
|
71
86
|
return x + dx + maxColorTextSize;
|
|
72
87
|
}
|
|
73
88
|
}
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell-renderer.js","sourceRoot":"","sources":["cell-renderer.ts"],"names":[],"mappings":"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","sourcesContent":["import * as DG from 'datagrok-api/dg';\nimport {SplitterFunc, WebLogo} from '../viewers/web-logo';\n\nconst undefinedColor = 'rgb(100,100,100)';\nconst grayColor = '#808080';\nconst blackColor = 'rgb(0,0,0)';\nconst monomerToShortFunction: (amino: string, maxLengthOfMonomer: number) => string = WebLogo.monomerToShort;\n\nexport enum DrawStyle {\n  MSA = 'MSA',\n  classic = 'classic',\n}\n\n/**\n * A function that prints a string aligned to left or centered.\n *\n * @param {number} x x coordinate.\n * @param {number} y y coordinate.\n * @param {number} w Width.\n * @param {number} h Height.\n * @param {CanvasRenderingContext2D} g Canvas rendering context.\n * @param {string} s String to print.\n * @param {string} [color=undefinedColor] String color.\n * @param {number} [pivot=0] Pirvot.\n * @param {boolean} [left=false] Is left aligned.\n * @param {number} [transparencyRate=0.0] Transparency rate where 1.0 is fully transparent\n * @param {string} [separator=''] Is separator for sequence.\n * @param {boolean} [last=false] Is checker if element last or not.\n * @param drawStyle Is draw style. MSA - for multicharSeq, classic - for other seq.\n * @param maxWord Is array of max words for each line.\n * @param wordIdx Is index of word we currently draw.\n * @param gridCell Is grid cell.\n * @param referenceSequence Is reference sequence for diff mode.\n * @param maxLengthOfMonomer Is max length of monomer.\n * @return {number} x coordinate to start printing at.\n */\nexport function printLeftOrCentered(\n  x: number, y: number, w: number, h: number,\n  g: CanvasRenderingContext2D, s: string, color: string = undefinedColor,\n  pivot: number = 0, left = false, transparencyRate: number = 1.0,\n  separator: string = '', last: boolean = false, drawStyle: DrawStyle = DrawStyle.classic, maxWord: { [index: string]: number } = {}, wordIdx: number = 0, gridCell: DG.GridCell | null = null, referenceSequence: string[] = [], maxLengthOfMonomer: number | null = null): number {\n  g.textAlign = 'start';\n  let colorPart = s.substring(0);\n  let grayPart = last ? '' : separator;\n  if (drawStyle === DrawStyle.MSA) {\n    grayPart = '';\n  }\n  let colorCode = true;\n  let compareWithCurrent = true;\n  if (gridCell != null) {\n    colorCode = (gridCell.cell.column?.temp['color-code'] != null) ? gridCell.cell.column.temp['color-code'] : true;\n    compareWithCurrent = (gridCell.cell.column?.temp['compare-with-current'] != null) ? gridCell.cell.column.temp['compare-with-current'] : true;\n  }\n  const currentMonomer: string = referenceSequence[wordIdx];\n  if (compareWithCurrent && (referenceSequence.length > 0)) {\n    transparencyRate = (colorPart == currentMonomer) ? 0.3 : transparencyRate;\n  }\n  if (maxLengthOfMonomer != null) {\n    colorPart = monomerToShortFunction(colorPart, maxLengthOfMonomer);\n  }\n\n\n  let textSize: any = g.measureText(colorPart + grayPart);\n  const indent = 5;\n\n  let maxColorTextSize = g.measureText(colorPart).width;\n  let colorTextSize = g.measureText(colorPart).width;\n  const dy = (textSize.fontBoundingBoxAscent + textSize.fontBoundingBoxDescent) / 2;\n  textSize = textSize.width;\n  if (drawStyle === DrawStyle.MSA) {\n    maxColorTextSize = maxWord[wordIdx];\n    textSize = maxWord[wordIdx];\n  }\n\n  function draw(dx1: number, dx2: number): void {\n    const drawColor = colorCode ? color : blackColor;\n    g.fillStyle = drawColor;\n    g.globalAlpha = transparencyRate;\n    if (drawStyle === DrawStyle.classic) {\n      g.fillText(colorPart, x + dx1, y + dy);\n      g.fillStyle = grayColor;\n      g.fillText(grayPart, x + dx2, y + dy);\n    }\n    if (drawStyle === DrawStyle.MSA) {\n      g.fillStyle = drawColor;\n      g.fillText(colorPart, x + dx1 + ((maxWord[wordIdx] - colorTextSize) / 2), y + dy);\n    }\n  }\n\n  if (left || textSize > w) {\n    draw(indent, indent + maxColorTextSize);\n    return x + maxColorTextSize + g.measureText(grayPart).width;\n\n  } else {\n    const dx = (w - textSize) / 2;\n    draw(dx, dx + maxColorTextSize);\n    return x + dx + maxColorTextSize;\n  }\n}\n\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import * as DG from 'datagrok-api/dg';
|
|
2
|
+
import { VdRegion } from '../vd-regions';
|
|
3
|
+
/** Interface for VdRegionsViewer from @datagrok/bio to unbind dependency to Bio package */
|
|
4
|
+
export interface IVdRegionsViewer {
|
|
5
|
+
get root(): HTMLElement;
|
|
6
|
+
init(): Promise<void>;
|
|
7
|
+
setDf(mlbDf: DG.DataFrame, regions: VdRegion[]): Promise<void>;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=vd-regions-viewer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vd-regions-viewer.d.ts","sourceRoot":"","sources":["vd-regions-viewer.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAEtC,OAAO,EAAC,QAAQ,EAAC,MAAM,eAAe,CAAC;AAEvC,2FAA2F;AAC3F,MAAM,WAAW,gBAAgB;IAC/B,IAAI,IAAI,IAAI,WAAW,CAAC;IAExB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEtB,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAChE"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmQtcmVnaW9ucy12aWV3ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ2ZC1yZWdpb25zLXZpZXdlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgdWkgZnJvbSAnZGF0YWdyb2stYXBpL3VpJztcbmltcG9ydCAqIGFzIGdyb2sgZnJvbSAnZGF0YWdyb2stYXBpL2dyb2snO1xuaW1wb3J0ICogYXMgREcgZnJvbSAnZGF0YWdyb2stYXBpL2RnJztcblxuaW1wb3J0IHtWZFJlZ2lvbn0gZnJvbSAnLi4vdmQtcmVnaW9ucyc7XG5cbi8qKiBJbnRlcmZhY2UgZm9yIFZkUmVnaW9uc1ZpZXdlciBmcm9tIEBkYXRhZ3Jvay9iaW8gdG8gdW5iaW5kIGRlcGVuZGVuY3kgdG8gQmlvIHBhY2thZ2UgKi9cbmV4cG9ydCBpbnRlcmZhY2UgSVZkUmVnaW9uc1ZpZXdlciB7XG4gIGdldCByb290KCk6IEhUTUxFbGVtZW50O1xuXG4gIGluaXQoKTogUHJvbWlzZTx2b2lkPjtcblxuICBzZXREZihtbGJEZjogREcuRGF0YUZyYW1lLCByZWdpb25zOiBWZFJlZ2lvbltdKTogUHJvbWlzZTx2b2lkPjtcbn0iXX0=
|
|
@@ -19,11 +19,9 @@ export declare type SeqColStats = {
|
|
|
19
19
|
};
|
|
20
20
|
export declare type SplitterFunc = (seq: string) => string[];
|
|
21
21
|
export declare class PositionMonomerInfo {
|
|
22
|
-
/** Sequences count with monomer in position
|
|
23
|
-
*/
|
|
22
|
+
/** Sequences count with monomer in position */
|
|
24
23
|
count: number;
|
|
25
|
-
/** Remember screen coords rect
|
|
26
|
-
*/
|
|
24
|
+
/** Remember screen coords rect */
|
|
27
25
|
bounds: DG.Rect;
|
|
28
26
|
constructor(count?: number, bounds?: DG.Rect);
|
|
29
27
|
}
|
|
@@ -47,26 +45,30 @@ export declare class PositionInfo {
|
|
|
47
45
|
export declare class WebLogo extends DG.JsViewer {
|
|
48
46
|
static residuesSet: string;
|
|
49
47
|
private static viewerCount;
|
|
50
|
-
private viewerId;
|
|
48
|
+
private readonly viewerId;
|
|
51
49
|
private unitsHandler;
|
|
52
50
|
private initialized;
|
|
53
51
|
protected cp: SeqPalette | null;
|
|
54
52
|
private host?;
|
|
55
53
|
private msgHost?;
|
|
56
|
-
private canvas
|
|
57
|
-
private slider
|
|
58
|
-
private textBaseline;
|
|
54
|
+
private canvas;
|
|
55
|
+
private slider;
|
|
56
|
+
private readonly textBaseline;
|
|
59
57
|
private axisHeight;
|
|
60
58
|
private seqCol;
|
|
61
59
|
private splitter;
|
|
62
60
|
private positions;
|
|
63
61
|
private rowsMasked;
|
|
64
62
|
private rowsNull;
|
|
63
|
+
private visibleSlider;
|
|
64
|
+
private allowResize;
|
|
65
|
+
private currentRange;
|
|
65
66
|
private _positionWidth;
|
|
66
67
|
positionWidth: number;
|
|
67
68
|
minHeight: number;
|
|
69
|
+
backgroundColor: number;
|
|
68
70
|
maxHeight: number;
|
|
69
|
-
|
|
71
|
+
skipEmptySequences: boolean;
|
|
70
72
|
sequenceColumnName: string | null;
|
|
71
73
|
positionMarginState: string;
|
|
72
74
|
positionMargin: number;
|
|
@@ -84,25 +86,49 @@ export declare class WebLogo extends DG.JsViewer {
|
|
|
84
86
|
private endPosition;
|
|
85
87
|
/** For startPosition equals to endPosition Length is 1 */
|
|
86
88
|
private get Length();
|
|
89
|
+
/** Calculate new position data basic on {@link positionMarginState} and {@link positionMargin} */
|
|
87
90
|
private get positionWidthWithMargin();
|
|
91
|
+
private get positionMarginValue();
|
|
92
|
+
/** Count of position rendered for calculations countOfRenderPositions */
|
|
93
|
+
private get countOfRenderPositions();
|
|
94
|
+
/** Position of start rendering */
|
|
95
|
+
private get firstVisibleIndex();
|
|
88
96
|
private viewSubs;
|
|
89
97
|
constructor();
|
|
90
98
|
private init;
|
|
99
|
+
/** Handler of changing size WebLogo */
|
|
91
100
|
private rootOnSizeChanged;
|
|
92
101
|
/** Assigns {@link seqCol} and {@link cp} based on {@link sequenceColumnName} and calls {@link render}().
|
|
93
102
|
*/
|
|
94
103
|
private updateSeqCol;
|
|
104
|
+
/** Updates {@link positionNames} and calculates {@link startPosition} and {@link endPosition}.
|
|
105
|
+
*/
|
|
95
106
|
private updatePositions;
|
|
107
|
+
private checkIsHideSlider;
|
|
108
|
+
setSliderVisibility(visible: boolean): void;
|
|
109
|
+
/** Sets {@link slider}, needed to set slider options and to update slider position.
|
|
110
|
+
*/
|
|
111
|
+
private setSlider;
|
|
112
|
+
/** Handler of property change events. */
|
|
96
113
|
onPropertyChanged(property: DG.Property): void;
|
|
97
|
-
|
|
114
|
+
/** Add filter handlers when table is a attached */
|
|
115
|
+
onTableAttached(): void;
|
|
116
|
+
/** Remove all handlers when table is a detach */
|
|
98
117
|
detach(): Promise<void>;
|
|
118
|
+
/** Helper function for rendering */
|
|
99
119
|
protected _nullSequence(fillerResidue?: string): string;
|
|
120
|
+
/** Helper function for remove empty positions */
|
|
100
121
|
protected removeWhere(array: Array<any>, predicate: (T: any) => boolean): Array<any>;
|
|
122
|
+
/** Function for removing empty positions */
|
|
101
123
|
protected _removeEmptyPositions(): void;
|
|
102
124
|
protected _calculate(r: number): void;
|
|
125
|
+
/** Render WebLogo sensitive to changes in params of rendering
|
|
126
|
+
*@param {boolean} recalc - indicates that need to recalculate data for rendering
|
|
127
|
+
*/
|
|
103
128
|
render(recalc?: boolean): void;
|
|
129
|
+
/** Calculate canvas size an positionWidth and updates properties */
|
|
104
130
|
private calcSize;
|
|
105
|
-
/**
|
|
131
|
+
/** Selects a suitable palette based on column data
|
|
106
132
|
* @param {DG.Column} seqCol Column to look for a palette
|
|
107
133
|
* @param {number} minLength minimum length of sequence to detect palette (empty strings are allowed)
|
|
108
134
|
* @return {SeqPalette} Palette corresponding to the alphabet of the sequences in the column
|
|
@@ -116,9 +142,17 @@ export declare class WebLogo extends DG.JsViewer {
|
|
|
116
142
|
* @return { SeqColStats }, sameLength: boolean } stats of column sequences
|
|
117
143
|
*/
|
|
118
144
|
static getStats(seqCol: DG.Column, minLength: number, splitter: SplitterFunc): SeqColStats;
|
|
145
|
+
/** Calculate similarity in current sequence and alphabet.
|
|
146
|
+
* @param {MonomerFreqs} freq
|
|
147
|
+
* @param {Set<string>} alphabet
|
|
148
|
+
* @param {string} gapSymbol
|
|
149
|
+
* @return {number} Cosine similarity
|
|
150
|
+
*/
|
|
119
151
|
static getAlphabetSimilarity(freq: MonomerFreqs, alphabet: Set<string>, gapSymbol?: string): number;
|
|
120
|
-
static
|
|
152
|
+
static pickUpSeqCol(df: DG.DataFrame): DG.Column | null;
|
|
121
153
|
private static monomerRe;
|
|
154
|
+
/** Only some of the synonyms. These were obtained from the clustered oligopeptide dataset. */
|
|
155
|
+
private static aaSynonyms;
|
|
122
156
|
/** Split sequence for single character monomers, square brackets multichar monomer names or gap symbol.
|
|
123
157
|
* @param {any} seq object with sequence
|
|
124
158
|
* @return {string[]} array of monomers
|
|
@@ -145,9 +179,13 @@ export declare class WebLogo extends DG.JsViewer {
|
|
|
145
179
|
* @return {SplitterFunc}
|
|
146
180
|
*/
|
|
147
181
|
static getSplitter(units: string, separator: string, limit?: number | undefined): SplitterFunc;
|
|
182
|
+
/** Generate splitter function for sequence column
|
|
183
|
+
* @param {DG.Column} col
|
|
184
|
+
* @return {SplitterFunc} Splitter function
|
|
185
|
+
*/
|
|
148
186
|
static getSplitterForColumn(col: DG.Column): SplitterFunc;
|
|
149
187
|
private static longMonomerPartRe;
|
|
150
|
-
|
|
188
|
+
/** Convert long monomer names to short ones */
|
|
151
189
|
static monomerToShort(amino: string, maxLengthOfMonomer: number): string;
|
|
152
190
|
}
|
|
153
191
|
//# sourceMappingURL=web-logo.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"web-logo.d.ts","sourceRoot":"","sources":["web-logo.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAUtC,OAAO,EAAC,UAAU,EAAC,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"web-logo.d.ts","sourceRoot":"","sources":["web-logo.ts"],"names":[],"mappings":"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"}
|