@datagrok-libraries/bio 5.9.7 → 5.9.11

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.
@@ -1,154 +0,0 @@
1
- /** HELM associated sdf libraries with monomer processing*/
2
- export class MonomerLibrary {
3
- constructor(sdf) {
4
- this.monomerFields = [
5
- 'molecule', 'MonomerType', 'MonomerNaturalAnalogCode', 'MonomerName', 'MonomerCode', 'MonomerCaps', 'BranchMonomer',
6
- ];
7
- this.library = {};
8
- this.monomers = [];
9
- const sdfReader = new SDFReader();
10
- const data = sdfReader.getColls(sdf);
11
- this.monomerFields.forEach((f) => {
12
- if (!(f in data))
13
- throw new Error(`Monomer library was not compiled: ${f} field is absent in provided file`);
14
- if (data[f].length != data.molecule.length)
15
- throw new Error(`Monomer library was not compiled: ${f} field is not presented for each monomer`);
16
- });
17
- for (let i = 0; i < data.molecule.length; i++) {
18
- const linkData = this.getLinkData(data.molecule[i], data.MonomerCaps[i], data.MonomerName[i]);
19
- const entry = {
20
- mol: data.molecule[i],
21
- type: 'Peptide',
22
- code: data.MonomerCode[i],
23
- analogueCode: data.MonomerNaturalAnalogCode[i],
24
- linkages: linkData,
25
- };
26
- const name = data.MonomerCode[i] !== '.' ? data.MonomerCode[i] : data.MonomerName[i];
27
- this.library[name] = entry;
28
- this.monomers.push(name);
29
- }
30
- }
31
- /** getting full monomer information from monomer library
32
- * @param {string} name
33
- * @return {MonomerEntry}
34
- */
35
- getMonomerEntry(name) {
36
- if (!this.monomers.includes(name))
37
- throw new Error(`Monomer library do not contain ${name} monomer`);
38
- return this.library[name];
39
- }
40
- /** getting mol as string for monomer
41
- * @param {string} name
42
- * @return {string}
43
- */
44
- getMonomerMol(name) {
45
- if (!this.monomers.includes(name))
46
- throw new Error(`Monomer library do not contain ${name} monomer`);
47
- const entry = this.library[name];
48
- let monomerMol = entry.mol.replace(/M RGP .+\n/, '');
49
- //order matters
50
- const links = Object.keys(entry.linkages);
51
- for (const link of links)
52
- monomerMol = monomerMol.replace('R#', entry.linkages[link].type + ' ');
53
- return monomerMol;
54
- }
55
- /** getting the list of the minomers available in library*/
56
- get monomerNames() {
57
- return this.monomers;
58
- }
59
- static get id() {
60
- return MonomerLibrary.libName;
61
- }
62
- getLinkData(mol, caps, name) {
63
- var _a;
64
- const rawData = mol.match(/M RGP .+/);
65
- if (rawData === null)
66
- throw new Error(`Monomer library was not compiled: ${name} entry has no RGP`);
67
- const types = {};
68
- (_a = caps.split('\n')) === null || _a === void 0 ? void 0 : _a.forEach((e) => {
69
- types[e.match(/\d+/)[0]] = e.match(/(?<=\])\w+/)[0];
70
- });
71
- const data = rawData[0].replace('M RGP ', '').split(/\s+/);
72
- const res = {};
73
- for (let i = 0; i < parseInt(data[0]); i++) {
74
- const code = parseInt(data[2 * i + 2]);
75
- let type = '';
76
- switch (code) {
77
- case 1:
78
- type = 'N-terminal';
79
- break;
80
- case 2:
81
- type = 'C-terminal';
82
- break;
83
- case 3:
84
- type = 'branch';
85
- break;
86
- default:
87
- break;
88
- }
89
- res[type] = { atomNumber: parseInt(data[2 * i + 1]), type: types[code] };
90
- }
91
- return res;
92
- }
93
- }
94
- MonomerLibrary.libName = 'monomerLibrary';
95
- //TODO: merge with Chem version
96
- class SDFReader {
97
- constructor() {
98
- this.dataColls = { 'molecule': [] };
99
- }
100
- getColls(content) {
101
- this.read(content);
102
- return this.dataColls;
103
- }
104
- read(content) {
105
- content = content.replaceAll('\r', ''); //equalize old and new sdf standards
106
- let startIndex = content.indexOf('$$$$', 0);
107
- this.parse(content, 0, startIndex, (name, val) => {
108
- this.dataColls[name] = [];
109
- this.dataColls[name].push(val);
110
- });
111
- startIndex += 5;
112
- while (startIndex > -1 && startIndex < content.length)
113
- startIndex = this.readNext(content, startIndex);
114
- }
115
- readNext(content, startIndex) {
116
- const nextStartIndex = content.indexOf('$$$$', startIndex);
117
- if (nextStartIndex === -1) {
118
- return -1;
119
- }
120
- else {
121
- this.parse(content, startIndex, nextStartIndex, (name, val) => {
122
- this.dataColls[name].push(val);
123
- });
124
- }
125
- if (nextStartIndex > -1)
126
- return nextStartIndex + 5;
127
- return nextStartIndex;
128
- }
129
- parse(content, start, end, handler) {
130
- const molEnd = +content.indexOf('M END\n', start) + 7;
131
- let localEnd = start;
132
- this.dataColls['molecule'].push(content.substring(start, molEnd));
133
- start = molEnd;
134
- while (localEnd < end) {
135
- start = content.indexOf('> <', localEnd);
136
- if (start === -1)
137
- return;
138
- start += 3;
139
- localEnd = content.indexOf('>\n', start);
140
- if (localEnd === -1)
141
- return;
142
- const propertyName = content.substring(start, localEnd);
143
- start = localEnd + 2;
144
- localEnd = content.indexOf('\n', start);
145
- if (localEnd === -1)
146
- localEnd = end;
147
- else if (content[localEnd + 1] != '\n')
148
- localEnd = content.indexOf('\n', localEnd + 1);
149
- handler(propertyName, content.substring(start, localEnd));
150
- localEnd += 2;
151
- }
152
- }
153
- }
154
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monomer-library.js","sourceRoot":"","sources":["monomer-library.ts"],"names":[],"mappings":"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","sourcesContent":["export type MonomerEntry = {\n  mol: string,\n  type: string,\n  analogueCode: string,\n  linkages: { [link: string]: { atomNumber: number, type: string } }\n};\nexport type MonomerEntries = { [name: string]: MonomerEntry };\nexport type LinkData = { [link: string]: { atomNumber: number, type: string } };\n\n/** HELM associated sdf libraries with monomer processing*/\nexport class MonomerLibrary {\n  static libName = 'monomerLibrary';\n\n  private monomerFields: string[] = [\n    'molecule', 'MonomerType', 'MonomerNaturalAnalogCode', 'MonomerName', 'MonomerCode', 'MonomerCaps', 'BranchMonomer',\n  ];\n\n  private library: MonomerEntries = {};\n\n  private monomers: string[] = [];\n\n  constructor(sdf: string) {\n    const sdfReader = new SDFReader();\n    const data = sdfReader.getColls(sdf);\n    this.monomerFields.forEach((f) => {\n      if (!(f in data))\n        throw new Error(`Monomer library was not compiled: ${f} field is absent in provided file`);\n\n      if (data[f].length != data.molecule.length)\n        throw new Error(`Monomer library was not compiled: ${f} field is not presented for each monomer`);\n    });\n\n    for (let i = 0; i < data.molecule.length; i++) {\n      const linkData = this.getLinkData(data.molecule[i], data.MonomerCaps[i], data.MonomerName[i]);\n      const entry = {\n        mol: data.molecule[i],\n        type: 'Peptide',\n        code: data.MonomerCode[i],\n        analogueCode: data.MonomerNaturalAnalogCode[i],\n        linkages: linkData,\n      };\n\n      const name = data.MonomerCode[i] !== '.' ? data.MonomerCode[i] : data.MonomerName[i];\n      this.library[name] = entry;\n      this.monomers.push(name);\n    }\n  }\n\n  /** getting full monomer information from monomer library\n   * @param {string} name\n   * @return {MonomerEntry}\n   */\n  public getMonomerEntry(name: string): MonomerEntry {\n    if (!this.monomers.includes(name))\n      throw new Error(`Monomer library do not contain ${name} monomer`);\n\n    return this.library[name];\n  }\n\n  /** getting mol as string for monomer\n   * @param {string} name\n   * @return {string}\n   */\n  public getMonomerMol(name: string): string {\n    if (!this.monomers.includes(name))\n      throw new Error(`Monomer library do not contain ${name} monomer`);\n\n\n    const entry = this.library[name];\n    let monomerMol = entry.mol.replace(/M  RGP  .+\\n/, '');\n\n    //order matters\n    const links = Object.keys(entry.linkages);\n    for (const link of links)\n      monomerMol = monomerMol.replace('R#', entry.linkages[link].type + ' ');\n\n\n    return monomerMol;\n  }\n\n  /** getting the list of the minomers available in library*/\n  get monomerNames(): string[] {\n    return this.monomers;\n  }\n\n  static get id(): string {\n    return MonomerLibrary.libName;\n  }\n\n  private getLinkData(mol: string, caps: string, name: string): LinkData {\n    const rawData = mol.match(/M  RGP  .+/);\n    if (rawData === null)\n      throw new Error(`Monomer library was not compiled: ${name} entry has no RGP`);\n\n    const types: { [code: string]: string } = {};\n    caps.split('\\n')?.forEach((e) => {\n      types[e.match(/\\d+/)![0]] = e.match(/(?<=\\])\\w+/)![0];\n    });\n\n    const data = rawData[0].replace('M  RGP  ', '').split(/\\s+/);\n    const res: LinkData = {};\n    for (let i = 0; i < parseInt(data[0]); i++) {\n      const code = parseInt(data[2 * i + 2]);\n      let type = '';\n      switch (code) {\n      case 1:\n        type = 'N-terminal';\n        break;\n      case 2:\n        type = 'C-terminal';\n        break;\n      case 3:\n        type = 'branch';\n        break;\n      default:\n        break;\n      }\n      res[type] = {atomNumber: parseInt(data[2 * i + 1]), type: types[code]};\n    }\n\n    return res;\n  }\n}\n\n//TODO: merge with Chem version\nclass SDFReader {\n  dataColls: { [_: string]: string [] };\n\n  constructor() {\n    this.dataColls = {'molecule': []};\n  }\n\n  getColls(content: string): { [_: string]: string[] } {\n    this.read(content);\n    return this.dataColls;\n  }\n\n  read(content: string): void {\n    content = content.replaceAll('\\r', ''); //equalize old and new sdf standards\n    let startIndex = content.indexOf('$$$$', 0);\n    this.parse(content, 0, startIndex, (name: string, val: string): void => { // TODO: type\n      this.dataColls[name] = [];\n      this.dataColls[name].push(val);\n    });\n    startIndex += 5;\n    while (startIndex > -1 && startIndex < content.length)\n      startIndex = this.readNext(content, startIndex);\n  }\n\n  readNext(content: string, startIndex: number): number {\n    const nextStartIndex = content.indexOf('$$$$', startIndex);\n    if (nextStartIndex === -1) {\n      return -1;\n    } else {\n      this.parse(content, startIndex, nextStartIndex,\n        (name: string, val: string): void => {\n          this.dataColls[name].push(val);\n        });\n    }\n\n    if (nextStartIndex > -1)\n      return nextStartIndex + 5;\n\n\n    return nextStartIndex;\n  }\n\n  parse(content: string, start: number, end: number, handler: (name: string, val: string) => void): void {\n    const molEnd = +content.indexOf('M  END\\n', start) + 7;\n    let localEnd = start;\n    this.dataColls['molecule'].push(content.substring(start, molEnd));\n\n    start = molEnd;\n    while (localEnd < end) {\n      start = content.indexOf('> <', localEnd);\n      if (start === -1)\n        return;\n\n\n      start += 3;\n      localEnd = content.indexOf('>\\n', start);\n      if (localEnd === -1)\n        return;\n\n\n      const propertyName = content.substring(start, localEnd);\n      start = localEnd + 2;\n\n      localEnd = content.indexOf('\\n', start);\n      if (localEnd === -1)\n        localEnd = end;\n      else if (content[localEnd + 1] != '\\n')\n        localEnd = content.indexOf('\\n', localEnd + 1);\n\n      handler(propertyName, content.substring(start, localEnd));\n      localEnd += 2;\n    }\n  }\n}\n"]}