@datagrok-libraries/bio 0.0.4 → 0.0.8

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/.eslintrc.json CHANGED
@@ -1,29 +1,51 @@
1
- {
2
- "env": {
3
- "browser": true,
4
- "es2021": true
5
- },
6
- "extends": [
7
- "google"
8
- ],
9
- "parserOptions": {
10
- "ecmaVersion": 12,
11
- "sourceType": "module"
12
- },
13
- "rules": {
14
- "indent": [
15
- "error",
16
- 2
17
- ],
18
- "max-len": [
19
- "error",
20
- 120
21
- ],
22
- "require-jsdoc": "off",
23
- "spaced-comment": "off"
24
- },
25
- "parser": "@typescript-eslint/parser",
26
- "plugins": [
27
- "@typescript-eslint"
28
- ]
29
- }
1
+ {
2
+ "env": {
3
+ "browser": true,
4
+ "es2021": true
5
+ },
6
+ "extends": [
7
+ "google"
8
+ ],
9
+ "parser": "@typescript-eslint/parser",
10
+ "parserOptions": {
11
+ "ecmaVersion": 12,
12
+ "sourceType": "module"
13
+ },
14
+ "plugins": [
15
+ "@typescript-eslint"
16
+ ],
17
+ "rules": {
18
+ "indent": [
19
+ "error",
20
+ 2
21
+ ],
22
+ "max-len": [
23
+ "error",
24
+ 120
25
+ ],
26
+ "no-unused-vars": "warn",
27
+ "require-jsdoc": "off",
28
+ "spaced-comment": "off",
29
+ "linebreak-style": "off",
30
+ "curly": [
31
+ "error",
32
+ "multi-or-nest",
33
+ "consistent"
34
+ ],
35
+ "brace-style": [
36
+ "error",
37
+ "1tbs",
38
+ {
39
+ "allowSingleLine": true
40
+ }
41
+ ],
42
+ "block-spacing": [2, "always"],
43
+ "comma-dangle": ["error", {
44
+ "arrays": "only-multiline",
45
+ "functions": "never",
46
+ "objects": "only-multiline",
47
+ "imports": "only-multiline"
48
+ }],
49
+ "guard-for-in": "off"
50
+ }
51
+ }
package/detectors.js CHANGED
@@ -1,3 +1,9 @@
1
+ import * as grok from 'datagrok-api/grok';
2
+ import * as ui from 'datagrok-api/ui';
3
+ import * as DG from 'datagrok-api/dg';
4
+ import {Aminoacids} from './src/aminoacids';
5
+ import {Nucleotides} from './src/nucleotides';
6
+
1
7
  /**
2
8
  * The class contains semantic type detectors.
3
9
  * Detectors are functions tagged with `DG.FUNC_TYPES.SEM_TYPE_DETECTOR`.
@@ -6,4 +12,45 @@
6
12
  * Follow this naming convention to ensure that your detectors are properly loaded.
7
13
  */
8
14
  class BioPackageDetectors extends DG.Package {
15
+ //tags: semTypeDetector
16
+ //input: column col
17
+ //output: string semType
18
+ detectNucleotidesSeq(col) {
19
+ const alphabet = Nucleotides.Names + {'-': 'gap'};
20
+ return DG.Detector.sampleCategories(col, (s) => {
21
+ return s.split('').every((n) => n in alphabet);
22
+ }) ? Nucleotides.SemType : null;
23
+ }
24
+
25
+ //tags: semTypeDetector
26
+ //input: column col
27
+ //output: string semType
28
+ detectAminoacidsSeq(col) {
29
+ const alphabet = Aminoacids.Names + {'-': 'gap'};
30
+ return DG.Detector.sampleCategories(col, (s) => {
31
+ return s.split('').every((aa) => aa in alphabet);
32
+ }) ? Aminoacids.SemType : null;
33
+ }
34
+
35
+ //tags: semTypeDetector
36
+ //input: column col
37
+ //output: string semType
38
+ detectMultipleAlignmentNucleotidesSeq(col) {
39
+ const alphabet = Nucleotides.Names + {'-': 'gap'};
40
+ const len = col.get(0).length;
41
+ return DG.Detector.sampleCategories(col, (s) => {
42
+ return s.length == len && s.split('').every((n) => n in alphabet);
43
+ }) ? Nucleotides.SemTypeMultipleAlignment : null;
44
+ }
45
+
46
+ //tags: semTypeDetector
47
+ //input: column col
48
+ //output: string semType
49
+ detectMultipleAlignmentAminoacidsSeq(col) {
50
+ const alphabet = Aminoacids.Names + {'-': 'gap'};
51
+ const len = col.get(0).length;
52
+ return DG.Detector.sampleCategories(col, (s) => {
53
+ return s.length == len && s.split('').every((aa) => aa in alphabet);
54
+ }) ? Aminoacids.SemTypeMultipleAlignment : null;
55
+ }
9
56
  }
package/package.json CHANGED
@@ -1,42 +1,42 @@
1
- {
2
- "name": "@datagrok-libraries/bio",
3
- "publishConfig": {
4
- "access": "public"
5
- },
6
- "beta": true,
7
- "friendlyName": "Datagrok bio library",
8
- "version": "0.0.4",
9
- "description": "",
10
- "dependencies": {
11
- "datagrok-api": ">=0.108.0",
12
- "@datagrok-libraries/utils": ">=0.0.13",
13
- "cash-dom": "latest",
14
- "dayjs": "latest"
15
- },
16
- "devDependencies": {
17
- "typescript": "^4.2.3",
18
- "ts-loader": "^9.2.6",
19
- "webpack": "latest",
20
- "webpack-cli": "latest",
21
- "@typescript-eslint/eslint-plugin": "^4.29.1",
22
- "@typescript-eslint/parser": "^4.29.1",
23
- "eslint": "^7.32.0",
24
- "eslint-config-google": "^0.14.0"
25
- },
26
- "scripts": {
27
- "link": "npm link",
28
- "link-api": "npm link datagrok-api",
29
- "link-utils": "npm link @datagrok-libraries/utils",
30
- "link-all": "npm link datagrok-api @datagrok-libraries/utils",
31
- "debug-bio": "grok publish --rebuild",
32
- "release-bio": "grok publish --rebuild --release",
33
- "build-bio": "tsc",
34
- "build": "tsc",
35
- "debug-bio-public": "grok publish public --rebuild",
36
- "release-bio-public": "grok publish public --rebuild --release",
37
- "debug-bio-local": "grok publish local --rebuild",
38
- "release-bio-local": "grok publish local --rebuild --release",
39
- "lint": "eslint src --ext .ts",
40
- "lint-fix": "eslint src --ext .ts --fix"
41
- }
42
- }
1
+ {
2
+ "name": "@datagrok-libraries/bio",
3
+ "publishConfig": {
4
+ "access": "public"
5
+ },
6
+ "beta": true,
7
+ "friendlyName": "Datagrok bio library",
8
+ "version": "0.0.8",
9
+ "description": "",
10
+ "main": "src/index.ts",
11
+ "dependencies": {
12
+ "@datagrok-libraries/utils": ">=0.0.22",
13
+ "cash-dom": "latest",
14
+ "datagrok-api": ">=0.108.0",
15
+ "dayjs": "latest",
16
+ "rxjs": "^6.5.5"
17
+ },
18
+ "devDependencies": {
19
+ "@typescript-eslint/eslint-plugin": "^4.29.1",
20
+ "@typescript-eslint/parser": "^4.29.1",
21
+ "eslint": "latest",
22
+ "eslint-config-google": "latest",
23
+ "ts-loader": "^9.2.6",
24
+ "typescript": "^4.2.3"
25
+ },
26
+ "scripts": {
27
+ "link": "npm link",
28
+ "link-api": "npm link datagrok-api",
29
+ "link-utils": "npm link @datagrok-libraries/utils",
30
+ "link-all": "npm link datagrok-api @datagrok-libraries/utils",
31
+ "debug-bio": "grok publish --rebuild",
32
+ "release-bio": "grok publish --rebuild --release",
33
+ "build-bio": "tsc",
34
+ "build": "tsc",
35
+ "debug-bio-public": "grok publish public --rebuild",
36
+ "release-bio-public": "grok publish public --rebuild --release",
37
+ "debug-bio-local": "grok publish local --rebuild",
38
+ "release-bio-local": "grok publish local --rebuild --release",
39
+ "lint": "eslint \"./src/**/*.ts\"",
40
+ "lint-fix": "eslint \"./src/**/*.ts\" --fix"
41
+ }
42
+ }
@@ -0,0 +1,31 @@
1
+ import { StringDictionary } from '@datagrok-libraries/utils/src/type-declarations';
2
+ import { SeqPalette, SeqPaletteBase } from './seq-palettes';
3
+ export declare class AminoacidsPalettes extends SeqPaletteBase {
4
+ private static lesk;
5
+ static get Lesk(): SeqPalette;
6
+ private static grokGroups;
7
+ static get GrokGroups(): SeqPalette;
8
+ private static rasMol;
9
+ static get RasMol(): SeqPalette;
10
+ }
11
+ export declare class Aminoacids {
12
+ static readonly SemType: string;
13
+ static readonly SemTypeMultipleAlignment: string;
14
+ static undefinedColor: string;
15
+ static Names: StringDictionary;
16
+ static AASmiles: StringDictionary;
17
+ static AASmilesTruncated: StringDictionary;
18
+ /** TODO: Full?
19
+ */
20
+ static AAFullNames: StringDictionary;
21
+ static getPalette(scheme?: string): SeqPalette;
22
+ /**
23
+ * Returns divided amino acid with its content in the bracket, if the content is number, then its omitted
24
+ *
25
+ * @param {string} c raw amino
26
+ * @return {[string, string]} outer and inner content
27
+ */
28
+ static getInnerOuter(c: string): [string, string];
29
+ static getColorAAPivot(monomer?: string, scheme?: 'grok'): [string, string, string, number];
30
+ }
31
+ //# sourceMappingURL=aminoacids.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"aminoacids.d.ts","sourceRoot":"","sources":["aminoacids.ts"],"names":[],"mappings":"AAIA,OAAO,EAAC,gBAAgB,EAAC,MAAM,iDAAiD,CAAC;AACjF,OAAO,EAAC,UAAU,EAAE,cAAc,EAAC,MAAM,gBAAgB,CAAC;AAE1D,qBAAa,kBAAmB,SAAQ,cAAc;IACpD,OAAO,CAAC,MAAM,CAAC,IAAI,CAAa;IAEhC,WAAkB,IAAI,IAAI,UAAU,CAWnC;IAED,OAAO,CAAC,MAAM,CAAC,UAAU,CAAa;IAEtC,WAAkB,UAAU,IAAI,UAAU,CAYzC;IAED,OAAO,CAAC,MAAM,CAAC,MAAM,CAAa;IAElC,WAAkB,MAAM,IAAI,UAAU,CA4BrC;CACF;AAED,qBAAa,UAAU;IACrB,MAAM,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAgB;IAE/C,MAAM,CAAC,QAAQ,CAAC,wBAAwB,EAAE,MAAM,CAAiC;IAEjF,MAAM,CAAC,cAAc,SAAsB;IAE3C,OAAc,KAAK,EAAE,gBAAgB,CAqBnC;IAEF,OAAc,QAAQ,EAAE,gBAAgB,CAqBtC;IAEF,OAAc,iBAAiB,EAAE,gBAAgB,CAqB/C;IAEF;OACG;IACH,OAAc,WAAW,EAAE,gBAAgB,CAqBzC;WAEY,UAAU,CAAC,MAAM,GAAE,MAAe,GAAG,UAAU;IAW7D;;;;;OAKG;WACW,aAAa,CAAC,CAAC,EAAE,MAAM,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC;WAmB1C,eAAe,CAAC,OAAO,GAAE,MAAW,EAAE,MAAM,GAAE,MAAe,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;CA6C/G"}
@@ -0,0 +1,226 @@
1
+ import { SeqPaletteBase } from './seq-palettes';
2
+ export class AminoacidsPalettes extends SeqPaletteBase {
3
+ static get Lesk() {
4
+ if (this.lesk === void 0) {
5
+ this.lesk = this.makePalette([
6
+ [['G', 'A', 'S', 'T'], 'orange'],
7
+ [['C', 'V', 'I', 'L', 'P', 'F', 'Y', 'M', 'W'], 'all_green'],
8
+ [['N', 'Q', 'H'], 'magenta'],
9
+ [['D', 'E'], 'red'],
10
+ [['K', 'R'], 'all_blue'],
11
+ ]);
12
+ }
13
+ return this.lesk;
14
+ }
15
+ static get GrokGroups() {
16
+ if (this.grokGroups === void 0) {
17
+ this.grokGroups = this.makePalette([
18
+ [['C', 'U'], 'yellow'],
19
+ [['G', 'P'], 'red'],
20
+ [['A', 'V', 'I', 'L', 'M', 'F', 'Y', 'W'], 'all_green'],
21
+ [['R', 'H', 'K'], 'light_blue'],
22
+ [['D', 'E'], 'dark_blue'],
23
+ [['S', 'T', 'N', 'Q'], 'orange'],
24
+ ]);
25
+ }
26
+ return this.grokGroups;
27
+ }
28
+ static get RasMol() {
29
+ if (this.rasMol === void 0) {
30
+ this.rasMol = {
31
+ // http://acces.ens-lyon.fr/biotic/rastop/help/colour.htm
32
+ 'D': '#E60A0A',
33
+ 'E': '#E60A0A',
34
+ 'C': '#E6E600',
35
+ 'M': '#E6E600',
36
+ 'K': '#145AFF',
37
+ 'R': '#145AFF',
38
+ 'S': '#FA9600',
39
+ 'T': '#FA9600',
40
+ 'F': '#3232AA',
41
+ 'Y': '#3232AA',
42
+ 'N': '#00DCDC',
43
+ 'Q': '#00DCDC',
44
+ 'G': '#EBEBEB',
45
+ 'L': '#0F820F',
46
+ 'V': '#0F820F',
47
+ 'I': '#0F820F',
48
+ 'A': '#C8C8C8',
49
+ 'W': '#B45AB4',
50
+ 'H': '#8282D2',
51
+ 'P': '#DC9682',
52
+ 'others': '#BEA06E',
53
+ };
54
+ }
55
+ return this.rasMol;
56
+ }
57
+ }
58
+ export class Aminoacids {
59
+ static getPalette(scheme = 'grok') {
60
+ switch (scheme) {
61
+ case 'grok':
62
+ return AminoacidsPalettes.GrokGroups;
63
+ case 'lesk':
64
+ return AminoacidsPalettes.Lesk;
65
+ default:
66
+ throw new Error(`ChemPalette: scheme \`${scheme}\` does not exist`);
67
+ }
68
+ }
69
+ /**
70
+ * Returns divided amino acid with its content in the bracket, if the content is number, then its omitted
71
+ *
72
+ * @param {string} c raw amino
73
+ * @return {[string, string]} outer and inner content
74
+ */
75
+ static getInnerOuter(c) {
76
+ let isInner = 0;
77
+ let inner = '';
78
+ let outer = '';
79
+ for (const char of c) {
80
+ if (char == '(')
81
+ isInner++;
82
+ else if (char == ')')
83
+ isInner--;
84
+ else if (isInner)
85
+ inner += char;
86
+ else
87
+ outer += char;
88
+ }
89
+ return !isNaN(parseInt(inner)) ? [outer, ''] : [outer, inner];
90
+ }
91
+ static getColorAAPivot(monomer = '', scheme = 'grok') {
92
+ var _a, _b, _c;
93
+ //const chemPaletteInstance = AAPalettes.GrokGroups();
94
+ const chemPaletteInstance = this.getPalette(scheme);
95
+ let [outerMonomer, innerMonomer] = this.getInnerOuter(monomer);
96
+ outerMonomer = (outerMonomer.length > 6 ? `${outerMonomer.slice(0, 3)}...` : outerMonomer);
97
+ innerMonomer = (innerMonomer.length > 6 ? `${innerMonomer.slice(0, 3)}...` : innerMonomer);
98
+ if (monomer.length == 1 || monomer[1] == '(') {
99
+ const amino = (_a = monomer[0]) === null || _a === void 0 ? void 0 : _a.toUpperCase();
100
+ return amino in chemPaletteInstance ?
101
+ [chemPaletteInstance[amino], amino, innerMonomer, 1] :
102
+ [this.undefinedColor, outerMonomer, innerMonomer, 1];
103
+ }
104
+ if (monomer[0] == 'd' && monomer[1] in chemPaletteInstance) {
105
+ if (monomer.length == 2 || monomer[2] == '(') {
106
+ const amino = (_b = monomer[1]) === null || _b === void 0 ? void 0 : _b.toUpperCase();
107
+ return amino in chemPaletteInstance ?
108
+ [chemPaletteInstance[amino], amino, innerMonomer, 2] :
109
+ [this.undefinedColor, outerMonomer, innerMonomer, 2];
110
+ }
111
+ }
112
+ if (monomer.substring(0, 3) in this.AAFullNames) {
113
+ if (monomer.length == 3 || monomer[3] == '(') {
114
+ const amino = this.AAFullNames[monomer.substring(0, 3)];
115
+ return amino in chemPaletteInstance ?
116
+ [chemPaletteInstance[amino], amino, innerMonomer, 3] :
117
+ [this.undefinedColor, outerMonomer, innerMonomer, 3];
118
+ }
119
+ }
120
+ if (((_c = monomer[0]) === null || _c === void 0 ? void 0 : _c.toLowerCase()) == monomer[0]) {
121
+ if (monomer.substring(1, 3) in this.AAFullNames) {
122
+ if (monomer.length == 4 || monomer[4] == '(') {
123
+ const amino = this.AAFullNames[monomer.substring(1, 3)];
124
+ return amino in chemPaletteInstance ?
125
+ [chemPaletteInstance[amino], amino, innerMonomer, 4] :
126
+ [this.undefinedColor, outerMonomer, innerMonomer, 4];
127
+ }
128
+ }
129
+ }
130
+ return [this.undefinedColor, outerMonomer, innerMonomer, 0];
131
+ }
132
+ }
133
+ Aminoacids.SemType = 'Aminoacids';
134
+ Aminoacids.SemTypeMultipleAlignment = 'AminoacidsMultipleAlignment';
135
+ Aminoacids.undefinedColor = 'rgb(100,100,100)';
136
+ Aminoacids.Names = {
137
+ 'G': 'Glycine',
138
+ 'L': 'Leucine',
139
+ 'Y': 'Tyrosine',
140
+ 'S': 'Serine',
141
+ 'E': 'Glutamic acid',
142
+ 'Q': 'Glutamine',
143
+ 'D': 'Aspartic acid',
144
+ 'N': 'Asparagine',
145
+ 'F': 'Phenylalanine',
146
+ 'A': 'Alanine',
147
+ 'K': 'Lysine',
148
+ 'R': 'Arginine',
149
+ 'H': 'Histidine',
150
+ 'C': 'Cysteine',
151
+ 'V': 'Valine',
152
+ 'P': 'Proline',
153
+ 'W': 'Tryptophan',
154
+ 'I': 'Isoleucine',
155
+ 'M': 'Methionine',
156
+ 'T': 'Threonine',
157
+ };
158
+ Aminoacids.AASmiles = {
159
+ 'G': 'NCC(=O)O',
160
+ 'L': 'N[C@H](CC(C)C)C(=O)O',
161
+ 'Y': 'NC(CC1=CC=C(O)C=C1)C(=O)O',
162
+ 'S': 'NC(CO)C(=O)O',
163
+ 'E': 'N[C@@H](CCC(O)=O)C(=O)O',
164
+ 'Q': 'N[C@@H](CCC(N)=O)C(=O)O',
165
+ 'D': 'N[C@@H](CC(O)=O)C(=O)O',
166
+ 'N': 'N[C@@H](CC(N)=O)C(=O)O',
167
+ 'F': 'NC(CC1=CC=CC=C1)C(=O)O',
168
+ 'A': 'N[C@H](C)C(=O)O',
169
+ 'K': 'NC(CCCCN)C(=O)O',
170
+ 'R': 'N[C@H](CCCNC(=N)C)C(=O)O',
171
+ 'H': 'NC(CC1=CN=C[N]1)C(=O)O',
172
+ 'C': 'N[C@@H](CS)C(=O)O',
173
+ 'V': 'NC(C(C)C)C(=O)O',
174
+ 'P': 'N(CCC1)C1C(=O)O',
175
+ 'W': 'N[C@@H](Cc1c2ccccc2n([H])c1)C(=O)O',
176
+ 'I': 'N[C@H]([C@H](C)CC)C(=O)O',
177
+ 'M': 'NC(CCSC)C(=O)O',
178
+ 'T': 'NC(C(O)C)C(=O)O',
179
+ };
180
+ Aminoacids.AASmilesTruncated = {
181
+ 'G': '*C*',
182
+ 'L': 'CC(C)C[C@H](*)*',
183
+ 'Y': 'C1=CC(=CC=C1CC(*)*)O',
184
+ 'S': 'OCC(*)C*',
185
+ 'E': '*[C@@H](CCC(O)=O)*',
186
+ 'Q': '*N[C@@H](CCC(N)=O)*',
187
+ 'D': '*[C@@H](CC(O)=O)*',
188
+ 'N': '*[C@@H](CC(N)=O)*',
189
+ 'F': 'C1=CC=C(C=C1)CC(*)*',
190
+ 'A': 'C[C@H](*)*',
191
+ 'K': 'C(CCN)CC(*)*',
192
+ 'R': '*[C@H](CCCNC(=N)C)*',
193
+ 'H': 'C1=C(NC=N1)CC(*)*',
194
+ 'C': 'C([C@@H](*)*)S',
195
+ 'V': 'CC(C)C(*)*',
196
+ 'P': 'C1CCN(*)C1*',
197
+ 'W': '*[C@@H](Cc1c2ccccc2n([H])c1)*',
198
+ 'I': 'CC[C@H](C)[C@H](*)*',
199
+ 'M': 'CSCCC(*)*',
200
+ 'T': 'CC(O)C(*)*',
201
+ };
202
+ /** TODO: Full?
203
+ */
204
+ Aminoacids.AAFullNames = {
205
+ 'Ala': 'A',
206
+ 'Arg': 'R',
207
+ 'Asn': 'N',
208
+ 'Asp': 'D',
209
+ 'Cys': 'C',
210
+ 'Gln': 'Q',
211
+ 'Glu': 'E',
212
+ 'Gly': 'G',
213
+ 'His': 'H',
214
+ 'Ile': 'I',
215
+ 'Leu': 'L',
216
+ 'Lys': 'K',
217
+ 'Met': 'M',
218
+ 'Phe': 'F',
219
+ 'Pro': 'P',
220
+ 'Ser': 'S',
221
+ 'Thr': 'T',
222
+ 'Trp': 'W',
223
+ 'Tyr': 'Y',
224
+ 'Val': 'V',
225
+ };
226
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aminoacids.js","sourceRoot":"","sources":["aminoacids.ts"],"names":[],"mappings":"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","sourcesContent":["import * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\n\nimport {StringDictionary} from '@datagrok-libraries/utils/src/type-declarations';\nimport {SeqPalette, SeqPaletteBase} from './seq-palettes';\n\nexport class AminoacidsPalettes extends SeqPaletteBase {\n  private static lesk: SeqPalette;\n\n  public static get Lesk(): SeqPalette {\n    if (this.lesk === void 0) {\n      this.lesk = this.makePalette([\n        [['G', 'A', 'S', 'T'], 'orange'],\n        [['C', 'V', 'I', 'L', 'P', 'F', 'Y', 'M', 'W'], 'all_green'],\n        [['N', 'Q', 'H'], 'magenta'],\n        [['D', 'E'], 'red'],\n        [['K', 'R'], 'all_blue'],\n      ]);\n    }\n    return this.lesk;\n  }\n\n  private static grokGroups: SeqPalette;\n\n  public static get GrokGroups(): SeqPalette {\n    if (this.grokGroups === void 0) {\n      this.grokGroups = this.makePalette([\n        [['C', 'U'], 'yellow'],\n        [['G', 'P'], 'red'],\n        [['A', 'V', 'I', 'L', 'M', 'F', 'Y', 'W'], 'all_green'],\n        [['R', 'H', 'K'], 'light_blue'],\n        [['D', 'E'], 'dark_blue'],\n        [['S', 'T', 'N', 'Q'], 'orange'],\n      ]);\n    }\n    return this.grokGroups;\n  }\n\n  private static rasMol: SeqPalette;\n\n  public static get RasMol(): SeqPalette {\n    if (this.rasMol === void 0) {\n      this.rasMol = {\n        // http://acces.ens-lyon.fr/biotic/rastop/help/colour.htm\n        'D': '#E60A0A', // asp, aspartic acid, asp\n        'E': '#E60A0A', // glu, glutamic acid\n        'C': '#E6E600', // cys, cysteine\n        'M': '#E6E600', // met, methionine\n        'K': '#145AFF', // lys, lysine\n        'R': '#145AFF', // arg, arginine\n        'S': '#FA9600', // ser, serine\n        'T': '#FA9600', // thr, threonine\n        'F': '#3232AA', // phe, phenylalanine\n        'Y': '#3232AA', // tyr, tyrosine\n        'N': '#00DCDC', // asn, asparagine\n        'Q': '#00DCDC', // gln, glutamine\n        'G': '#EBEBEB', // gly, glycine\n        'L': '#0F820F', // leu, leucine\n        'V': '#0F820F', // val, valine\n        'I': '#0F820F', // ile, isoleucine\n        'A': '#C8C8C8', // ala, alanine\n        'W': '#B45AB4', // trp, tryptophan\n        'H': '#8282D2', // his, histidine\n        'P': '#DC9682', // pro, proline\n        'others': '#BEA06E',\n      };\n    }\n    return this.rasMol;\n  }\n}\n\nexport class Aminoacids {\n  static readonly SemType: string = 'Aminoacids';\n\n  static readonly SemTypeMultipleAlignment: string = 'AminoacidsMultipleAlignment';\n\n  static undefinedColor = 'rgb(100,100,100)';\n\n  public static Names: StringDictionary = {\n    'G': 'Glycine',\n    'L': 'Leucine',\n    'Y': 'Tyrosine',\n    'S': 'Serine',\n    'E': 'Glutamic acid',\n    'Q': 'Glutamine',\n    'D': 'Aspartic acid',\n    'N': 'Asparagine',\n    'F': 'Phenylalanine',\n    'A': 'Alanine',\n    'K': 'Lysine',\n    'R': 'Arginine',\n    'H': 'Histidine',\n    'C': 'Cysteine',\n    'V': 'Valine',\n    'P': 'Proline',\n    'W': 'Tryptophan',\n    'I': 'Isoleucine',\n    'M': 'Methionine',\n    'T': 'Threonine',\n  };\n\n  public static AASmiles: StringDictionary = {\n    'G': 'NCC(=O)O',\n    'L': 'N[C@H](CC(C)C)C(=O)O',\n    'Y': 'NC(CC1=CC=C(O)C=C1)C(=O)O',\n    'S': 'NC(CO)C(=O)O',\n    'E': 'N[C@@H](CCC(O)=O)C(=O)O',\n    'Q': 'N[C@@H](CCC(N)=O)C(=O)O',\n    'D': 'N[C@@H](CC(O)=O)C(=O)O',\n    'N': 'N[C@@H](CC(N)=O)C(=O)O',\n    'F': 'NC(CC1=CC=CC=C1)C(=O)O',\n    'A': 'N[C@H](C)C(=O)O',\n    'K': 'NC(CCCCN)C(=O)O',\n    'R': 'N[C@H](CCCNC(=N)C)C(=O)O',\n    'H': 'NC(CC1=CN=C[N]1)C(=O)O',\n    'C': 'N[C@@H](CS)C(=O)O',\n    'V': 'NC(C(C)C)C(=O)O',\n    'P': 'N(CCC1)C1C(=O)O',\n    'W': 'N[C@@H](Cc1c2ccccc2n([H])c1)C(=O)O',\n    'I': 'N[C@H]([C@H](C)CC)C(=O)O',\n    'M': 'NC(CCSC)C(=O)O',\n    'T': 'NC(C(O)C)C(=O)O',\n  };\n\n  public static AASmilesTruncated: StringDictionary = {\n    'G': '*C*',\n    'L': 'CC(C)C[C@H](*)*',\n    'Y': 'C1=CC(=CC=C1CC(*)*)O',\n    'S': 'OCC(*)C*',\n    'E': '*[C@@H](CCC(O)=O)*',\n    'Q': '*N[C@@H](CCC(N)=O)*',\n    'D': '*[C@@H](CC(O)=O)*',\n    'N': '*[C@@H](CC(N)=O)*',\n    'F': 'C1=CC=C(C=C1)CC(*)*',\n    'A': 'C[C@H](*)*',\n    'K': 'C(CCN)CC(*)*',\n    'R': '*[C@H](CCCNC(=N)C)*',\n    'H': 'C1=C(NC=N1)CC(*)*',\n    'C': 'C([C@@H](*)*)S',\n    'V': 'CC(C)C(*)*',\n    'P': 'C1CCN(*)C1*',\n    'W': '*[C@@H](Cc1c2ccccc2n([H])c1)*',\n    'I': 'CC[C@H](C)[C@H](*)*',\n    'M': 'CSCCC(*)*',\n    'T': 'CC(O)C(*)*',\n  };\n\n  /** TODO: Full?\n   */\n  public static AAFullNames: StringDictionary = {\n    'Ala': 'A',\n    'Arg': 'R',\n    'Asn': 'N',\n    'Asp': 'D',\n    'Cys': 'C',\n    'Gln': 'Q',\n    'Glu': 'E',\n    'Gly': 'G',\n    'His': 'H',\n    'Ile': 'I',\n    'Leu': 'L',\n    'Lys': 'K',\n    'Met': 'M',\n    'Phe': 'F',\n    'Pro': 'P',\n    'Ser': 'S',\n    'Thr': 'T',\n    'Trp': 'W',\n    'Tyr': 'Y',\n    'Val': 'V',\n  };\n\n  public static getPalette(scheme: string = 'grok'): SeqPalette {\n    switch (scheme) {\n    case 'grok':\n      return AminoacidsPalettes.GrokGroups;\n    case 'lesk':\n      return AminoacidsPalettes.Lesk;\n    default:\n      throw new Error(`ChemPalette: scheme \\`${scheme}\\` does not exist`);\n    }\n  }\n\n  /**\n   * Returns divided amino acid with its content in the bracket, if the content is number, then its omitted\n   *\n   * @param {string} c raw amino\n   * @return {[string, string]} outer and inner content\n   */\n  public static getInnerOuter(c: string): [string, string] {\n    let isInner = 0;\n    let inner = '';\n    let outer = '';\n\n    for (const char of c) {\n      if (char == '(')\n        isInner++;\n      else if (char == ')')\n        isInner--;\n      else if (isInner)\n        inner += char;\n      else\n        outer += char;\n    }\n\n    return !isNaN(parseInt(inner)) ? [outer, ''] : [outer, inner];\n  }\n\n  public static getColorAAPivot(monomer: string = '', scheme: 'grok' = 'grok'): [string, string, string, number] {\n    //const chemPaletteInstance = AAPalettes.GrokGroups();\n    const chemPaletteInstance = this.getPalette(scheme);\n    let [outerMonomer, innerMonomer] = this.getInnerOuter(monomer);\n    outerMonomer = (outerMonomer.length > 6 ? `${outerMonomer.slice(0, 3)}...` : outerMonomer);\n    innerMonomer = (innerMonomer.length > 6 ? `${innerMonomer.slice(0, 3)}...` : innerMonomer);\n\n    if (monomer.length == 1 || monomer[1] == '(') {\n      const amino = monomer[0]?.toUpperCase()!;\n      return amino in chemPaletteInstance ?\n        [chemPaletteInstance[amino], amino, innerMonomer, 1] :\n        [this.undefinedColor, outerMonomer, innerMonomer, 1];\n    }\n\n    if (monomer[0] == 'd' && monomer[1]! in chemPaletteInstance) {\n      if (monomer.length == 2 || monomer[2] == '(') {\n        const amino = monomer[1]?.toUpperCase()!;\n        return amino in chemPaletteInstance ?\n          [chemPaletteInstance[amino], amino, innerMonomer, 2] :\n          [this.undefinedColor, outerMonomer, innerMonomer, 2];\n      }\n    }\n\n    if (monomer.substring(0, 3) in this.AAFullNames) {\n      if (monomer.length == 3 || monomer[3] == '(') {\n        const amino = this.AAFullNames[monomer.substring(0, 3)];\n        return amino in chemPaletteInstance ?\n          [chemPaletteInstance[amino], amino, innerMonomer, 3] :\n          [this.undefinedColor, outerMonomer, innerMonomer, 3];\n      }\n    }\n\n    if (monomer[0]?.toLowerCase() == monomer[0]) {\n      if (monomer.substring(1, 3) in this.AAFullNames) {\n        if (monomer.length == 4 || monomer[4] == '(') {\n          const amino = this.AAFullNames[monomer.substring(1, 3)];\n          return amino in chemPaletteInstance ?\n            [chemPaletteInstance[amino], amino, innerMonomer, 4] :\n            [this.undefinedColor, outerMonomer, innerMonomer, 4];\n        }\n      }\n    }\n\n    return [this.undefinedColor, outerMonomer, innerMonomer, 0];\n  }\n}\n"]}
package/src/index.d.ts ADDED
@@ -0,0 +1,7 @@
1
+ import { SeqPalette } from './seq-palettes';
2
+ import { Aminoacids, AminoacidsPalettes } from './aminoacids';
3
+ import { Nucleotides, NucleotidesPalettes } from './nucleotides';
4
+ import { WebLogo, PositionInfo, PositionMonomerInfo } from './viewers/web-logo';
5
+ export { SeqPalette, AminoacidsPalettes, Aminoacids, NucleotidesPalettes, Nucleotides };
6
+ export { WebLogo, PositionInfo, PositionMonomerInfo };
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAC,UAAU,EAAE,kBAAkB,EAAC,MAAM,cAAc,CAAC;AAC5D,OAAO,EAAC,WAAW,EAAE,mBAAmB,EAAC,MAAM,eAAe,CAAC;AAC/D,OAAO,EAAC,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAC,MAAM,oBAAoB,CAAC;AAE9E,OAAO,EAAC,UAAU,EAAE,kBAAkB,EAAE,UAAU,EAAE,mBAAmB,EAAE,WAAW,EAAC,CAAC;AACtF,OAAO,EAAC,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAC,CAAC"}
package/src/index.js ADDED
@@ -0,0 +1,6 @@
1
+ import { Aminoacids, AminoacidsPalettes } from './aminoacids';
2
+ import { Nucleotides, NucleotidesPalettes } from './nucleotides';
3
+ import { WebLogo, PositionInfo, PositionMonomerInfo } from './viewers/web-logo';
4
+ export { AminoacidsPalettes, Aminoacids, NucleotidesPalettes, Nucleotides };
5
+ export { WebLogo, PositionInfo, PositionMonomerInfo };
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUMsVUFBVSxFQUFFLGtCQUFrQixFQUFDLE1BQU0sY0FBYyxDQUFDO0FBQzVELE9BQU8sRUFBQyxXQUFXLEVBQUUsbUJBQW1CLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDL0QsT0FBTyxFQUFDLE9BQU8sRUFBRSxZQUFZLEVBQUUsbUJBQW1CLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQztBQUU5RSxPQUFPLEVBQWEsa0JBQWtCLEVBQUUsVUFBVSxFQUFFLG1CQUFtQixFQUFFLFdBQVcsRUFBQyxDQUFDO0FBQ3RGLE9BQU8sRUFBQyxPQUFPLEVBQUUsWUFBWSxFQUFFLG1CQUFtQixFQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1NlcVBhbGV0dGV9IGZyb20gJy4vc2VxLXBhbGV0dGVzJztcbmltcG9ydCB7QW1pbm9hY2lkcywgQW1pbm9hY2lkc1BhbGV0dGVzfSBmcm9tICcuL2FtaW5vYWNpZHMnO1xuaW1wb3J0IHtOdWNsZW90aWRlcywgTnVjbGVvdGlkZXNQYWxldHRlc30gZnJvbSAnLi9udWNsZW90aWRlcyc7XG5pbXBvcnQge1dlYkxvZ28sIFBvc2l0aW9uSW5mbywgUG9zaXRpb25Nb25vbWVySW5mb30gZnJvbSAnLi92aWV3ZXJzL3dlYi1sb2dvJztcblxuZXhwb3J0IHtTZXFQYWxldHRlLCBBbWlub2FjaWRzUGFsZXR0ZXMsIEFtaW5vYWNpZHMsIE51Y2xlb3RpZGVzUGFsZXR0ZXMsIE51Y2xlb3RpZGVzfTtcbmV4cG9ydCB7V2ViTG9nbywgUG9zaXRpb25JbmZvLCBQb3NpdGlvbk1vbm9tZXJJbmZvfTtcblxuIl19
package/src/index.ts ADDED
@@ -0,0 +1,8 @@
1
+ import {SeqPalette} from './seq-palettes';
2
+ import {Aminoacids, AminoacidsPalettes} from './aminoacids';
3
+ import {Nucleotides, NucleotidesPalettes} from './nucleotides';
4
+ import {WebLogo, PositionInfo, PositionMonomerInfo} from './viewers/web-logo';
5
+
6
+ export {SeqPalette, AminoacidsPalettes, Aminoacids, NucleotidesPalettes, Nucleotides};
7
+ export {WebLogo, PositionInfo, PositionMonomerInfo};
8
+
@@ -0,0 +1,12 @@
1
+ import { StringDictionary } from '@datagrok-libraries/utils/src/type-declarations';
2
+ import { SeqPalette, SeqPaletteBase } from './seq-palettes';
3
+ export declare class NucleotidesPalettes extends SeqPaletteBase {
4
+ private static chromatogram;
5
+ static get Chromatogram(): SeqPalette;
6
+ }
7
+ export declare class Nucleotides {
8
+ static readonly SemType: string;
9
+ static readonly SemTypeMultipleAlignment: string;
10
+ static Names: StringDictionary;
11
+ }
12
+ //# sourceMappingURL=nucleotides.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nucleotides.d.ts","sourceRoot":"","sources":["nucleotides.ts"],"names":[],"mappings":"AAIA,OAAO,EAAC,gBAAgB,EAAC,MAAM,iDAAiD,CAAC;AACjF,OAAO,EAAC,UAAU,EAAE,cAAc,EAAC,MAAM,gBAAgB,CAAC;AAE1D,qBAAa,mBAAoB,SAAQ,cAAc;IACrD,OAAO,CAAC,MAAM,CAAC,YAAY,CAAa;IAExC,WAAkB,YAAY,IAAI,UAAU,CAW3C;CACF;AAED,qBAAa,WAAW;IACtB,MAAM,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAuB;IAEtD,MAAM,CAAC,QAAQ,CAAC,wBAAwB,EAAE,MAAM,CAAkC;IAElF,OAAc,KAAK,EAAE,gBAAgB,CAMnC;CACH"}
@@ -0,0 +1,27 @@
1
+ import { SeqPaletteBase } from './seq-palettes';
2
+ export class NucleotidesPalettes extends SeqPaletteBase {
3
+ static get Chromatogram() {
4
+ if (this.chromatogram === void 0) {
5
+ this.chromatogram = {
6
+ 'A': 'green',
7
+ 'C': 'blue',
8
+ 'G': 'black',
9
+ 'T': 'red', 'U': 'red',
10
+ 'others': 'gray',
11
+ };
12
+ }
13
+ return this.chromatogram;
14
+ }
15
+ }
16
+ export class Nucleotides {
17
+ }
18
+ Nucleotides.SemType = 'MultipleAlignment';
19
+ Nucleotides.SemTypeMultipleAlignment = 'NucleotidesMultipleAlignment';
20
+ Nucleotides.Names = {
21
+ 'A': 'Adenine',
22
+ 'C': 'Cytosine',
23
+ 'G': 'Guanine',
24
+ 'T': 'Thymine',
25
+ 'U': 'Uracil',
26
+ };
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVjbGVvdGlkZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJudWNsZW90aWRlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLQSxPQUFPLEVBQWEsY0FBYyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFFMUQsTUFBTSxPQUFPLG1CQUFvQixTQUFRLGNBQWM7SUFHOUMsTUFBTSxLQUFLLFlBQVk7UUFDNUIsSUFBSSxJQUFJLENBQUMsWUFBWSxLQUFLLEtBQUssQ0FBQyxFQUFFO1lBQ2hDLElBQUksQ0FBQyxZQUFZLEdBQUc7Z0JBQ2xCLEdBQUcsRUFBRSxPQUFPO2dCQUNaLEdBQUcsRUFBRSxNQUFNO2dCQUNYLEdBQUcsRUFBRSxPQUFPO2dCQUNaLEdBQUcsRUFBRSxLQUFLLEVBQUUsR0FBRyxFQUFFLEtBQUs7Z0JBQ3RCLFFBQVEsRUFBRSxNQUFNO2FBQ2pCLENBQUM7U0FDSDtRQUNELE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQztJQUMzQixDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8sV0FBVzs7QUFDTixtQkFBTyxHQUFXLG1CQUFtQixDQUFDO0FBRXRDLG9DQUF3QixHQUFXLDhCQUE4QixDQUFDO0FBRXBFLGlCQUFLLEdBQXFCO0lBQ3RDLEdBQUcsRUFBRSxTQUFTO0lBQ2QsR0FBRyxFQUFFLFVBQVU7SUFDZixHQUFHLEVBQUUsU0FBUztJQUNkLEdBQUcsRUFBRSxTQUFTO0lBQ2QsR0FBRyxFQUFFLFFBQVE7Q0FDZCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgZ3JvayBmcm9tICdkYXRhZ3Jvay1hcGkvZ3Jvayc7XG5pbXBvcnQgKiBhcyB1aSBmcm9tICdkYXRhZ3Jvay1hcGkvdWknO1xuaW1wb3J0ICogYXMgREcgZnJvbSAnZGF0YWdyb2stYXBpL2RnJztcblxuaW1wb3J0IHtTdHJpbmdEaWN0aW9uYXJ5fSBmcm9tICdAZGF0YWdyb2stbGlicmFyaWVzL3V0aWxzL3NyYy90eXBlLWRlY2xhcmF0aW9ucyc7XG5pbXBvcnQge1NlcVBhbGV0dGUsIFNlcVBhbGV0dGVCYXNlfSBmcm9tICcuL3NlcS1wYWxldHRlcyc7XG5cbmV4cG9ydCBjbGFzcyBOdWNsZW90aWRlc1BhbGV0dGVzIGV4dGVuZHMgU2VxUGFsZXR0ZUJhc2Uge1xuICBwcml2YXRlIHN0YXRpYyBjaHJvbWF0b2dyYW06IFNlcVBhbGV0dGU7XG5cbiAgcHVibGljIHN0YXRpYyBnZXQgQ2hyb21hdG9ncmFtKCk6IFNlcVBhbGV0dGUge1xuICAgIGlmICh0aGlzLmNocm9tYXRvZ3JhbSA9PT0gdm9pZCAwKSB7XG4gICAgICB0aGlzLmNocm9tYXRvZ3JhbSA9IHtcbiAgICAgICAgJ0EnOiAnZ3JlZW4nLFxuICAgICAgICAnQyc6ICdibHVlJyxcbiAgICAgICAgJ0cnOiAnYmxhY2snLCAvLyBvcmFuZ2UgP1xuICAgICAgICAnVCc6ICdyZWQnLCAnVSc6ICdyZWQnLFxuICAgICAgICAnb3RoZXJzJzogJ2dyYXknLFxuICAgICAgfTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuY2hyb21hdG9ncmFtO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBOdWNsZW90aWRlcyB7XG4gIHN0YXRpYyByZWFkb25seSBTZW1UeXBlOiBzdHJpbmcgPSAnTXVsdGlwbGVBbGlnbm1lbnQnO1xuXG4gIHN0YXRpYyByZWFkb25seSBTZW1UeXBlTXVsdGlwbGVBbGlnbm1lbnQ6IHN0cmluZyA9ICdOdWNsZW90aWRlc011bHRpcGxlQWxpZ25tZW50JztcblxuICBwdWJsaWMgc3RhdGljIE5hbWVzOiBTdHJpbmdEaWN0aW9uYXJ5ID0ge1xuICAgICdBJzogJ0FkZW5pbmUnLFxuICAgICdDJzogJ0N5dG9zaW5lJyxcbiAgICAnRyc6ICdHdWFuaW5lJyxcbiAgICAnVCc6ICdUaHltaW5lJyxcbiAgICAnVSc6ICdVcmFjaWwnLFxuICB9O1xufVxuIl19
@@ -0,0 +1 @@
1
+ //# sourceMappingURL=package.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"package.d.ts","sourceRoot":"","sources":["package.ts"],"names":[],"mappings":""}
package/src/package.js ADDED
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFja2FnZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInBhY2thZ2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIiJdfQ==
@@ -0,0 +1,16 @@
1
+ export interface SeqPalette {
2
+ /**
3
+ * @param {string} m Monomer character
4
+ * @return {string} Color
5
+ */
6
+ [m: string]: string;
7
+ }
8
+ export declare class SeqPaletteBase {
9
+ /** Palette with shades of primary colors
10
+ */
11
+ private static colourPalette;
12
+ protected static makePalette(dt: [string[], string][], simplified?: boolean): {
13
+ [key: string]: string;
14
+ };
15
+ }
16
+ //# sourceMappingURL=seq-palettes.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"seq-palettes.d.ts","sourceRoot":"","sources":["seq-palettes.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,UAAU;IACzB;;;OAGG;IACH,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;CACrB;AAED,qBAAa,cAAc;IACzB;OACG;IACH,OAAO,CAAC,MAAM,CAAC,aAAa,CAqB1B;IAEF,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,EAAE,CAAC,MAAM,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE,UAAU,UAAQ;;;CAW1E"}