@datagrok-libraries/bio 3.0.4 → 3.1.1

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 CHANGED
@@ -5,13 +5,13 @@
5
5
  },
6
6
  "beta": true,
7
7
  "friendlyName": "Datagrok bio library",
8
- "version": "3.0.4",
8
+ "version": "3.1.1",
9
9
  "description": "",
10
10
  "dependencies": {
11
- "@datagrok-libraries/utils": "^1.0.0",
11
+ "@datagrok-libraries/utils": "^1.6.2",
12
12
  "@types/wu": "latest",
13
13
  "cash-dom": "latest",
14
- "datagrok-api": "^1.4.12",
14
+ "datagrok-api": "^1.6.0",
15
15
  "dayjs": "latest",
16
16
  "rxjs": "^6.5.5",
17
17
  "wu": "latest"
@@ -0,0 +1,6 @@
1
+ export declare class MonomerWorks {
2
+ monomerLibs: string[] | null;
3
+ acceptedMonomers: Set<string> | null;
4
+ constructor();
5
+ }
6
+ //# sourceMappingURL=monomer-works.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"monomer-works.d.ts","sourceRoot":"","sources":["monomer-works.ts"],"names":[],"mappings":"AAKA,qBAAa,YAAY;IACvB,WAAW,EAAE,MAAM,EAAE,GAAG,IAAI,CAAQ;IACpC,gBAAgB,EAAE,GAAG,CAAC,MAAM,CAAC,GAAG,IAAI,CAAQ;;CAwB7C"}
@@ -0,0 +1,7 @@
1
+ export class MonomerWorks {
2
+ constructor() {
3
+ this.monomerLibs = null;
4
+ this.acceptedMonomers = null;
5
+ }
6
+ }
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9ub21lci13b3Jrcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIm1vbm9tZXItd29ya3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0EsTUFBTSxPQUFPLFlBQVk7SUFJdkI7UUFIQSxnQkFBVyxHQUFvQixJQUFJLENBQUM7UUFDcEMscUJBQWdCLEdBQXVCLElBQUksQ0FBQztJQUk1QyxDQUFDO0NBb0JGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgZ3JvayBmcm9tICdkYXRhZ3Jvay1hcGkvZ3Jvayc7XG5pbXBvcnQgKiBhcyB1aSBmcm9tICdkYXRhZ3Jvay1hcGkvdWknO1xuaW1wb3J0ICogYXMgREcgZnJvbSAnZGF0YWdyb2stYXBpL2RnJztcbmltcG9ydCB7U2VxUGFsZXR0ZX0gZnJvbSAnLi9zZXEtcGFsZXR0ZXMnO1xuXG5leHBvcnQgY2xhc3MgTW9ub21lcldvcmtzIHtcbiAgbW9ub21lckxpYnM6IHN0cmluZ1tdIHwgbnVsbCA9IG51bGw7XG4gIGFjY2VwdGVkTW9ub21lcnM6IFNldDxzdHJpbmc+IHwgbnVsbCA9IG51bGw7XG5cbiAgY29uc3RydWN0b3IoKSB7XG5cbiAgfVxuXG4gIC8qXG4gIGdldENvbG9ycyhzZXFDb2w6IERHLkNvbHVtbjxzdHJpbmc+LCBtZXRob2Q/OiBzdHJpbmcpOiBTZXFQYWxldHRlIHtcbiAgICBpZiAoIW1ldGhvZCkge1xuICAgICAgLy8gcmV0dXJuIFVua25vd25cbiAgICAgIGlmICgpIHt9IC8vbW9ub21lciBub3QgaW4gYWNjZXB0ZWRNb25vbWVycyBjb2xvciBpdCByZWRcblxuICAgIH0gZWxzZSB7XG4gICAgICBzd2l0Y2ggKG1ldGhvZCkge1xuICAgICAgICBjYXNlIDpcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ05vdCBpbXBsZW1lbnRlZCcpO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiA7XG4gIH1cbiAgKi9cbn1cbiJdfQ==
@@ -0,0 +1,19 @@
1
+ /**
2
+ * A function that prints a string aligned to left or centered.
3
+ *
4
+ * @param {number} x x coordinate.
5
+ * @param {number} y y coordinate.
6
+ * @param {number} w Width.
7
+ * @param {number} h Height.
8
+ * @param {CanvasRenderingContext2D} g Canvas rendering context.
9
+ * @param {string} s String to print.
10
+ * @param {string} [color=undefinedColor] String color.
11
+ * @param {number} [pivot=0] Pirvot.
12
+ * @param {boolean} [left=false] Is left aligned.
13
+ * @param {number} [transparencyRate=0.0] Transparency rate where 1.0 is fully transparent
14
+ * @param {string} [separator=''] Is separator for sequence.
15
+ * @param {boolean} [last=false] Is checker if element last or not.
16
+ * @return {number} x coordinate to start printing at.
17
+ */
18
+ 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?: string, maxWord?: any, maxWordIdx?: number, gridCell?: any): number;
19
+ //# sourceMappingURL=cell-renderer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cell-renderer.d.ts","sourceRoot":"","sources":["cell-renderer.ts"],"names":[],"mappings":"AAGA;;;;;;;;;;;;;;;;GAgBG;AACF,wBAAgB,mBAAmB,CAChC,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,SAAiB,EAC9D,KAAK,GAAE,MAAU,EAAE,IAAI,UAAQ,EAAE,gBAAgB,GAAE,MAAY,EAC/D,SAAS,GAAE,MAAW,EAAE,IAAI,GAAE,OAAe,EAAE,SAAS,GAAE,MAAkB,EAAE,OAAO,GAAE,GAAQ,EAAE,UAAU,GAAE,MAAU,EAAE,QAAQ,GAAE,GAAQ,GAAG,MAAM,CAmDrJ"}
@@ -0,0 +1,69 @@
1
+ const undefinedColor = 'rgb(100,100,100)';
2
+ const grayColor = '#808080';
3
+ /**
4
+ * A function that prints a string aligned to left or centered.
5
+ *
6
+ * @param {number} x x coordinate.
7
+ * @param {number} y y coordinate.
8
+ * @param {number} w Width.
9
+ * @param {number} h Height.
10
+ * @param {CanvasRenderingContext2D} g Canvas rendering context.
11
+ * @param {string} s String to print.
12
+ * @param {string} [color=undefinedColor] String color.
13
+ * @param {number} [pivot=0] Pirvot.
14
+ * @param {boolean} [left=false] Is left aligned.
15
+ * @param {number} [transparencyRate=0.0] Transparency rate where 1.0 is fully transparent
16
+ * @param {string} [separator=''] Is separator for sequence.
17
+ * @param {boolean} [last=false] Is checker if element last or not.
18
+ * @return {number} x coordinate to start printing at.
19
+ */
20
+ export function printLeftOrCentered(x, y, w, h, g, s, color = undefinedColor, pivot = 0, left = false, transparencyRate = 1.0, separator = '', last = false, drawStyle = 'classic', maxWord = {}, maxWordIdx = 0, gridCell = {}) {
21
+ var _a;
22
+ g.textAlign = 'start';
23
+ const colorPart = s.substring(0);
24
+ let grayPart = last ? '' : separator;
25
+ if (drawStyle === 'msa') {
26
+ grayPart = '';
27
+ }
28
+ let textSize = g.measureText(colorPart + grayPart);
29
+ const indent = 5;
30
+ let maxColorTextSize = g.measureText(colorPart).width;
31
+ let colorTextSize = g.measureText(colorPart).width;
32
+ const dy = (textSize.fontBoundingBoxAscent + textSize.fontBoundingBoxDescent) / 2;
33
+ textSize = textSize.width;
34
+ if (drawStyle === 'msa') {
35
+ maxColorTextSize = maxWord[maxWordIdx];
36
+ textSize = maxWord[maxWordIdx];
37
+ if (maxColorTextSize > maxWord) {
38
+ maxWord[maxWordIdx] = maxColorTextSize;
39
+ gridCell.cell.column.temp = maxWord;
40
+ }
41
+ if (maxWordIdx > ((_a = maxWord['bio-maxIndex']) !== null && _a !== void 0 ? _a : 0)) {
42
+ maxWord['bio-maxIndex'] = maxWordIdx;
43
+ gridCell.cell.column.temp = maxWord;
44
+ }
45
+ }
46
+ function draw(dx1, dx2) {
47
+ g.fillStyle = color;
48
+ g.globalAlpha = transparencyRate;
49
+ if (drawStyle === 'classic') {
50
+ g.fillText(colorPart, x + dx1, y + dy);
51
+ g.fillStyle = grayColor;
52
+ g.fillText(grayPart, x + dx2, y + dy);
53
+ }
54
+ if (drawStyle === 'msa') {
55
+ g.fillStyle = color;
56
+ g.fillText(colorPart, x + dx1 + ((maxWord[maxWordIdx] - colorTextSize) / 2), y + dy);
57
+ }
58
+ }
59
+ if (left || textSize > w) {
60
+ draw(indent, indent + maxColorTextSize);
61
+ return x + maxColorTextSize + g.measureText(grayPart).width;
62
+ }
63
+ else {
64
+ const dx = (w - textSize) / 2;
65
+ draw(dx, dx + maxColorTextSize);
66
+ return x + dx + maxColorTextSize;
67
+ }
68
+ }
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VsbC1yZW5kZXJlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImNlbGwtcmVuZGVyZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxjQUFjLEdBQUcsa0JBQWtCLENBQUM7QUFDMUMsTUFBTSxTQUFTLEdBQUcsU0FBUyxDQUFDO0FBRTVCOzs7Ozs7Ozs7Ozs7Ozs7O0dBZ0JHO0FBQ0YsTUFBTSxVQUFVLG1CQUFtQixDQUNoQyxDQUFTLEVBQUUsQ0FBUyxFQUFFLENBQVMsRUFBRSxDQUFTLEVBQzFDLENBQTJCLEVBQUUsQ0FBUyxFQUFFLEtBQUssR0FBRyxjQUFjLEVBQzlELFFBQWdCLENBQUMsRUFBRSxJQUFJLEdBQUcsS0FBSyxFQUFFLG1CQUEyQixHQUFHLEVBQy9ELFlBQW9CLEVBQUUsRUFBRSxPQUFnQixLQUFLLEVBQUUsWUFBb0IsU0FBUyxFQUFFLFVBQWUsRUFBRSxFQUFFLGFBQXFCLENBQUMsRUFBRSxXQUFnQixFQUFFOztJQUMzSSxDQUFDLENBQUMsU0FBUyxHQUFHLE9BQU8sQ0FBQztJQUN0QixNQUFNLFNBQVMsR0FBRyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ2pDLElBQUksUUFBUSxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7SUFDckMsSUFBSSxTQUFTLEtBQUssS0FBSyxFQUFFO1FBQ3ZCLFFBQVEsR0FBRyxFQUFFLENBQUM7S0FDZjtJQUVELElBQUksUUFBUSxHQUFRLENBQUMsQ0FBQyxXQUFXLENBQUMsU0FBUyxHQUFHLFFBQVEsQ0FBQyxDQUFDO0lBQ3hELE1BQU0sTUFBTSxHQUFHLENBQUMsQ0FBQztJQUVqQixJQUFJLGdCQUFnQixHQUFHLENBQUMsQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDLENBQUMsS0FBSyxDQUFDO0lBQ3RELElBQUksYUFBYSxHQUFHLENBQUMsQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDLENBQUMsS0FBSyxDQUFDO0lBQ25ELE1BQU0sRUFBRSxHQUFHLENBQUMsUUFBUSxDQUFDLHFCQUFxQixHQUFHLFFBQVEsQ0FBQyxzQkFBc0IsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNsRixRQUFRLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQztJQUMxQixJQUFJLFNBQVMsS0FBSyxLQUFLLEVBQUU7UUFDdkIsZ0JBQWdCLEdBQUcsT0FBTyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ3ZDLFFBQVEsR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDL0IsSUFBSSxnQkFBZ0IsR0FBRyxPQUFPLEVBQUU7WUFDOUIsT0FBTyxDQUFDLFVBQVUsQ0FBQyxHQUFHLGdCQUFnQixDQUFDO1lBQ3ZDLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksR0FBRyxPQUFPLENBQUM7U0FDckM7UUFDRCxJQUFJLFVBQVUsR0FBRyxDQUFDLE1BQUEsT0FBTyxDQUFDLGNBQWMsQ0FBQyxtQ0FBSSxDQUFDLENBQUMsRUFBRTtZQUMvQyxPQUFPLENBQUMsY0FBYyxDQUFDLEdBQUcsVUFBVSxDQUFDO1lBQ3JDLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksR0FBRyxPQUFPLENBQUM7U0FDckM7S0FDRjtJQUVELFNBQVMsSUFBSSxDQUFDLEdBQVcsRUFBRSxHQUFXO1FBQ3BDLENBQUMsQ0FBQyxTQUFTLEdBQUcsS0FBSyxDQUFDO1FBQ3BCLENBQUMsQ0FBQyxXQUFXLEdBQUcsZ0JBQWdCLENBQUM7UUFDakMsSUFBSSxTQUFTLEtBQUssU0FBUyxFQUFFO1lBQzNCLENBQUMsQ0FBQyxRQUFRLENBQUMsU0FBUyxFQUFFLENBQUMsR0FBRyxHQUFHLEVBQUUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDO1lBQ3ZDLENBQUMsQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO1lBQ3hCLENBQUMsQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUMsR0FBRyxHQUFHLEVBQUUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDO1NBQ3ZDO1FBQ0QsSUFBSSxTQUFTLEtBQUssS0FBSyxFQUFFO1lBQ3ZCLENBQUMsQ0FBQyxTQUFTLEdBQUcsS0FBSyxDQUFDO1lBQ3BCLENBQUMsQ0FBQyxRQUFRLENBQUMsU0FBUyxFQUFFLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsR0FBRyxhQUFhLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUM7U0FDdEY7SUFDSCxDQUFDO0lBRUQsSUFBSSxJQUFJLElBQUksUUFBUSxHQUFHLENBQUMsRUFBRTtRQUN4QixJQUFJLENBQUMsTUFBTSxFQUFFLE1BQU0sR0FBRyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQ3hDLE9BQU8sQ0FBQyxHQUFHLGdCQUFnQixHQUFHLENBQUMsQ0FBQyxXQUFXLENBQUMsUUFBUSxDQUFDLENBQUMsS0FBSyxDQUFDO0tBRTdEO1NBQU07UUFDTCxNQUFNLEVBQUUsR0FBRyxDQUFDLENBQUMsR0FBRyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDOUIsSUFBSSxDQUFDLEVBQUUsRUFBRSxFQUFFLEdBQUcsZ0JBQWdCLENBQUMsQ0FBQztRQUNoQyxPQUFPLENBQUMsR0FBRyxFQUFFLEdBQUcsZ0JBQWdCLENBQUM7S0FDbEM7QUFDSCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgdW5kZWZpbmVkQ29sb3IgPSAncmdiKDEwMCwxMDAsMTAwKSc7XG5jb25zdCBncmF5Q29sb3IgPSAnIzgwODA4MCc7XG5cbi8qKlxuICogQSBmdW5jdGlvbiB0aGF0IHByaW50cyBhIHN0cmluZyBhbGlnbmVkIHRvIGxlZnQgb3IgY2VudGVyZWQuXG4gKlxuICogQHBhcmFtIHtudW1iZXJ9IHggeCBjb29yZGluYXRlLlxuICogQHBhcmFtIHtudW1iZXJ9IHkgeSBjb29yZGluYXRlLlxuICogQHBhcmFtIHtudW1iZXJ9IHcgV2lkdGguXG4gKiBAcGFyYW0ge251bWJlcn0gaCBIZWlnaHQuXG4gKiBAcGFyYW0ge0NhbnZhc1JlbmRlcmluZ0NvbnRleHQyRH0gZyBDYW52YXMgcmVuZGVyaW5nIGNvbnRleHQuXG4gKiBAcGFyYW0ge3N0cmluZ30gcyBTdHJpbmcgdG8gcHJpbnQuXG4gKiBAcGFyYW0ge3N0cmluZ30gW2NvbG9yPXVuZGVmaW5lZENvbG9yXSBTdHJpbmcgY29sb3IuXG4gKiBAcGFyYW0ge251bWJlcn0gW3Bpdm90PTBdIFBpcnZvdC5cbiAqIEBwYXJhbSB7Ym9vbGVhbn0gW2xlZnQ9ZmFsc2VdIElzIGxlZnQgYWxpZ25lZC5cbiAqIEBwYXJhbSB7bnVtYmVyfSBbdHJhbnNwYXJlbmN5UmF0ZT0wLjBdIFRyYW5zcGFyZW5jeSByYXRlIHdoZXJlIDEuMCBpcyBmdWxseSB0cmFuc3BhcmVudFxuICogQHBhcmFtIHtzdHJpbmd9IFtzZXBhcmF0b3I9JyddIElzIHNlcGFyYXRvciBmb3Igc2VxdWVuY2UuXG4gKiBAcGFyYW0ge2Jvb2xlYW59IFtsYXN0PWZhbHNlXSBJcyBjaGVja2VyIGlmIGVsZW1lbnQgbGFzdCBvciBub3QuXG4gKiBAcmV0dXJuIHtudW1iZXJ9IHggY29vcmRpbmF0ZSB0byBzdGFydCBwcmludGluZyBhdC5cbiAqL1xuIGV4cG9ydCBmdW5jdGlvbiBwcmludExlZnRPckNlbnRlcmVkKFxuICAgIHg6IG51bWJlciwgeTogbnVtYmVyLCB3OiBudW1iZXIsIGg6IG51bWJlcixcbiAgICBnOiBDYW52YXNSZW5kZXJpbmdDb250ZXh0MkQsIHM6IHN0cmluZywgY29sb3IgPSB1bmRlZmluZWRDb2xvcixcbiAgICBwaXZvdDogbnVtYmVyID0gMCwgbGVmdCA9IGZhbHNlLCB0cmFuc3BhcmVuY3lSYXRlOiBudW1iZXIgPSAxLjAsXG4gICAgc2VwYXJhdG9yOiBzdHJpbmcgPSAnJywgbGFzdDogYm9vbGVhbiA9IGZhbHNlLCBkcmF3U3R5bGU6IHN0cmluZyA9ICdjbGFzc2ljJywgbWF4V29yZDogYW55ID0ge30sIG1heFdvcmRJZHg6IG51bWJlciA9IDAsIGdyaWRDZWxsOiBhbnkgPSB7fSk6IG51bWJlciB7XG4gICAgZy50ZXh0QWxpZ24gPSAnc3RhcnQnO1xuICAgIGNvbnN0IGNvbG9yUGFydCA9IHMuc3Vic3RyaW5nKDApO1xuICAgIGxldCBncmF5UGFydCA9IGxhc3QgPyAnJyA6IHNlcGFyYXRvcjtcbiAgICBpZiAoZHJhd1N0eWxlID09PSAnbXNhJykge1xuICAgICAgZ3JheVBhcnQgPSAnJztcbiAgICB9XG4gIFxuICAgIGxldCB0ZXh0U2l6ZTogYW55ID0gZy5tZWFzdXJlVGV4dChjb2xvclBhcnQgKyBncmF5UGFydCk7XG4gICAgY29uc3QgaW5kZW50ID0gNTtcbiAgXG4gICAgbGV0IG1heENvbG9yVGV4dFNpemUgPSBnLm1lYXN1cmVUZXh0KGNvbG9yUGFydCkud2lkdGg7XG4gICAgbGV0IGNvbG9yVGV4dFNpemUgPSBnLm1lYXN1cmVUZXh0KGNvbG9yUGFydCkud2lkdGg7XG4gICAgY29uc3QgZHkgPSAodGV4dFNpemUuZm9udEJvdW5kaW5nQm94QXNjZW50ICsgdGV4dFNpemUuZm9udEJvdW5kaW5nQm94RGVzY2VudCkgLyAyO1xuICAgIHRleHRTaXplID0gdGV4dFNpemUud2lkdGg7XG4gICAgaWYgKGRyYXdTdHlsZSA9PT0gJ21zYScpIHtcbiAgICAgIG1heENvbG9yVGV4dFNpemUgPSBtYXhXb3JkW21heFdvcmRJZHhdO1xuICAgICAgdGV4dFNpemUgPSBtYXhXb3JkW21heFdvcmRJZHhdO1xuICAgICAgaWYgKG1heENvbG9yVGV4dFNpemUgPiBtYXhXb3JkKSB7XG4gICAgICAgIG1heFdvcmRbbWF4V29yZElkeF0gPSBtYXhDb2xvclRleHRTaXplO1xuICAgICAgICBncmlkQ2VsbC5jZWxsLmNvbHVtbi50ZW1wID0gbWF4V29yZDtcbiAgICAgIH1cbiAgICAgIGlmIChtYXhXb3JkSWR4ID4gKG1heFdvcmRbJ2Jpby1tYXhJbmRleCddID8/IDApKSB7XG4gICAgICAgIG1heFdvcmRbJ2Jpby1tYXhJbmRleCddID0gbWF4V29yZElkeDtcbiAgICAgICAgZ3JpZENlbGwuY2VsbC5jb2x1bW4udGVtcCA9IG1heFdvcmQ7XG4gICAgICB9XG4gICAgfVxuICBcbiAgICBmdW5jdGlvbiBkcmF3KGR4MTogbnVtYmVyLCBkeDI6IG51bWJlcik6IHZvaWQge1xuICAgICAgZy5maWxsU3R5bGUgPSBjb2xvcjtcbiAgICAgIGcuZ2xvYmFsQWxwaGEgPSB0cmFuc3BhcmVuY3lSYXRlO1xuICAgICAgaWYgKGRyYXdTdHlsZSA9PT0gJ2NsYXNzaWMnKSB7XG4gICAgICAgIGcuZmlsbFRleHQoY29sb3JQYXJ0LCB4ICsgZHgxLCB5ICsgZHkpO1xuICAgICAgICBnLmZpbGxTdHlsZSA9IGdyYXlDb2xvcjtcbiAgICAgICAgZy5maWxsVGV4dChncmF5UGFydCwgeCArIGR4MiwgeSArIGR5KTtcbiAgICAgIH1cbiAgICAgIGlmIChkcmF3U3R5bGUgPT09ICdtc2EnKSB7XG4gICAgICAgIGcuZmlsbFN0eWxlID0gY29sb3I7XG4gICAgICAgIGcuZmlsbFRleHQoY29sb3JQYXJ0LCB4ICsgZHgxICsgKChtYXhXb3JkW21heFdvcmRJZHhdIC0gY29sb3JUZXh0U2l6ZSkgLyAyKSwgeSArIGR5KTtcbiAgICAgIH1cbiAgICB9XG4gIFxuICAgIGlmIChsZWZ0IHx8IHRleHRTaXplID4gdykge1xuICAgICAgZHJhdyhpbmRlbnQsIGluZGVudCArIG1heENvbG9yVGV4dFNpemUpO1xuICAgICAgcmV0dXJuIHggKyBtYXhDb2xvclRleHRTaXplICsgZy5tZWFzdXJlVGV4dChncmF5UGFydCkud2lkdGg7XG4gIFxuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCBkeCA9ICh3IC0gdGV4dFNpemUpIC8gMjtcbiAgICAgIGRyYXcoZHgsIGR4ICsgbWF4Q29sb3JUZXh0U2l6ZSk7XG4gICAgICByZXR1cm4geCArIGR4ICsgbWF4Q29sb3JUZXh0U2l6ZTtcbiAgICB9XG4gIH1cbiAgXG4gICJdfQ==
@@ -70,9 +70,9 @@ export class UnitsHandler {
70
70
  isFasta() { return this.notation === "FASTA" /* NOTATION.FASTA */; }
71
71
  isSeparator() { return this.notation === "SEPARATOR" /* NOTATION.SEPARATOR */; }
72
72
  isHelm() { return this.notation === "HELM" /* NOTATION.HELM */; }
73
- isRna() { return this.alphabet.toLowerCase().endsWith('rna'); }
74
- isDna() { return this.alphabet.toLowerCase().endsWith('dna'); }
75
- isPeptide() { return this.alphabet.toLowerCase().endsWith('pt'); }
73
+ isRna() { return this.alphabet.toLowerCase() === 'rna'; }
74
+ isDna() { return this.alphabet.toLowerCase() === 'dna'; }
75
+ isPeptide() { return this.alphabet.toLowerCase() === 'pt'; }
76
76
  /** Associate notation types with the corresponding units */
77
77
  /**
78
78
  * @return {NOTATION} Notation associated with the units type
@@ -157,4 +157,4 @@ UnitsHandler.PeptideFastaAlphabet = new Set([
157
157
  ]);
158
158
  UnitsHandler.DnaFastaAlphabet = new Set(['A', 'C', 'G', 'T']);
159
159
  UnitsHandler.RnaFastaAlphabet = new Set(['A', 'C', 'G', 'U']);
160
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"units-handler.js","sourceRoot":"","sources":["units-handler.ts"],"names":[],"mappings":"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","sourcesContent":["import * as DG from 'datagrok-api/dg';\nimport * as ui from 'datagrok-api/ui';\nimport * as grok from 'datagrok-api/grok';\n\nimport {WebLogo, SeqColStats} from '../viewers/web-logo';\n\n/** enum type to simplify setting \"user-friendly\" notation if necessary */\nexport const enum NOTATION {\n  FASTA = 'FASTA',\n  SEPARATOR = 'SEPARATOR',\n  HELM = 'HELM'\n}\n\n/** Class for handling notation units in Macromolecule columns */\nexport class UnitsHandler {\n  protected readonly _column: DG.Column; // the column to be converted\n  protected _units: string; // units, of the form fasta, separator\n  protected _notation: NOTATION; // current notation (without :SEQ:NT, etc.)\n  protected _defaultGapSymbol: string;\n  protected _defaultGapSymbolsDict = {\n    HELM: '*',\n    SEPARATOR: '',\n    FASTA: '-',\n  };\n\n  public static readonly PeptideFastaAlphabet = new Set([\n    'G', 'L', 'Y', 'S', 'E', 'Q', 'D', 'N', 'F', 'A',\n    'K', 'R', 'H', 'C', 'V', 'P', 'W', 'I', 'M', 'T',\n  ]);\n  public static readonly DnaFastaAlphabet = new Set(['A', 'C', 'G', 'T']);\n  public static readonly RnaFastaAlphabet = new Set(['A', 'C', 'G', 'U']);\n\n  public static setUnitsToFastaColumn(col: DG.Column) {\n    if (col.semType !== DG.SEMTYPE.MACROMOLECULE)\n      throw new Error('Fasta column must be MACROMOLECULE');\n\n    const stats: SeqColStats = WebLogo.getStats(col, 5, WebLogo.splitterAsFasta);\n    const seqType = stats.sameLength ? 'SEQ.MSA' : 'SEQ';\n\n    const alphabetCandidates: [string, Set<string>][] = [\n      ['PT', UnitsHandler.PeptideFastaAlphabet],\n      ['DNA', UnitsHandler.DnaFastaAlphabet],\n      ['RNA', UnitsHandler.RnaFastaAlphabet],\n    ];\n\n    // Calculate likelihoods for alphabet_candidates\n    const alphabetCandidatesSim: number[] = alphabetCandidates.map(\n      (c) => WebLogo.getAlphabetSimilarity(stats.freq, c[1]));\n    const maxCos = Math.max(...alphabetCandidatesSim);\n    const alphabet = maxCos > 0.65 ? alphabetCandidates[alphabetCandidatesSim.indexOf(maxCos)][0] : 'UN';\n    \n    const units: string = 'fasta';\n    col.setTag(DG.TAGS.UNITS, units);\n    col.setTag('aligned', seqType);\n    col.setTag('alphabet', alphabet);\n  }\n\n  protected get units(): string { return this._units; }\n\n  protected get column(): DG.Column { return this._column; }\n\n  public get notation(): NOTATION { return this._notation; }\n\n  public get defaultGapSymbol(): string { return this._defaultGapSymbol; }\n\n  public get separator(): string {\n    const separator = this.column.getTag('separator');\n    if (separator !== null)\n      return separator;\n    else\n      throw new Error('Separator not set');\n  }\n\n  public get aligned(): string {\n    const aligned = this.column.getTag('aligned');\n    if (aligned !== null) {\n      return aligned;\n    } else {\n      throw new Error('Tag aligned not set');\n    }\n  }\n\n  public get alphabet(): string {\n    const alphabet = this.column.getTag('alphabet');\n    if (alphabet !== null) {\n      return alphabet;\n    } else {\n      throw new Error('Tag alphabet not set');\n    }\n  }\n\n  public isFasta(): boolean { return this.notation === NOTATION.FASTA; }\n\n  public isSeparator(): boolean { return this.notation === NOTATION.SEPARATOR; }\n\n  public isHelm(): boolean { return this.notation === NOTATION.HELM; }\n\n  public isRna(): boolean { return this.alphabet.toLowerCase().endsWith('rna'); }\n\n  public isDna(): boolean { return this.alphabet.toLowerCase().endsWith('dna'); }\n\n  public isPeptide(): boolean { return this.alphabet.toLowerCase().endsWith('pt'); }\n\n  /** Associate notation types with the corresponding units */\n  /**\n   * @return {NOTATION}     Notation associated with the units type\n   */\n  protected getNotation(): NOTATION {\n    if (this.units.toLowerCase().startsWith('fasta'))\n      return NOTATION.FASTA;\n    else if (this.units.toLowerCase().startsWith('separator'))\n      return NOTATION.SEPARATOR;\n    else if (this.units.toLowerCase().startsWith('helm'))\n      return NOTATION.HELM;\n    else\n      throw new Error('The column has units that do not correspond to any notation');\n  }\n\n  /**\n   * Create a new empty column of the specified notation type and the same\n   * length as column\n   *\n   * @param {NOTATION} targetNotation\n   * @return {DG.Column}\n   */\n  protected getNewColumn(targetNotation: NOTATION): DG.Column {\n    const col = this.column;\n    const len = col.length;\n    const name = targetNotation.toLowerCase() + '(' + col.name + ')';\n    const newColName = col.dataFrame.columns.getUnusedName(name);\n    const newColumn = DG.Column.fromList('string', newColName, new Array(len).fill(''));\n    newColumn.semType = DG.SEMTYPE.MACROMOLECULE;\n    newColumn.setTag(\n      DG.TAGS.UNITS,\n      this.units.replace(\n        this.notation.toLowerCase().toString(),\n        targetNotation.toLowerCase().toString()\n      )\n    );\n    newColumn.setTag(DG.TAGS.CELL_RENDERER, 'Macromolecule');\n\n    return newColumn;\n  }\n\n  /**\n   * Create a new empty column using templateCol as a template\n   *\n   * @param {DG.Column} templateCol  the properties and units of this column are used as a\n   * template to build the new one\n   * @return {DG.Column}\n   */\n  public static getNewColumn(templateCol: DG.Column): DG.Column {\n    const col: UnitsHandler = new UnitsHandler(templateCol);\n    const targetNotation = col.notation;\n    return col.getNewColumn(targetNotation);\n  }\n\n  /**\n   * A helper function checking the validity of the 'units' string\n   *\n   * @param {string} units  the string to be validated\n   * @return {boolean}\n   */\n  public static unitsStringIsValid(units: string): boolean {\n    units = units.toLowerCase();\n    const prefixes = [NOTATION.FASTA, NOTATION.SEPARATOR, NOTATION.HELM];\n    const postfixes = ['rna', 'dna', 'pt'];\n\n    const prefixCriterion = prefixes.some((p) => units.startsWith(p.toLowerCase()));\n    return prefixCriterion;\n  }\n\n  /**\n   * Construct a new column of semantic type MACROMOLECULE from the list of\n   * specified parameters\n   *\n   * @param {number}    len  the length of the new column\n   * @param {string}    name  the name of the new column\n   * @param {string}    units  the units of the new column\n   * @return {DG.Column}\n   */\n  public static getNewColumnFromParams(\n    len: number,\n    name: string,\n    units: string\n  ): DG.Column {\n    // WARNING: in this implementation is is impossible to verify the uniqueness\n    // of the new column's name\n    // TODO: verify the validity of units parameter\n    if (!UnitsHandler.unitsStringIsValid(units))\n      throw new Error('Invalid format of \\'units\\' parameter');\n    const newColumn = DG.Column.fromList('string', name, new Array(len).fill(''));\n    newColumn.semType = DG.SEMTYPE.MACROMOLECULE;\n    newColumn.setTag(DG.TAGS.UNITS, units);\n    return newColumn;\n  }\n\n  public constructor(col: DG.Column) {\n    this._column = col;\n    const units = this._column.tags[DG.TAGS.UNITS];\n    if (units !== null)\n      this._units = units;\n    else\n      throw new Error('Units are not specified in column');\n    this._notation = this.getNotation();\n    this._defaultGapSymbol = (this.isFasta()) ? this._defaultGapSymbolsDict.FASTA :\n      (this.isHelm()) ? this._defaultGapSymbolsDict.HELM :\n        this._defaultGapSymbolsDict.SEPARATOR;\n  }\n}\n"]}
160
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"units-handler.js","sourceRoot":"","sources":["units-handler.ts"],"names":[],"mappings":"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","sourcesContent":["import * as DG from 'datagrok-api/dg';\nimport * as ui from 'datagrok-api/ui';\nimport * as grok from 'datagrok-api/grok';\n\nimport {WebLogo, SeqColStats} from '../viewers/web-logo';\n\n/** enum type to simplify setting \"user-friendly\" notation if necessary */\nexport const enum NOTATION {\n  FASTA = 'FASTA',\n  SEPARATOR = 'SEPARATOR',\n  HELM = 'HELM'\n}\n\n/** Class for handling notation units in Macromolecule columns */\nexport class UnitsHandler {\n  protected readonly _column: DG.Column; // the column to be converted\n  protected _units: string; // units, of the form fasta, separator\n  protected _notation: NOTATION; // current notation (without :SEQ:NT, etc.)\n  protected _defaultGapSymbol: string;\n  protected _defaultGapSymbolsDict = {\n    HELM: '*',\n    SEPARATOR: '',\n    FASTA: '-',\n  };\n\n  public static readonly PeptideFastaAlphabet = new Set([\n    'G', 'L', 'Y', 'S', 'E', 'Q', 'D', 'N', 'F', 'A',\n    'K', 'R', 'H', 'C', 'V', 'P', 'W', 'I', 'M', 'T',\n  ]);\n  public static readonly DnaFastaAlphabet = new Set(['A', 'C', 'G', 'T']);\n  public static readonly RnaFastaAlphabet = new Set(['A', 'C', 'G', 'U']);\n\n  public static setUnitsToFastaColumn(col: DG.Column) {\n    if (col.semType !== DG.SEMTYPE.MACROMOLECULE)\n      throw new Error('Fasta column must be MACROMOLECULE');\n\n    const stats: SeqColStats = WebLogo.getStats(col, 5, WebLogo.splitterAsFasta);\n    const seqType = stats.sameLength ? 'SEQ.MSA' : 'SEQ';\n\n    const alphabetCandidates: [string, Set<string>][] = [\n      ['PT', UnitsHandler.PeptideFastaAlphabet],\n      ['DNA', UnitsHandler.DnaFastaAlphabet],\n      ['RNA', UnitsHandler.RnaFastaAlphabet],\n    ];\n\n    // Calculate likelihoods for alphabet_candidates\n    const alphabetCandidatesSim: number[] = alphabetCandidates.map(\n      (c) => WebLogo.getAlphabetSimilarity(stats.freq, c[1]));\n    const maxCos = Math.max(...alphabetCandidatesSim);\n    const alphabet = maxCos > 0.65 ? alphabetCandidates[alphabetCandidatesSim.indexOf(maxCos)][0] : 'UN';\n    \n    const units: string = 'fasta';\n    col.setTag(DG.TAGS.UNITS, units);\n    col.setTag('aligned', seqType);\n    col.setTag('alphabet', alphabet);\n  }\n\n  protected get units(): string { return this._units; }\n\n  protected get column(): DG.Column { return this._column; }\n\n  public get notation(): NOTATION { return this._notation; }\n\n  public get defaultGapSymbol(): string { return this._defaultGapSymbol; }\n\n  public get separator(): string {\n    const separator = this.column.getTag('separator');\n    if (separator !== null)\n      return separator;\n    else\n      throw new Error('Separator not set');\n  }\n\n  public get aligned(): string {\n    const aligned = this.column.getTag('aligned');\n    if (aligned !== null) {\n      return aligned;\n    } else {\n      throw new Error('Tag aligned not set');\n    }\n  }\n\n  public get alphabet(): string {\n    const alphabet = this.column.getTag('alphabet');\n    if (alphabet !== null) {\n      return alphabet;\n    } else {\n      throw new Error('Tag alphabet not set');\n    }\n  }\n\n  public isFasta(): boolean { return this.notation === NOTATION.FASTA; }\n\n  public isSeparator(): boolean { return this.notation === NOTATION.SEPARATOR; }\n\n  public isHelm(): boolean { return this.notation === NOTATION.HELM; }\n\n  public isRna(): boolean { return this.alphabet.toLowerCase() === 'rna'; }\n\n  public isDna(): boolean { return this.alphabet.toLowerCase() === 'dna'; }\n\n  public isPeptide(): boolean { return this.alphabet.toLowerCase() === 'pt'; }\n\n  /** Associate notation types with the corresponding units */\n  /**\n   * @return {NOTATION}     Notation associated with the units type\n   */\n  protected getNotation(): NOTATION {\n    if (this.units.toLowerCase().startsWith('fasta'))\n      return NOTATION.FASTA;\n    else if (this.units.toLowerCase().startsWith('separator'))\n      return NOTATION.SEPARATOR;\n    else if (this.units.toLowerCase().startsWith('helm'))\n      return NOTATION.HELM;\n    else\n      throw new Error('The column has units that do not correspond to any notation');\n  }\n\n  /**\n   * Create a new empty column of the specified notation type and the same\n   * length as column\n   *\n   * @param {NOTATION} targetNotation\n   * @return {DG.Column}\n   */\n  protected getNewColumn(targetNotation: NOTATION): DG.Column {\n    const col = this.column;\n    const len = col.length;\n    const name = targetNotation.toLowerCase() + '(' + col.name + ')';\n    const newColName = col.dataFrame.columns.getUnusedName(name);\n    const newColumn = DG.Column.fromList('string', newColName, new Array(len).fill(''));\n    newColumn.semType = DG.SEMTYPE.MACROMOLECULE;\n    newColumn.setTag(\n      DG.TAGS.UNITS,\n      this.units.replace(\n        this.notation.toLowerCase().toString(),\n        targetNotation.toLowerCase().toString()\n      )\n    );\n    newColumn.setTag(DG.TAGS.CELL_RENDERER, 'Macromolecule');\n\n    return newColumn;\n  }\n\n  /**\n   * Create a new empty column using templateCol as a template\n   *\n   * @param {DG.Column} templateCol  the properties and units of this column are used as a\n   * template to build the new one\n   * @return {DG.Column}\n   */\n  public static getNewColumn(templateCol: DG.Column): DG.Column {\n    const col: UnitsHandler = new UnitsHandler(templateCol);\n    const targetNotation = col.notation;\n    return col.getNewColumn(targetNotation);\n  }\n\n  /**\n   * A helper function checking the validity of the 'units' string\n   *\n   * @param {string} units  the string to be validated\n   * @return {boolean}\n   */\n  public static unitsStringIsValid(units: string): boolean {\n    units = units.toLowerCase();\n    const prefixes = [NOTATION.FASTA, NOTATION.SEPARATOR, NOTATION.HELM];\n    const postfixes = ['rna', 'dna', 'pt'];\n\n    const prefixCriterion = prefixes.some((p) => units.startsWith(p.toLowerCase()));\n    return prefixCriterion;\n  }\n\n  /**\n   * Construct a new column of semantic type MACROMOLECULE from the list of\n   * specified parameters\n   *\n   * @param {number}    len  the length of the new column\n   * @param {string}    name  the name of the new column\n   * @param {string}    units  the units of the new column\n   * @return {DG.Column}\n   */\n  public static getNewColumnFromParams(\n    len: number,\n    name: string,\n    units: string\n  ): DG.Column {\n    // WARNING: in this implementation is is impossible to verify the uniqueness\n    // of the new column's name\n    // TODO: verify the validity of units parameter\n    if (!UnitsHandler.unitsStringIsValid(units))\n      throw new Error('Invalid format of \\'units\\' parameter');\n    const newColumn = DG.Column.fromList('string', name, new Array(len).fill(''));\n    newColumn.semType = DG.SEMTYPE.MACROMOLECULE;\n    newColumn.setTag(DG.TAGS.UNITS, units);\n    return newColumn;\n  }\n\n  public constructor(col: DG.Column) {\n    this._column = col;\n    const units = this._column.tags[DG.TAGS.UNITS];\n    if (units !== null)\n      this._units = units;\n    else\n      throw new Error('Units are not specified in column');\n    this._notation = this.getNotation();\n    this._defaultGapSymbol = (this.isFasta()) ? this._defaultGapSymbolsDict.FASTA :\n      (this.isHelm()) ? this._defaultGapSymbolsDict.HELM :\n        this._defaultGapSymbolsDict.SEPARATOR;\n  }\n}\n"]}