@datagrok-libraries/bio 5.0.0 → 5.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/index.d.ts +6 -4
- package/index.d.ts.map +1 -1
- package/index.js +5 -3
- package/index.ts +16 -4
- package/package.json +1 -1
- package/src/utils/macromolecule.d.ts +22 -0
- package/src/utils/macromolecule.d.ts.map +1 -1
- package/src/utils/macromolecule.js +38 -26
- package/src/utils/notation-converter.d.ts +2 -2
- package/src/utils/notation-converter.d.ts.map +1 -1
- package/src/utils/notation-converter.js +8 -4
- package/src/utils/splitter.d.ts.map +1 -1
- package/src/utils/splitter.js +2 -3
- package/src/utils/units-handler.d.ts +1 -19
- package/src/utils/units-handler.d.ts.map +1 -1
- package/src/utils/units-handler.js +39 -50
- package/src/viewers/phylocanvas-gl-viewer.d.ts +7 -0
- package/src/viewers/phylocanvas-gl-viewer.d.ts.map +1 -0
- package/src/viewers/phylocanvas-gl-viewer.js +2 -0
- package/src/viewers/vd-regions-viewer.d.ts +2 -2
- package/src/viewers/vd-regions-viewer.d.ts.map +1 -1
- package/src/viewers/vd-regions-viewer.js +1 -1
- package/src/viewers/viewer.d.ts +9 -0
- package/src/viewers/viewer.d.ts.map +1 -0
- package/src/viewers/viewer.js +2 -0
- package/src/viewers/web-logo.js +2 -2
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as DG from 'datagrok-api/dg';
|
|
2
|
-
import {
|
|
2
|
+
import { getStats, splitterAsFasta, detectAlphabet } from './macromolecule';
|
|
3
3
|
/** Class for handling notation units in Macromolecule columns */
|
|
4
4
|
export class UnitsHandler {
|
|
5
5
|
constructor(col) {
|
|
@@ -13,74 +13,67 @@ export class UnitsHandler {
|
|
|
13
13
|
this._defaultGapSymbol = (this.isFasta()) ? UnitsHandler._defaultGapSymbolsDict.FASTA :
|
|
14
14
|
(this.isHelm()) ? UnitsHandler._defaultGapSymbolsDict.HELM :
|
|
15
15
|
UnitsHandler._defaultGapSymbolsDict.SEPARATOR;
|
|
16
|
-
if (!this.column.tags.has(
|
|
16
|
+
if (!this.column.tags.has("aligned" /* TAGS.aligned */)) {
|
|
17
|
+
if (this.isFasta() || this.isSeparator())
|
|
18
|
+
throw new Error(`For column '${this.column.name}' of notation '${this.notation}' ` +
|
|
19
|
+
`tag '${"aligned" /* TAGS.aligned */}' is mandatory.`);
|
|
20
|
+
}
|
|
21
|
+
if (!this.column.tags.has(".alphabetSize" /* TAGS.alphabetSize */)) {
|
|
17
22
|
if (this.isHelm())
|
|
18
23
|
throw new Error(`For column '${this.column.name}' of notation '${this.notation}' ` +
|
|
19
|
-
`tag '${
|
|
24
|
+
`tag '${".alphabetSize" /* TAGS.alphabetSize */}' is mandatory.`);
|
|
20
25
|
else if (['UN'].includes(this.alphabet))
|
|
21
26
|
throw new Error(`For column '${this.column.name}' of alphabet '${this.alphabet}' ` +
|
|
22
|
-
`tag '${
|
|
27
|
+
`tag '${".alphabetSize" /* TAGS.alphabetSize */}' is mandatory.`);
|
|
23
28
|
}
|
|
24
|
-
if (!this.column.tags.has(
|
|
29
|
+
if (!this.column.tags.has(".alphabetIsMultichar" /* TAGS.alphabetIsMultichar */)) {
|
|
25
30
|
if (this.isHelm())
|
|
26
31
|
throw new Error(`For column '${this.column.name}' of notation '${this.notation}' ` +
|
|
27
|
-
`tag '${
|
|
32
|
+
`tag '${".alphabetIsMultichar" /* TAGS.alphabetIsMultichar */}' is mandatory.`);
|
|
28
33
|
else if (['UN'].includes(this.alphabet))
|
|
29
34
|
throw new Error(`For column '${this.column.name}' of alphabet '${this.alphabet}' ` +
|
|
30
|
-
`tag '${
|
|
35
|
+
`tag '${".alphabetIsMultichar" /* TAGS.alphabetIsMultichar */}' is mandatory.`);
|
|
31
36
|
}
|
|
32
37
|
}
|
|
33
38
|
static setUnitsToFastaColumn(col) {
|
|
34
39
|
if (col.semType !== DG.SEMTYPE.MACROMOLECULE)
|
|
35
40
|
throw new Error('Fasta column must be MACROMOLECULE');
|
|
36
41
|
const stats = getStats(col, 5, splitterAsFasta);
|
|
37
|
-
const
|
|
38
|
-
const
|
|
39
|
-
["PT" /* ALPHABET.PT */, UnitsHandler.PeptideFastaAlphabet],
|
|
40
|
-
["DNA" /* ALPHABET.DNA */, UnitsHandler.DnaFastaAlphabet],
|
|
41
|
-
["RNA" /* ALPHABET.RNA */, UnitsHandler.RnaFastaAlphabet],
|
|
42
|
-
];
|
|
43
|
-
// Calculate likelihoods for alphabet_candidates
|
|
44
|
-
const alphabetCandidatesSim = alphabetCandidates.map((c) => getAlphabetSimilarity(stats.freq, c[1]));
|
|
45
|
-
const maxCos = Math.max(...alphabetCandidatesSim);
|
|
46
|
-
const alphabet = maxCos > 0.65 ? alphabetCandidates[alphabetCandidatesSim.indexOf(maxCos)][0] : 'UN';
|
|
42
|
+
const aligned = stats.sameLength ? 'SEQ.MSA' : 'SEQ';
|
|
43
|
+
const alphabet = detectAlphabet(stats);
|
|
47
44
|
col.setTag(DG.TAGS.UNITS, "fasta" /* NOTATION.FASTA */);
|
|
48
|
-
col.setTag(
|
|
49
|
-
col.setTag(
|
|
45
|
+
col.setTag("aligned" /* TAGS.aligned */, aligned);
|
|
46
|
+
col.setTag("alphabet" /* TAGS.alphabet */, alphabet);
|
|
50
47
|
}
|
|
51
48
|
get units() { return this._units; }
|
|
52
49
|
get column() { return this._column; }
|
|
53
50
|
get notation() { return this._notation; }
|
|
54
51
|
get defaultGapSymbol() { return this._defaultGapSymbol; }
|
|
55
52
|
get separator() {
|
|
56
|
-
const separator = this.column.getTag(
|
|
53
|
+
const separator = this.column.getTag("separator" /* TAGS.separator */);
|
|
57
54
|
if (separator !== null)
|
|
58
55
|
return separator;
|
|
59
56
|
else
|
|
60
57
|
throw new Error('Separator not set');
|
|
61
58
|
}
|
|
62
59
|
get aligned() {
|
|
63
|
-
const aligned = this.column.getTag(
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
}
|
|
67
|
-
else {
|
|
60
|
+
const aligned = this.column.getTag("aligned" /* TAGS.aligned */);
|
|
61
|
+
// TAGS.aligned is mandatory for columns of NOTATION.FASTA and NOTATION.SEPARATOR
|
|
62
|
+
if (!aligned && (this.isFasta() || this.isSeparator()))
|
|
68
63
|
throw new Error('Tag aligned not set');
|
|
69
|
-
|
|
64
|
+
return aligned;
|
|
70
65
|
}
|
|
71
66
|
/** Alphabet name (upper case) */
|
|
72
67
|
get alphabet() {
|
|
73
|
-
const alphabet = this.column.getTag(
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
}
|
|
77
|
-
else {
|
|
68
|
+
const alphabet = this.column.getTag("alphabet" /* TAGS.alphabet */);
|
|
69
|
+
// TAGS.alphabet is mandatory for columns of NOTATION.FASTA and NOTATION.SEPARATOR
|
|
70
|
+
if (!alphabet && (this.isFasta() || this.isSeparator()))
|
|
78
71
|
throw new Error('Tag alphabet not set');
|
|
79
|
-
|
|
72
|
+
return alphabet;
|
|
80
73
|
}
|
|
81
74
|
getAlphabetSize() {
|
|
82
75
|
if (this.notation == "helm" /* NOTATION.HELM */ || this.alphabet == "UN" /* ALPHABET.UN */) {
|
|
83
|
-
const alphabetSize = parseInt(this.column.getTag(
|
|
76
|
+
const alphabetSize = parseInt(this.column.getTag(".alphabetSize" /* TAGS.alphabetSize */));
|
|
84
77
|
return alphabetSize;
|
|
85
78
|
}
|
|
86
79
|
else {
|
|
@@ -100,7 +93,7 @@ export class UnitsHandler {
|
|
|
100
93
|
}
|
|
101
94
|
getAlphabetIsMultichar() {
|
|
102
95
|
if (this.notation == "helm" /* NOTATION.HELM */ || this.alphabet == "UN" /* ALPHABET.UN */) {
|
|
103
|
-
return this.column.getTag(
|
|
96
|
+
return this.column.getTag(".alphabetIsMultichar" /* TAGS.alphabetIsMultichar */) == 'true';
|
|
104
97
|
}
|
|
105
98
|
else {
|
|
106
99
|
return false;
|
|
@@ -112,7 +105,7 @@ export class UnitsHandler {
|
|
|
112
105
|
isRna() { return this.alphabet === 'RNA'; }
|
|
113
106
|
isDna() { return this.alphabet === 'DNA'; }
|
|
114
107
|
isPeptide() { return this.alphabet === 'PT'; }
|
|
115
|
-
isMsa() { return this.aligned.toUpperCase().includes('MSA'); }
|
|
108
|
+
isMsa() { return this.aligned ? this.aligned.toUpperCase().includes('MSA') : false; }
|
|
116
109
|
/** Associate notation types with the corresponding units */
|
|
117
110
|
/**
|
|
118
111
|
* @return {NOTATION} Notation associated with the units type
|
|
@@ -143,18 +136,21 @@ export class UnitsHandler {
|
|
|
143
136
|
newColumn.semType = DG.SEMTYPE.MACROMOLECULE;
|
|
144
137
|
newColumn.setTag(DG.TAGS.UNITS, targetNotation);
|
|
145
138
|
newColumn.setTag(DG.TAGS.CELL_RENDERER, 'Macromolecule');
|
|
146
|
-
const
|
|
139
|
+
const srcAligned = col.getTag("aligned" /* TAGS.aligned */);
|
|
140
|
+
if (srcAligned)
|
|
141
|
+
newColumn.setTag("aligned" /* TAGS.aligned */, srcAligned);
|
|
142
|
+
const srcAlphabet = col.getTag("alphabet" /* TAGS.alphabet */);
|
|
147
143
|
if (srcAlphabet)
|
|
148
|
-
newColumn.setTag(
|
|
149
|
-
let srcAlphabetSize = col.getTag(
|
|
144
|
+
newColumn.setTag("alphabet" /* TAGS.alphabet */, srcAlphabet);
|
|
145
|
+
let srcAlphabetSize = col.getTag(".alphabetSize" /* TAGS.alphabetSize */);
|
|
150
146
|
if (srcAlphabetSize)
|
|
151
|
-
newColumn.setTag(
|
|
152
|
-
const srcAlphabetIsMultichar = col.getTag(
|
|
147
|
+
newColumn.setTag(".alphabetSize" /* TAGS.alphabetSize */, srcAlphabetSize);
|
|
148
|
+
const srcAlphabetIsMultichar = col.getTag(".alphabetIsMultichar" /* TAGS.alphabetIsMultichar */);
|
|
153
149
|
if (srcAlphabetIsMultichar !== undefined)
|
|
154
|
-
newColumn.setTag(
|
|
150
|
+
newColumn.setTag(".alphabetIsMultichar" /* TAGS.alphabetIsMultichar */, srcAlphabetIsMultichar);
|
|
155
151
|
if (targetNotation == "helm" /* NOTATION.HELM */) {
|
|
156
152
|
srcAlphabetSize = this.getAlphabetSize().toString();
|
|
157
|
-
newColumn.setTag(
|
|
153
|
+
newColumn.setTag(".alphabetSize" /* TAGS.alphabetSize */, srcAlphabetSize);
|
|
158
154
|
}
|
|
159
155
|
return newColumn;
|
|
160
156
|
}
|
|
@@ -204,13 +200,6 @@ export class UnitsHandler {
|
|
|
204
200
|
return newColumn;
|
|
205
201
|
}
|
|
206
202
|
}
|
|
207
|
-
UnitsHandler.TAGS = {
|
|
208
|
-
aligned: 'aligned',
|
|
209
|
-
alphabet: 'alphabet',
|
|
210
|
-
alphabetSize: '.alphabetSize',
|
|
211
|
-
alphabetIsMultichar: '.alphabetIsMultichar',
|
|
212
|
-
separator: 'separator',
|
|
213
|
-
};
|
|
214
203
|
UnitsHandler._defaultGapSymbolsDict = {
|
|
215
204
|
HELM: '*',
|
|
216
205
|
SEPARATOR: '',
|
|
@@ -222,4 +211,4 @@ UnitsHandler.PeptideFastaAlphabet = new Set([
|
|
|
222
211
|
]);
|
|
223
212
|
UnitsHandler.DnaFastaAlphabet = new Set(['A', 'C', 'G', 'T']);
|
|
224
213
|
UnitsHandler.RnaFastaAlphabet = new Set(['A', 'C', 'G', 'U']);
|
|
225
|
-
//# 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 {getAlphabetSimilarity, getStats, SeqColStats, splitterAsFasta} from './macromolecule';\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\nexport const enum ALPHABET {\n  DNA = 'DNA',\n  RNA = 'RNA',\n  PT = 'PT',\n  UN = 'UN',\n}\n\n/** Class for handling notation units in Macromolecule columns */\nexport class UnitsHandler {\n  public static readonly TAGS = {\n    aligned: 'aligned',\n    alphabet: 'alphabet',\n    alphabetSize: '.alphabetSize',\n    alphabetIsMultichar: '.alphabetIsMultichar',\n    separator: 'separator',\n  };\n\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 static readonly _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 = getStats(col, 5, splitterAsFasta);\n    const seqType = stats.sameLength ? 'SEQ.MSA' : 'SEQ';\n\n    const alphabetCandidates: [string, Set<string>][] = [\n      [ALPHABET.PT, UnitsHandler.PeptideFastaAlphabet],\n      [ALPHABET.DNA, UnitsHandler.DnaFastaAlphabet],\n      [ALPHABET.RNA, UnitsHandler.RnaFastaAlphabet],\n    ];\n\n    // Calculate likelihoods for alphabet_candidates\n    const alphabetCandidatesSim: number[] = alphabetCandidates.map(\n      (c) => 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    col.setTag(DG.TAGS.UNITS, NOTATION.FASTA);\n    col.setTag(UnitsHandler.TAGS.aligned, seqType);\n    col.setTag(UnitsHandler.TAGS.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(UnitsHandler.TAGS.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(UnitsHandler.TAGS.aligned);\n    if (aligned !== null) {\n      return aligned;\n    } else {\n      throw new Error('Tag aligned not set');\n    }\n  }\n\n  /** Alphabet name (upper case) */\n  public get alphabet(): string {\n    const alphabet = this.column.getTag(UnitsHandler.TAGS.alphabet);\n    if (alphabet !== null) {\n      return alphabet.toUpperCase();\n    } else {\n      throw new Error('Tag alphabet not set');\n    }\n  }\n\n  public getAlphabetSize(): number {\n    if (this.notation == NOTATION.HELM || this.alphabet == ALPHABET.UN) {\n      const alphabetSize = parseInt(this.column.getTag(UnitsHandler.TAGS.alphabetSize));\n      return alphabetSize;\n    } else {\n      switch (this.alphabet) {\n      case ALPHABET.PT:\n        return 20;\n      case ALPHABET.DNA:\n      case ALPHABET.RNA:\n        return 4;\n      case 'NT':\n        console.warn(`Unexpected alphabet 'NT'.`);\n        return 4;\n      default:\n        throw new Error(`Unexpected alphabet '${this.alphabet}'.`);\n      }\n    }\n  }\n\n  public getAlphabetIsMultichar(): boolean {\n    if (this.notation == NOTATION.HELM || this.alphabet == ALPHABET.UN) {\n      return this.column.getTag(UnitsHandler.TAGS.alphabetIsMultichar) == 'true';\n    } else {\n      return false;\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 === 'RNA'; }\n\n  public isDna(): boolean { return this.alphabet === 'DNA'; }\n\n  public isPeptide(): boolean { return this.alphabet === 'PT'; }\n\n  public isMsa(): boolean {return this.aligned.toUpperCase().includes('MSA'); }\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(NOTATION.FASTA))\n      return NOTATION.FASTA;\n    else if (this.units.toLowerCase().startsWith(NOTATION.SEPARATOR))\n      return NOTATION.SEPARATOR;\n    else if (this.units.toLowerCase().startsWith(NOTATION.HELM))\n      return NOTATION.HELM;\n    else\n      throw new Error(`Column '${this.column.name}' has unexpected notation '${this.units}'.`);\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(DG.TAGS.UNITS, targetNotation);\n    newColumn.setTag(DG.TAGS.CELL_RENDERER, 'Macromolecule');\n\n    const srcAlphabet = col.getTag(UnitsHandler.TAGS.alphabet);\n    if (srcAlphabet)\n      newColumn.setTag(UnitsHandler.TAGS.alphabet, srcAlphabet);\n\n    let srcAlphabetSize: string = col.getTag(UnitsHandler.TAGS.alphabetSize);\n    if (srcAlphabetSize)\n      newColumn.setTag(UnitsHandler.TAGS.alphabetSize, srcAlphabetSize);\n\n    const srcAlphabetIsMultichar: string = col.getTag(UnitsHandler.TAGS.alphabetIsMultichar);\n    if (srcAlphabetIsMultichar !== undefined)\n      newColumn.setTag(UnitsHandler.TAGS.alphabetIsMultichar, srcAlphabetIsMultichar);\n\n    if (targetNotation == NOTATION.HELM) {\n      srcAlphabetSize = this.getAlphabetSize().toString();\n      newColumn.setTag(UnitsHandler.TAGS.alphabetSize, srcAlphabetSize);\n    }\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()) ? UnitsHandler._defaultGapSymbolsDict.FASTA :\n      (this.isHelm()) ? UnitsHandler._defaultGapSymbolsDict.HELM :\n        UnitsHandler._defaultGapSymbolsDict.SEPARATOR;\n\n    if (!this.column.tags.has(UnitsHandler.TAGS.alphabetSize)) {\n      if (this.isHelm())\n        throw new Error(`For column '${this.column.name}' of notation '${this.notation}' ` +\n          `tag '${UnitsHandler.TAGS.alphabetSize}' is mandatory.`);\n      else if (['UN'].includes(this.alphabet))\n        throw new Error(`For column '${this.column.name}' of alphabet '${this.alphabet}' ` +\n          `tag '${UnitsHandler.TAGS.alphabetSize}' is mandatory.`);\n    }\n\n    if (!this.column.tags.has(UnitsHandler.TAGS.alphabetIsMultichar)) {\n      if (this.isHelm())\n        throw new Error(`For column '${this.column.name}' of notation '${this.notation}' ` +\n          `tag '${UnitsHandler.TAGS.alphabetIsMultichar}' is mandatory.`);\n      else if (['UN'].includes(this.alphabet))\n        throw new Error(`For column '${this.column.name}' of alphabet '${this.alphabet}' ` +\n          `tag '${UnitsHandler.TAGS.alphabetIsMultichar}' is mandatory.`);\n    }\n  }\n}\n"]}
|
|
214
|
+
//# 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 {\n  ALPHABET, NOTATION,\n  getStats,\n  SeqColStats,\n  splitterAsFasta,\n  detectAlphabet, TAGS\n} from './macromolecule';\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 static readonly _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 = getStats(col, 5, splitterAsFasta);\n    const aligned = stats.sameLength ? 'SEQ.MSA' : 'SEQ';\n    const alphabet = detectAlphabet(stats);\n\n    col.setTag(DG.TAGS.UNITS, NOTATION.FASTA);\n    col.setTag(TAGS.aligned, aligned);\n    col.setTag(TAGS.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(TAGS.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(TAGS.aligned);\n\n    // TAGS.aligned is mandatory for columns of NOTATION.FASTA and NOTATION.SEPARATOR\n    if (!aligned && (this.isFasta() || this.isSeparator()))\n      throw new Error('Tag aligned not set');\n\n    return aligned;\n  }\n\n  /** Alphabet name (upper case) */\n  public get alphabet(): string {\n    const alphabet = this.column.getTag(TAGS.alphabet);\n\n    // TAGS.alphabet is mandatory for columns of NOTATION.FASTA and NOTATION.SEPARATOR\n    if (!alphabet && (this.isFasta() || this.isSeparator()))\n      throw new Error('Tag alphabet not set');\n\n    return alphabet;\n  }\n\n  public getAlphabetSize(): number {\n    if (this.notation == NOTATION.HELM || this.alphabet == ALPHABET.UN) {\n      const alphabetSize = parseInt(this.column.getTag(TAGS.alphabetSize));\n      return alphabetSize;\n    } else {\n      switch (this.alphabet) {\n      case ALPHABET.PT:\n        return 20;\n      case ALPHABET.DNA:\n      case ALPHABET.RNA:\n        return 4;\n      case 'NT':\n        console.warn(`Unexpected alphabet 'NT'.`);\n        return 4;\n      default:\n        throw new Error(`Unexpected alphabet '${this.alphabet}'.`);\n      }\n    }\n  }\n\n  public getAlphabetIsMultichar(): boolean {\n    if (this.notation == NOTATION.HELM || this.alphabet == ALPHABET.UN) {\n      return this.column.getTag(TAGS.alphabetIsMultichar) == 'true';\n    } else {\n      return false;\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 === 'RNA'; }\n\n  public isDna(): boolean { return this.alphabet === 'DNA'; }\n\n  public isPeptide(): boolean { return this.alphabet === 'PT'; }\n\n  public isMsa(): boolean { return this.aligned ? this.aligned.toUpperCase().includes('MSA') : false; }\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(NOTATION.FASTA))\n      return NOTATION.FASTA;\n    else if (this.units.toLowerCase().startsWith(NOTATION.SEPARATOR))\n      return NOTATION.SEPARATOR;\n    else if (this.units.toLowerCase().startsWith(NOTATION.HELM))\n      return NOTATION.HELM;\n    else\n      throw new Error(`Column '${this.column.name}' has unexpected notation '${this.units}'.`);\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(DG.TAGS.UNITS, targetNotation);\n    newColumn.setTag(DG.TAGS.CELL_RENDERER, 'Macromolecule');\n\n    const srcAligned = col.getTag(TAGS.aligned);\n    if (srcAligned)\n      newColumn.setTag(TAGS.aligned, srcAligned);\n\n    const srcAlphabet = col.getTag(TAGS.alphabet);\n    if (srcAlphabet)\n      newColumn.setTag(TAGS.alphabet, srcAlphabet);\n\n    let srcAlphabetSize: string = col.getTag(TAGS.alphabetSize);\n    if (srcAlphabetSize)\n      newColumn.setTag(TAGS.alphabetSize, srcAlphabetSize);\n\n    const srcAlphabetIsMultichar: string = col.getTag(TAGS.alphabetIsMultichar);\n    if (srcAlphabetIsMultichar !== undefined)\n      newColumn.setTag(TAGS.alphabetIsMultichar, srcAlphabetIsMultichar);\n\n    if (targetNotation == NOTATION.HELM) {\n      srcAlphabetSize = this.getAlphabetSize().toString();\n      newColumn.setTag(TAGS.alphabetSize, srcAlphabetSize);\n    }\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()) ? UnitsHandler._defaultGapSymbolsDict.FASTA :\n      (this.isHelm()) ? UnitsHandler._defaultGapSymbolsDict.HELM :\n        UnitsHandler._defaultGapSymbolsDict.SEPARATOR;\n\n    if (!this.column.tags.has(TAGS.aligned)) {\n      if (this.isFasta() || this.isSeparator())\n        throw new Error(`For column '${this.column.name}' of notation '${this.notation}' ` +\n          `tag '${TAGS.aligned}' is mandatory.`);\n    }\n\n    if (!this.column.tags.has(TAGS.alphabetSize)) {\n      if (this.isHelm())\n        throw new Error(`For column '${this.column.name}' of notation '${this.notation}' ` +\n          `tag '${TAGS.alphabetSize}' is mandatory.`);\n      else if (['UN'].includes(this.alphabet))\n        throw new Error(`For column '${this.column.name}' of alphabet '${this.alphabet}' ` +\n          `tag '${TAGS.alphabetSize}' is mandatory.`);\n    }\n\n    if (!this.column.tags.has(TAGS.alphabetIsMultichar)) {\n      if (this.isHelm())\n        throw new Error(`For column '${this.column.name}' of notation '${this.notation}' ` +\n          `tag '${TAGS.alphabetIsMultichar}' is mandatory.`);\n      else if (['UN'].includes(this.alphabet))\n        throw new Error(`For column '${this.column.name}' of alphabet '${this.alphabet}' ` +\n          `tag '${TAGS.alphabetIsMultichar}' is mandatory.`);\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"phylocanvas-gl-viewer.d.ts","sourceRoot":"","sources":["phylocanvas-gl-viewer.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAEtC,OAAO,EAAC,OAAO,EAAC,MAAM,UAAU,CAAC;AAGjC,MAAM,WAAW,oBAAqB,SAAQ,OAAO;IACnD,IAAI,KAAK,IAAI,EAAE,CAAC,SAAS,CAAC;IAE1B,IAAI,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,SAAS,EAAE;CAChC"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGh5bG9jYW52YXMtZ2wtdmlld2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsicGh5bG9jYW52YXMtZ2wtdmlld2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBncm9rIGZyb20gJ2RhdGFncm9rLWFwaS9ncm9rJztcbmltcG9ydCAqIGFzIHVpIGZyb20gJ2RhdGFncm9rLWFwaS91aSc7XG5pbXBvcnQgKiBhcyBERyBmcm9tICdkYXRhZ3Jvay1hcGkvZGcnO1xuXG5pbXBvcnQge0lWaWV3ZXJ9IGZyb20gJy4vdmlld2VyJztcblxuXG5leHBvcnQgaW50ZXJmYWNlIElQaHlsb2NhbnZhc0dsVmlld2VyIGV4dGVuZHMgSVZpZXdlciB7XG4gIGdldCBud2tEZigpOiBERy5EYXRhRnJhbWU7XG5cbiAgc2V0IG53a0RmKHZhbHVlOiBERy5EYXRhRnJhbWUpO1xufSJdfQ==
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import * as DG from 'datagrok-api/dg';
|
|
2
2
|
import { VdRegion } from '../vd-regions';
|
|
3
|
+
import { IViewer } from './viewer';
|
|
3
4
|
/** Interface for VdRegionsViewer from @datagrok/bio to unbind dependency to Bio package */
|
|
4
|
-
export interface IVdRegionsViewer {
|
|
5
|
-
get root(): HTMLElement;
|
|
5
|
+
export interface IVdRegionsViewer extends IViewer {
|
|
6
6
|
init(): Promise<void>;
|
|
7
7
|
setDf(mlbDf: DG.DataFrame, regions: VdRegion[]): Promise<void>;
|
|
8
8
|
}
|
|
@@ -1 +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;
|
|
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;AACvC,OAAO,EAAC,OAAO,EAAC,MAAM,UAAU,CAAC;AAEjC,2FAA2F;AAC3F,MAAM,WAAW,gBAAiB,SAAQ,OAAO;IAC/C,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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmQtcmVnaW9ucy12aWV3ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ2ZC1yZWdpb25zLXZpZXdlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgdWkgZnJvbSAnZGF0YWdyb2stYXBpL3VpJztcbmltcG9ydCAqIGFzIGdyb2sgZnJvbSAnZGF0YWdyb2stYXBpL2dyb2snO1xuaW1wb3J0ICogYXMgREcgZnJvbSAnZGF0YWdyb2stYXBpL2RnJztcblxuaW1wb3J0IHtWZFJlZ2lvbn0gZnJvbSAnLi4vdmQtcmVnaW9ucyc7XG5pbXBvcnQge0lWaWV3ZXJ9IGZyb20gJy4vdmlld2VyJztcblxuLyoqIEludGVyZmFjZSBmb3IgVmRSZWdpb25zVmlld2VyIGZyb20gQGRhdGFncm9rL2JpbyB0byB1bmJpbmQgZGVwZW5kZW5jeSB0byBCaW8gcGFja2FnZSAqL1xuZXhwb3J0IGludGVyZmFjZSBJVmRSZWdpb25zVmlld2VyIGV4dGVuZHMgSVZpZXdlciB7XG4gIGluaXQoKTogUHJvbWlzZTx2b2lkPjtcblxuICBzZXREZihtbGJEZjogREcuRGF0YUZyYW1lLCByZWdpb25zOiBWZFJlZ2lvbltdKTogUHJvbWlzZTx2b2lkPjtcbn0iXX0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"viewer.d.ts","sourceRoot":"","sources":["viewer.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,OAAO;IACtB,mCAAmC;IACnC,IAAI,IAAI,IAAI,WAAW,CAAC;IAExB,2BAA2B;IAC3B,KAAK,IAAI,IAAI,CAAC;IAEd,mCAAmC;IACnC,cAAc,IAAI,GAAG,CAAC;CACvB"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsidmlld2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBncm9rIGZyb20gJ2RhdGFncm9rLWFwaS9ncm9rJztcbmltcG9ydCAqIGFzIHVpIGZyb20gJ2RhdGFncm9rLWFwaS91aSc7XG5pbXBvcnQgKiBhcyBERyBmcm9tICdkYXRhZ3Jvay1hcGkvZGcnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElWaWV3ZXIge1xuICAvKiogSnNWaWV3ZXIucm9vdCgpOiBIVE1MRWxlbWVudCAqL1xuICBnZXQgcm9vdCgpOiBIVE1MRWxlbWVudDtcblxuICAvKiogVmlld2VyLmNsb3NlKCk6IHZvaWQgKi9cbiAgY2xvc2UoKTogdm9pZDtcblxuICAvKiogVmlld2VyLnJlbW92ZUZyb21WaWV3KCk6IGFueSAqL1xuICByZW1vdmVGcm9tVmlldygpOiBhbnk7XG59Il19
|