@datagrok/sequence-translator 0.0.9 → 0.0.12

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.
@@ -0,0 +1,2387 @@
1
+ var sequencetranslator_test;
2
+ /******/ (() => { // webpackBootstrap
3
+ /******/ "use strict";
4
+ /******/ var __webpack_modules__ = ({
5
+
6
+ /***/ "./node_modules/@datagrok-libraries/utils/src/test.js":
7
+ /*!************************************************************!*\
8
+ !*** ./node_modules/@datagrok-libraries/utils/src/test.js ***!
9
+ \************************************************************/
10
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
11
+
12
+ __webpack_require__.r(__webpack_exports__);
13
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
14
+ /* harmony export */ "tests": () => (/* binding */ tests),
15
+ /* harmony export */ "currentCategory": () => (/* binding */ currentCategory),
16
+ /* harmony export */ "assure": () => (/* binding */ assure),
17
+ /* harmony export */ "Test": () => (/* binding */ Test),
18
+ /* harmony export */ "test": () => (/* binding */ test),
19
+ /* harmony export */ "assertNoError": () => (/* binding */ assertNoError),
20
+ /* harmony export */ "expect": () => (/* binding */ expect),
21
+ /* harmony export */ "expectFloat": () => (/* binding */ expectFloat),
22
+ /* harmony export */ "category": () => (/* binding */ category),
23
+ /* harmony export */ "before": () => (/* binding */ before),
24
+ /* harmony export */ "after": () => (/* binding */ after),
25
+ /* harmony export */ "runTests": () => (/* binding */ runTests),
26
+ /* harmony export */ "delay": () => (/* binding */ delay)
27
+ /* harmony export */ });
28
+ /* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! datagrok-api/grok */ "datagrok-api/grok");
29
+ /* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__);
30
+ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
31
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
32
+ return new (P || (P = Promise))(function (resolve, reject) {
33
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
34
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
35
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
36
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
37
+ });
38
+ };
39
+
40
+ let tests = {};
41
+ let currentCategory;
42
+ var assure;
43
+ (function (assure) {
44
+ function notNull(value, name) {
45
+ if (value == null)
46
+ throw `${name == null ? 'Value' : name} not defined`;
47
+ }
48
+ assure.notNull = notNull;
49
+ })(assure || (assure = {}));
50
+ class Test {
51
+ constructor(category, name, test, options) {
52
+ var _a, _b;
53
+ this.category = category;
54
+ this.name = name;
55
+ options !== null && options !== void 0 ? options : (options = {});
56
+ (_a = options.timeout) !== null && _a !== void 0 ? _a : (options.timeout = 30000);
57
+ (_b = options.unhandledExceptionTimeout) !== null && _b !== void 0 ? _b : (options.unhandledExceptionTimeout = 2000);
58
+ this.options = options;
59
+ this.test = () => __awaiter(this, void 0, void 0, function* () {
60
+ return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {
61
+ let result = '';
62
+ try {
63
+ datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.lastError = '';
64
+ result = yield test();
65
+ }
66
+ catch (e) {
67
+ reject(e);
68
+ }
69
+ if (!(yield assertNoError(options.unhandledExceptionTimeout)))
70
+ reject(`Unhandled exception during test: ${datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.lastError}`);
71
+ resolve(result);
72
+ }));
73
+ });
74
+ }
75
+ }
76
+ function test(name, test, options) {
77
+ if (tests[currentCategory] == undefined)
78
+ tests[currentCategory] = {};
79
+ if (tests[currentCategory].tests == undefined)
80
+ tests[currentCategory].tests = [];
81
+ tests[currentCategory].tests.push(new Test(currentCategory, name, test, options));
82
+ }
83
+ /** Awaits for a while checking the error status of the platform */
84
+ function assertNoError(ms) {
85
+ return __awaiter(this, void 0, void 0, function* () {
86
+ for (let i = 0; i < ms / 500; ++i) {
87
+ yield delay(500);
88
+ if (datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.lastError.length !== 0)
89
+ return false;
90
+ }
91
+ return true;
92
+ });
93
+ }
94
+ /** Tests two objects for equality, throws an exception if they are not equal. */
95
+ function expect(actual, expected) {
96
+ if (actual !== expected)
97
+ throw `Expected "${expected}", got "${actual}"`;
98
+ }
99
+ function expectFloat(actual, expected, tolerance = 0.001) {
100
+ const areEqual = Math.abs(actual - expected) < 0.001;
101
+ if (!areEqual)
102
+ throw `Expected ${expected}, got ${actual} (tolerance = ${tolerance})`;
103
+ }
104
+ /** Defines a test suite. */
105
+ function category(category, tests) {
106
+ currentCategory = category;
107
+ tests();
108
+ }
109
+ /** Defines a function to be executed before the tests in this category are executed. */
110
+ function before(before) {
111
+ if (tests[currentCategory] == undefined)
112
+ tests[currentCategory] = {};
113
+ tests[currentCategory].before = before;
114
+ }
115
+ /** Defines a function to be executed after the tests in this category are executed. */
116
+ function after(after) {
117
+ if (tests[currentCategory] == undefined)
118
+ tests[currentCategory] = {};
119
+ tests[currentCategory].after = after;
120
+ }
121
+ function runTests(options) {
122
+ var _a;
123
+ return __awaiter(this, void 0, void 0, function* () {
124
+ let results = [];
125
+ for (const [key, value] of Object.entries(tests)) {
126
+ if ((options === null || options === void 0 ? void 0 : options.category) != undefined) {
127
+ if (!key.toLowerCase().startsWith(options === null || options === void 0 ? void 0 : options.category.toLowerCase()))
128
+ continue;
129
+ }
130
+ try {
131
+ if (value.before)
132
+ yield value.before();
133
+ }
134
+ catch (x) {
135
+ value.beforeStatus = x.toString();
136
+ }
137
+ let t = (_a = value.tests) !== null && _a !== void 0 ? _a : [];
138
+ let res = [];
139
+ for (let i = 0; i < t.length; i++) {
140
+ res.push(yield execTest(t[i], options === null || options === void 0 ? void 0 : options.test));
141
+ }
142
+ let data = (yield Promise.all(res)).filter((d) => d.result != 'skipped');
143
+ try {
144
+ if (value.after)
145
+ yield value.after();
146
+ }
147
+ catch (x) {
148
+ value.afterStatus = x.toString();
149
+ }
150
+ if (value.afterStatus)
151
+ data.push({ category: key, name: 'init', result: value.afterStatus, success: false });
152
+ if (value.beforeStatus)
153
+ data.push({ category: key, name: 'init', result: value.beforeStatus, success: false });
154
+ results.push(...data);
155
+ }
156
+ return results;
157
+ });
158
+ }
159
+ function execTest(t, predicate) {
160
+ var _a;
161
+ return __awaiter(this, void 0, void 0, function* () {
162
+ let r;
163
+ try {
164
+ if (predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase())))
165
+ r = { success: true, result: 'skipped' };
166
+ else
167
+ r = { success: true, result: (_a = yield t.test()) !== null && _a !== void 0 ? _a : 'OK' };
168
+ }
169
+ catch (x) {
170
+ r = { success: false, result: x.toString() };
171
+ }
172
+ r.category = t.category;
173
+ r.name = t.name;
174
+ return r;
175
+ });
176
+ }
177
+ function delay(ms) {
178
+ return __awaiter(this, void 0, void 0, function* () {
179
+ yield new Promise(r => setTimeout(r, ms));
180
+ });
181
+ }
182
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.js","sourceRoot":"","sources":["test.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,KAAK,IAAI,MAAM,mBAAmB,CAAC;AAE1C,MAAM,CAAC,IAAI,KAAK,GAA8I,EAAE,CAAC;AAEjK,MAAM,CAAC,IAAI,eAAuB,CAAC;AAEnC,MAAM,KAAW,MAAM,CAMtB;AAND,WAAiB,MAAM;IAErB,SAAgB,OAAO,CAAC,KAAU,EAAE,IAAa;QAC/C,IAAI,KAAK,IAAI,IAAI;YACf,MAAM,GAAG,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,cAAc,CAAC;IACzD,CAAC;IAHe,cAAO,UAGtB,CAAA;AACH,CAAC,EANgB,MAAM,KAAN,MAAM,QAMtB;AAOD,MAAM,OAAO,IAAI;IAMf,YAAY,QAAgB,EAAE,IAAY,EAAE,IAAwB,EAAE,OAAqB;;QACzF,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,OAAO,aAAP,OAAO,cAAP,OAAO,IAAP,OAAO,GAAK,EAAE,EAAC;QACf,MAAA,OAAO,CAAC,OAAO,oCAAf,OAAO,CAAC,OAAO,GAAK,KAAK,EAAC;QAC1B,MAAA,OAAO,CAAC,yBAAyB,oCAAjC,OAAO,CAAC,yBAAyB,GAAK,IAAI,EAAC;QAC3C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,IAAI,GAAG,GAAuB,EAAE;YACnC,OAAO,IAAI,OAAO,CAAC,CAAO,OAAO,EAAE,MAAM,EAAE,EAAE;gBAC3C,IAAI,MAAM,GAAG,EAAE,CAAC;gBAChB,IAAI;oBACF,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,EAAE,CAAC;oBAC1B,MAAM,GAAG,MAAM,IAAI,EAAE,CAAC;iBACvB;gBAAC,OAAO,CAAM,EAAE;oBACf,MAAM,CAAC,CAAC,CAAC,CAAC;iBACX;gBACD,IAAI,CAAC,CAAC,MAAM,aAAa,CAAC,OAAQ,CAAC,yBAA0B,CAAC,CAAC;oBAC7D,MAAM,CAAC,oCAAoC,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC,CAAC;gBACrE,OAAO,CAAC,MAAM,CAAC,CAAC;YAClB,CAAC,CAAA,CAAC,CAAC;QACL,CAAC,CAAA,CAAC;IACJ,CAAC;CACF;AAED,MAAM,UAAU,IAAI,CAAC,IAAY,EAAE,IAAwB,EAAE,OAAqB;IAChF,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,SAAS;QACrC,KAAK,CAAC,eAAe,CAAC,GAAG,EAAE,CAAC;IAC9B,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC,KAAK,IAAI,SAAS;QAC3C,KAAK,CAAC,eAAe,CAAC,CAAC,KAAK,GAAG,EAAE,CAAC;IACpC,KAAK,CAAC,eAAe,CAAC,CAAC,KAAM,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,eAAe,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;AACrF,CAAC;AAED,mEAAmE;AACnE,MAAM,UAAgB,aAAa,CAAC,EAAU;;QAC5C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,CAAC,EAAE;YACjC,MAAM,KAAK,CAAC,GAAG,CAAC,CAAC;YACjB,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC;gBACnC,OAAO,KAAK,CAAC;SAChB;QACD,OAAO,IAAI,CAAC;IACd,CAAC;CAAA;AAED,iFAAiF;AACjF,MAAM,UAAU,MAAM,CAAC,MAAW,EAAE,QAAa;IAC/C,IAAI,MAAM,KAAK,QAAQ;QACrB,MAAM,aAAa,QAAQ,WAAW,MAAM,GAAG,CAAC;AACpD,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,MAAc,EAAE,QAAgB,EAAE,SAAS,GAAG,KAAK;IAC7E,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,QAAQ,CAAC,GAAG,KAAK,CAAC;IACrD,IAAI,CAAC,QAAQ;QACX,MAAM,YAAY,QAAQ,SAAS,MAAM,iBAAiB,SAAS,GAAG,CAAC;AAC3E,CAAC;AAED,4BAA4B;AAC5B,MAAM,UAAU,QAAQ,CAAC,QAAgB,EAAE,KAAiB;IAC1D,eAAe,GAAG,QAAQ,CAAC;IAC3B,KAAK,EAAE,CAAC;AACV,CAAC;AAED,wFAAwF;AACxF,MAAM,UAAU,MAAM,CAAC,MAA2B;IAChD,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,SAAS;QACrC,KAAK,CAAC,eAAe,CAAC,GAAG,EAAE,CAAC;IAC9B,KAAK,CAAC,eAAe,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC;AACzC,CAAC;AAED,uFAAuF;AACvF,MAAM,UAAU,KAAK,CAAC,KAA0B;IAC9C,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,SAAS;QACrC,KAAK,CAAC,eAAe,CAAC,GAAG,EAAE,CAAC;IAC9B,KAAK,CAAC,eAAe,CAAC,CAAC,KAAK,GAAG,KAAK,CAAC;AACvC,CAAC;AAGD,MAAM,UAAgB,QAAQ,CAAC,OAA4C;;;QACzE,IAAI,OAAO,GAA4E,EAAE,CAAC;QAE1F,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YAChD,IAAI,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ,KAAI,SAAS,EAAE;gBAClC,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ,CAAC,WAAW,EAAE,CAAC;oBAChE,SAAS;aACZ;YACD,IAAI;gBACF,IAAI,KAAK,CAAC,MAAM;oBACd,MAAM,KAAK,CAAC,MAAM,EAAE,CAAC;aACxB;YAAC,OAAO,CAAM,EAAE;gBACf,KAAK,CAAC,YAAY,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;aACnC;YACD,IAAI,CAAC,GAAG,MAAA,KAAK,CAAC,KAAK,mCAAI,EAAE,CAAC;YAC1B,IAAI,GAAG,GAAG,EAAE,CAAC;YACb,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAChC,GAAG,CAAC,IAAI,CAAC,MAAM,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,IAAI,CAAC,CAAC,CAAC;aAC/C;YAED,IAAI,IAAI,GAAG,CAAC,MAAM,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,IAAI,SAAS,CAAC,CAAC;YACzE,IAAI;gBACF,IAAI,KAAK,CAAC,KAAK;oBACb,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;aACvB;YAAC,OAAO,CAAM,EAAE;gBACf,KAAK,CAAC,WAAW,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;aAClC;YACD,IAAI,KAAK,CAAC,WAAW;gBACnB,IAAI,CAAC,IAAI,CAAC,EAAC,QAAQ,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,WAAW,EAAE,OAAO,EAAE,KAAK,EAAC,CAAC,CAAC;YACtF,IAAI,KAAK,CAAC,YAAY;gBACpB,IAAI,CAAC,IAAI,CAAC,EAAC,QAAQ,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,YAAY,EAAE,OAAO,EAAE,KAAK,EAAC,CAAC,CAAC;YACvF,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;SACvB;QAED,OAAO,OAAO,CAAC;;CAChB;AAED,SAAe,QAAQ,CAAC,CAAO,EAAE,SAA6B;;;QAC5D,IAAI,CAAyE,CAAC;QAC9E,IAAI;YACF,IAAI,SAAS,IAAI,SAAS,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,CAAC;gBACvF,CAAC,GAAG,EAAC,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAC,CAAC;;gBAEvC,CAAC,GAAG,EAAC,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,MAAA,MAAM,CAAC,CAAC,IAAI,EAAE,mCAAI,IAAI,EAAC,CAAC;SACvD;QAAC,OAAO,CAAM,EAAE;YACf,CAAC,GAAG,EAAC,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE,EAAC,CAAC;SAC5C;QACD,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,QAAQ,CAAC;QACxB,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC;QAChB,OAAO,CAAC,CAAC;;CACV;AAED,MAAM,UAAgB,KAAK,CAAC,EAAU;;QACpC,MAAO,IAAI,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;IAC7C,CAAC;CAAA","sourcesContent":["import * as grok from \"datagrok-api/grok\";\n\nexport let tests: {[key: string]: {tests?: Test[], before?: () => Promise<void>, after?: () => Promise<void>, beforeStatus?: string, afterStatus?: string}} = {};\n\nexport let currentCategory: string;\n\nexport namespace assure {\n\n  export function notNull(value: any, name?: string) {\n    if (value == null)\n      throw `${name == null ? 'Value' : name} not defined`;\n  }\n}\n\nexport interface TestOptions {\n  timeout? : number;\n  unhandledExceptionTimeout? : number;\n}\n\nexport class Test {\n  test: () => Promise<any>;\n  name: string;\n  category: string;\n  options?: TestOptions;\n\n  constructor(category: string, name: string, test: () => Promise<any>, options?: TestOptions) {\n    this.category = category;\n    this.name = name;\n    options ??= {};\n    options.timeout ??= 30000;\n    options.unhandledExceptionTimeout ??= 2000;\n    this.options = options;\n    this.test = async (): Promise<any> => {\n      return new Promise(async (resolve, reject) => {\n        let result = '';\n        try {\n          grok.shell.lastError = '';\n          result = await test();\n        } catch (e: any) {\n          reject(e);\n        }\n        if (!(await assertNoError(options!.unhandledExceptionTimeout!)))\n          reject(`Unhandled exception during test: ${grok.shell.lastError}`);\n        resolve(result);\n      });\n    };\n  }\n}\n\nexport function test(name: string, test: () => Promise<any>, options?: TestOptions): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  if (tests[currentCategory].tests == undefined)\n    tests[currentCategory].tests = [];\n  tests[currentCategory].tests!.push(new Test(currentCategory, name, test, options));\n}\n\n/** Awaits for a while checking the error status of the platform */\nexport async function assertNoError(ms: number): Promise<boolean> {\n  for (let i = 0; i < ms / 500; ++i) {\n    await delay(500);\n    if (grok.shell.lastError.length !== 0)\n      return false;\n  }\n  return true;\n}\n\n/** Tests two objects for equality, throws an exception if they are not equal. */\nexport function expect(actual: any, expected: any): void {\n  if (actual !== expected)\n    throw `Expected \"${expected}\", got \"${actual}\"`;\n}\n\nexport function expectFloat(actual: number, expected: number, tolerance = 0.001): void {\n  const areEqual = Math.abs(actual - expected) < 0.001;\n  if (!areEqual)\n    throw `Expected ${expected}, got ${actual} (tolerance = ${tolerance})`;\n}\n\n/** Defines a test suite. */\nexport function category(category: string, tests: () => void): void {\n  currentCategory = category;\n  tests();\n}\n\n/** Defines a function to be executed before the tests in this category are executed. */\nexport function before(before: () => Promise<void>): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  tests[currentCategory].before = before;\n}\n\n/** Defines a function to be executed after the tests in this category are executed. */\nexport function after(after: () => Promise<void>): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  tests[currentCategory].after = after;\n}\n\n\nexport async function runTests(options?: {category?: string, test?: string}) {\n  let results: { category?: string, name?: string, success: boolean, result: string}[] = [];\n\n  for (const [key, value] of Object.entries(tests)) {\n    if (options?.category != undefined) {\n      if (!key.toLowerCase().startsWith(options?.category.toLowerCase()))\n        continue;\n    }\n    try {\n      if (value.before)\n        await value.before();\n    } catch (x: any) {\n      value.beforeStatus = x.toString();\n    }\n    let t = value.tests ?? [];\n    let res = [];\n    for(let i = 0; i < t.length; i++) {\n      res.push(await execTest(t[i], options?.test));\n    }\n\n    let data = (await Promise.all(res)).filter((d) => d.result != 'skipped');\n    try {\n      if (value.after)\n        await value.after();\n    } catch (x: any) {\n      value.afterStatus = x.toString();\n    }\n    if (value.afterStatus)\n      data.push({category: key, name: 'init', result: value.afterStatus, success: false});\n    if (value.beforeStatus)\n      data.push({category: key, name: 'init', result: value.beforeStatus, success: false});\n    results.push(...data);\n  }\n\n  return results;\n}\n\nasync function execTest(t: Test, predicate: string | undefined) {\n  let r: { category?: string, name?: string, success: boolean, result: string };\n  try {\n    if (predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase())))\n      r = {success: true, result: 'skipped'};\n    else\n      r = {success: true, result: await t.test() ?? 'OK'};\n  } catch (x: any) {\n    r = {success: false, result: x.toString()};\n  }\n  r.category = t.category;\n  r.name = t.name;\n  return r;\n}\n\nexport async function delay(ms: number) {\n  await  new Promise(r => setTimeout(r, ms));\n}\n"]}
183
+
184
+ /***/ }),
185
+
186
+ /***/ "./src/structures-works/converters.ts":
187
+ /*!********************************************!*\
188
+ !*** ./src/structures-works/converters.ts ***!
189
+ \********************************************/
190
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
191
+
192
+ __webpack_require__.r(__webpack_exports__);
193
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
194
+ /* harmony export */ "asoGapmersNucleotidesToBioSpring": () => (/* binding */ asoGapmersNucleotidesToBioSpring),
195
+ /* harmony export */ "asoGapmersNucleotidesToGcrs": () => (/* binding */ asoGapmersNucleotidesToGcrs),
196
+ /* harmony export */ "asoGapmersBioSpringToNucleotides": () => (/* binding */ asoGapmersBioSpringToNucleotides),
197
+ /* harmony export */ "asoGapmersBioSpringToGcrs": () => (/* binding */ asoGapmersBioSpringToGcrs),
198
+ /* harmony export */ "asoGapmersGcrsToBioSpring": () => (/* binding */ asoGapmersGcrsToBioSpring),
199
+ /* harmony export */ "asoGapmersGcrsToNucleotides": () => (/* binding */ asoGapmersGcrsToNucleotides),
200
+ /* harmony export */ "siRnaBioSpringToNucleotides": () => (/* binding */ siRnaBioSpringToNucleotides),
201
+ /* harmony export */ "siRnaBioSpringToAxolabs": () => (/* binding */ siRnaBioSpringToAxolabs),
202
+ /* harmony export */ "siRnaBioSpringToGcrs": () => (/* binding */ siRnaBioSpringToGcrs),
203
+ /* harmony export */ "siRnaAxolabsToGcrs": () => (/* binding */ siRnaAxolabsToGcrs),
204
+ /* harmony export */ "siRnaAxolabsToBioSpring": () => (/* binding */ siRnaAxolabsToBioSpring),
205
+ /* harmony export */ "siRnaAxolabsToNucleotides": () => (/* binding */ siRnaAxolabsToNucleotides),
206
+ /* harmony export */ "siRnaGcrsToNucleotides": () => (/* binding */ siRnaGcrsToNucleotides),
207
+ /* harmony export */ "siRnaGcrsToBioSpring": () => (/* binding */ siRnaGcrsToBioSpring),
208
+ /* harmony export */ "siRnaGcrsToAxolabs": () => (/* binding */ siRnaGcrsToAxolabs),
209
+ /* harmony export */ "siRnaNucleotideToBioSpringSenseStrand": () => (/* binding */ siRnaNucleotideToBioSpringSenseStrand),
210
+ /* harmony export */ "siRnaNucleotidesToGcrs": () => (/* binding */ siRnaNucleotidesToGcrs),
211
+ /* harmony export */ "siRnaNucleotideToAxolabsSenseStrand": () => (/* binding */ siRnaNucleotideToAxolabsSenseStrand),
212
+ /* harmony export */ "siRnaNucleotideToAxolabsAntisenseStrand": () => (/* binding */ siRnaNucleotideToAxolabsAntisenseStrand),
213
+ /* harmony export */ "gcrsToNucleotides": () => (/* binding */ gcrsToNucleotides),
214
+ /* harmony export */ "gcrsToMermade12": () => (/* binding */ gcrsToMermade12)
215
+ /* harmony export */ });
216
+ //name: asoGapmersNucleotidesToBioSpring
217
+ //input: string nucleotides {semType: DNA nucleotides}
218
+ //output: string result {semType: BioSpring / Gapmers}
219
+ function asoGapmersNucleotidesToBioSpring(nucleotides) {
220
+ let count = -1;
221
+ const objForEdges = {
222
+ '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': '5*', 'A': '6*', 'C': '7*', 'G': '8*'
223
+ };
224
+ const objForCenter = {
225
+ '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'T*', 'A': 'A*', 'C': '9*', 'G': 'G*'
226
+ };
227
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|T|C|G)/g, function (x) {
228
+ count++;
229
+ return (count > 4 && count < 15) ? objForCenter[x] : objForEdges[x];
230
+ }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?
231
+ nucleotides.length : 2 * count + 1);
232
+ }
233
+ //name: asoGapmersNucleotidesToGcrs
234
+ //input: string nucleotides {semType: DNA nucleotides}
235
+ //output: string result {semType: GCRS / Gapmers}
236
+ function asoGapmersNucleotidesToGcrs(nucleotides) {
237
+ let count = -1;
238
+ const objForEdges = {
239
+ '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'moeUnps',
240
+ 'A': 'moeAnps', 'C': 'moe5mCnps', 'G': 'moeGnps'
241
+ };
242
+ const objForCenter = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
243
+ 'C': '5mCps', 'A': 'Aps', 'T': 'Tps', 'G': 'Gps' };
244
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|T|C|G)/g, function (x) {
245
+ count++;
246
+ if (count < 5)
247
+ return (count == 4) ? objForEdges[x].slice(0, -3) + 'ps' : objForEdges[x];
248
+ if (count < 15)
249
+ return (count == 14) ? objForCenter[x].slice(0, -2) + 'nps' : objForCenter[x];
250
+ return objForEdges[x];
251
+ }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?
252
+ nucleotides.length : -3);
253
+ }
254
+ //name: asoGapmersBioSpringToNucleotides
255
+ //input: string nucleotides {semType: BioSpring / Gapmers}
256
+ //output: string result {semType: DNA nucleotides}
257
+ function asoGapmersBioSpringToNucleotides(nucleotides) {
258
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
259
+ '*': '', '5': 'T', '6': 'A', '7': 'C', '8': 'G', '9': 'C' };
260
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|\*|5|6|7|8|9)/g, function (x) { return obj[x]; });
261
+ }
262
+ //name: asoGapmersBioSpringToGcrs
263
+ //input: string nucleotides {semType: BioSpring / Gapmers}
264
+ //output: string result {semType: GCRS / Gapmers}
265
+ function asoGapmersBioSpringToGcrs(nucleotides) {
266
+ let count = -1;
267
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
268
+ '5*': 'moeUnps', '6*': 'moeAnps', '7*': 'moe5mCnps', '8*': 'moeGnps', '9*': '5mCps', 'A*': 'Aps', 'T*': 'Tps',
269
+ 'G*': 'Gps', 'C*': 'Cps', '5': 'moeU', '6': 'moeA', '7': 'moe5mC', '8': 'moeG',
270
+ };
271
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|5\*|6\*|7\*|8\*|9\*|A\*|T\*|G\*|C\*|5|6|7|8)/g, function (x) {
272
+ count++;
273
+ return (count == 4) ? obj[x].slice(0, -3) + 'ps' : (count == 14) ? obj[x].slice(0, -2) + 'nps' : obj[x];
274
+ });
275
+ }
276
+ //name: asoGapmersGcrsToBioSpring
277
+ //input: string nucleotides {semType: GCRS / Gapmers}
278
+ //output: string result {semType: BioSpring / Gapmers}
279
+ function asoGapmersGcrsToBioSpring(nucleotides) {
280
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
281
+ 'moeT': '5', 'moeA': '6', 'moe5mC': '7', 'moeG': '8', 'moeU': '5', '5mC': '9', 'nps': '*', 'ps': '*', 'U': 'T',
282
+ };
283
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|moeT|moeA|moe5mC|moeG|moeU|5mC|nps|ps|U)/g, function (x) { return obj[x]; });
284
+ }
285
+ //name: asoGapmersGcrsToNucleotides
286
+ //input: string nucleotides {semType: GCRS / Gapmers}
287
+ //output: string result {semType: DNA nucleotides}
288
+ function asoGapmersGcrsToNucleotides(nucleotides) {
289
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
290
+ 'moe': '', '5m': '', 'n': '', 'ps': '', 'U': 'T' };
291
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|moe|5m|n|ps|U)/g, function (x) { return obj[x]; });
292
+ }
293
+ //name: siRnaBioSpringToNucleotides
294
+ //input: string nucleotides {semType: BioSpring / siRNA}
295
+ //output: string result {semType: RNA nucleotides}
296
+ function siRnaBioSpringToNucleotides(nucleotides) {
297
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
298
+ '1': 'U', '2': 'A', '3': 'C', '4': 'G', '5': 'U', '6': 'A', '7': 'C', '8': 'G', '*': '' };
299
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|1|2|3|4|5|6|7|8|\*)/g, function (x) { return obj[x]; });
300
+ }
301
+ //name: siRnaBioSpringToAxolabs
302
+ //input: string nucleotides {semType: BioSpring / siRNA}
303
+ //output: string result {semType: Axolabs / siRNA}
304
+ function siRnaBioSpringToAxolabs(nucleotides) {
305
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
306
+ '1': 'Uf', '2': 'Af', '3': 'Cf', '4': 'Gf', '5': 'u', '6': 'a', '7': 'c', '8': 'g', '*': 's' };
307
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|1|2|3|4|5|6|7|8|\*)/g, function (x) { return obj[x]; });
308
+ }
309
+ //name: siRnaBioSpringToGcrs
310
+ //input: string nucleotides {semType: BioSpring / siRNA}
311
+ //output: string result {semType: GCRS}
312
+ function siRnaBioSpringToGcrs(nucleotides) {
313
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
314
+ '1': 'fU', '2': 'fA', '3': 'fC', '4': 'fG', '5': 'mU', '6': 'mA', '7': 'mC', '8': 'mG', '*': 'ps' };
315
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|1|2|3|4|5|6|7|8|\*)/g, function (x) { return obj[x]; });
316
+ }
317
+ //name: siRnaAxolabsToGcrs
318
+ //input: string nucleotides {semType: Axolabs / siRNA}
319
+ //output: string result {semType: GCRS}
320
+ function siRnaAxolabsToGcrs(nucleotides) {
321
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
322
+ 'Uf': 'fU', 'Af': 'fA', 'Cf': 'fC', 'Gf': 'fG', 'u': 'mU', 'a': 'mA', 'c': 'mC', 'g': 'mG', 's': 'ps',
323
+ };
324
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });
325
+ }
326
+ //name: siRnaAxolabsToBioSpring
327
+ //input: string nucleotides {semType: Axolabs / siRNA}
328
+ //output: string result {semType: BioSpring / siRNA}
329
+ function siRnaAxolabsToBioSpring(nucleotides) {
330
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
331
+ 'Uf': '1', 'Af': '2', 'Cf': '3', 'Gf': '4', 'u': '5', 'a': '6', 'c': '7', 'g': '8', 's': '*',
332
+ };
333
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });
334
+ }
335
+ //name: siRnaAxolabsToNucleotides
336
+ //input: string nucleotides {semType: Axolabs / siRNA}
337
+ //output: string result {semType: RNA nucleotides}
338
+ function siRnaAxolabsToNucleotides(nucleotides) {
339
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
340
+ 'Uf': 'U', 'Af': 'A', 'Cf': 'C', 'Gf': 'G', 'u': 'U', 'a': 'A', 'c': 'C', 'g': 'G', 's': '',
341
+ };
342
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });
343
+ }
344
+ //name: siRnaGcrsToNucleotides
345
+ //input: string nucleotides {semType: GCRS}
346
+ //output: string result {semType: RNA nucleotides}
347
+ function siRnaGcrsToNucleotides(nucleotides) {
348
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
349
+ 'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G', 'ps': '',
350
+ };
351
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });
352
+ }
353
+ //name: siRnaGcrsToBioSpring
354
+ //input: string nucleotides {semType: GCRS}
355
+ //output: string result {semType: BioSpring / siRNA}
356
+ function siRnaGcrsToBioSpring(nucleotides) {
357
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
358
+ 'fU': '1', 'fA': '2', 'fC': '3', 'fG': '4', 'mU': '5', 'mA': '6', 'mC': '7', 'mG': '8', 'ps': '*',
359
+ };
360
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });
361
+ }
362
+ //name: siRnaGcrsToAxolabs
363
+ //input: string nucleotides {semType: GCRS}
364
+ //output: string result {semType: Axolabs / siRNA}
365
+ function siRnaGcrsToAxolabs(nucleotides) {
366
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
367
+ 'fU': 'Uf', 'fA': 'Af', 'fC': 'Cf', 'fG': 'Gf', 'mU': 'u', 'mA': 'a', 'mC': 'c', 'mG': 'g', 'ps': 's',
368
+ };
369
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });
370
+ }
371
+ //name: siRnaNucleotideToBioSpringSenseStrand
372
+ //input: string nucleotides {semType: RNA nucleotides}
373
+ //output: string result {semType: BioSpring / siRNA}
374
+ function siRnaNucleotideToBioSpringSenseStrand(nucleotides) {
375
+ let count = -1;
376
+ const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
377
+ 'A': '6*', 'U': '5*', 'G': '8*', 'C': '7*' };
378
+ const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
379
+ 'A': '*6', 'U': '*5', 'G': '*8', 'C': '*7' };
380
+ const objForOddIndices = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
381
+ 'A': '6', 'U': '5', 'G': '8', 'C': '7' };
382
+ const objForEvenIndices = { '(invabasic)': '(invabasic)',
383
+ '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': '2', 'U': '1', 'G': '4', 'C': '3' };
384
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|U|G|C)/g, function (x) {
385
+ count++;
386
+ if (count < 2)
387
+ return objForLeftEdge[x];
388
+ if (count > nucleotides.length - 3)
389
+ return objForRightEdge[x];
390
+ return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];
391
+ });
392
+ }
393
+ //name: siRnaNucleotidesToGcrs
394
+ //input: string nucleotides {semType: RNA nucleotides}
395
+ //output: string result {semType: GCRS}
396
+ function siRnaNucleotidesToGcrs(nucleotides) {
397
+ let count = -1;
398
+ const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
399
+ 'A': 'mAps', 'U': 'mUps', 'G': 'mGps', 'C': 'mCps' };
400
+ const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
401
+ 'A': 'psmA', 'U': 'psmU', 'G': 'psmG', 'C': 'psmC' };
402
+ const objForEvenIndices = { '(invabasic)': '(invabasic)',
403
+ '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'fA', 'U': 'fU', 'G': 'fG', 'C': 'fC' };
404
+ const objForOddIndices = { '(invabasic)': '(invabasic)',
405
+ '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'mA', 'U': 'mU', 'G': 'mG', 'C': 'mC' };
406
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|U|G|C)/g, function (x) {
407
+ count++;
408
+ if (count < 2)
409
+ return objForLeftEdge[x];
410
+ if (count > nucleotides.length - 3)
411
+ return objForRightEdge[x];
412
+ return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];
413
+ });
414
+ }
415
+ //name: siRnaNucleotideToAxolabsSenseStrand
416
+ //input: string nucleotides {semType: RNA nucleotides}
417
+ //output: string result {semType: Axolabs}
418
+ function siRnaNucleotideToAxolabsSenseStrand(nucleotides) {
419
+ let count = -1;
420
+ const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
421
+ 'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };
422
+ const objForSomeIndices = { '(invabasic)': '(invabasic)',
423
+ '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };
424
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
425
+ 'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };
426
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|U|G|C)/g, function (x) {
427
+ count++;
428
+ if (count < 2)
429
+ return objForLeftEdge[x];
430
+ if (count == 6 || (count > 7 && count < 11))
431
+ return objForSomeIndices[x];
432
+ if (count == nucleotides.length - 1)
433
+ return 'a';
434
+ return obj[x];
435
+ });
436
+ }
437
+ //name: siRnaNucleotideToAxolabsAntisenseStrand
438
+ //input: string nucleotides {semType: RNA nucleotides}
439
+ //output: string result {semType: Axolabs}
440
+ function siRnaNucleotideToAxolabsAntisenseStrand(nucleotides) {
441
+ let count = -1;
442
+ const objForSmallLinkages = { '(invabasic)': '(invabasic)',
443
+ '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };
444
+ const objForBigLinkages = { '(invabasic)': '(invabasic)',
445
+ '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Afs', 'U': 'Ufs', 'G': 'Gfs', 'C': 'Cfs' };
446
+ const objForSomeIndices = { '(invabasic)': '(invabasic)',
447
+ '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };
448
+ const obj = { '(invabasic)': '(invabasic)',
449
+ '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };
450
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|U|G|C)/g, function (x) {
451
+ count++;
452
+ if (count > 19 && count < 22)
453
+ return objForSmallLinkages[x];
454
+ if (count == 0)
455
+ return 'us';
456
+ if (count == 1)
457
+ return objForBigLinkages[x];
458
+ return (count == 5 || count == 7 || count == 8 || count == 13 || count == 15) ? objForSomeIndices[x] : obj[x];
459
+ });
460
+ }
461
+ //name: gcrsToNucleotides
462
+ //input: string nucleotides {semType: GCRS}
463
+ //output: string result {semType: RNA nucleotides}
464
+ function gcrsToNucleotides(nucleotides) {
465
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
466
+ 'mAps': 'A', 'mUps': 'U', 'mGps': 'G', 'mCps': 'C', 'fAps': 'A', 'fUps': 'U', 'fGps': 'G', 'fCps': 'C',
467
+ 'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G',
468
+ };
469
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });
470
+ }
471
+ //name: gcrsToMermade12
472
+ //input: string nucleotides {semType: GCRS}
473
+ //output: string result {semType: Mermade 12 / siRNA}
474
+ function gcrsToMermade12(nucleotides) {
475
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
476
+ 'mAps': 'e', 'mUps': 'h', 'mGps': 'g', 'mCps': 'f', 'fAps': 'i', 'fUps': 'l', 'fGps': 'k', 'fCps': 'j', 'fU': 'L',
477
+ 'fA': 'I', 'fC': 'J', 'fG': 'K', 'mU': 'H', 'mA': 'E', 'mC': 'F', 'mG': 'G',
478
+ };
479
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });
480
+ }
481
+
482
+
483
+ /***/ }),
484
+
485
+ /***/ "./src/structures-works/from-monomers.ts":
486
+ /*!***********************************************!*\
487
+ !*** ./src/structures-works/from-monomers.ts ***!
488
+ \***********************************************/
489
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
490
+
491
+ __webpack_require__.r(__webpack_exports__);
492
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
493
+ /* harmony export */ "sequenceToMolV3000": () => (/* binding */ sequenceToMolV3000),
494
+ /* harmony export */ "sequenceToSmiles": () => (/* binding */ sequenceToSmiles)
495
+ /* harmony export */ });
496
+ /* harmony import */ var _map__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./map */ "./src/structures-works/map.ts");
497
+ /* harmony import */ var _sequence_codes_tools__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./sequence-codes-tools */ "./src/structures-works/sequence-codes-tools.ts");
498
+ /* harmony import */ var _mol_transformations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./mol-transformations */ "./src/structures-works/mol-transformations.ts");
499
+
500
+
501
+
502
+ function sequenceToMolV3000(sequence, inverted = false, oclRender = false) {
503
+ const obj = getObjectWithCodesAndSmiles(sequence);
504
+ let codes = sortByStringLengthInDescendingOrder(Object.keys(obj));
505
+ let i = 0;
506
+ const smilesCodes = [];
507
+ const codesList = [];
508
+ const links = ['s', 'ps', '*'];
509
+ const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];
510
+ const dropdowns = Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS);
511
+ codes = codes.concat(dropdowns);
512
+ while (i < sequence.length) {
513
+ const code = codes.find((s) => s == sequence.slice(i, i + s.length));
514
+ i += code.length;
515
+ inverted ? codesList.unshift(code) : codesList.push(code);
516
+ }
517
+ for (let i = 0; i < codesList.length; i++) {
518
+ if (dropdowns.includes(codesList[i])) {
519
+ smilesCodes.push((i >= codesList.length / 2) ?
520
+ _map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS[codesList[i]].right : _map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS[codesList[i]].left);
521
+ smilesCodes.push(_map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles);
522
+ }
523
+ else {
524
+ if (links.includes(codesList[i]) ||
525
+ includesStandardLinkAlready.includes(codesList[i]) ||
526
+ (i < codesList.length - 1 && links.includes(codesList[i + 1])))
527
+ smilesCodes.push(obj[codesList[i]]);
528
+ else {
529
+ smilesCodes.push(obj[codesList[i]]);
530
+ smilesCodes.push(_map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles);
531
+ }
532
+ }
533
+ }
534
+ return (0,_mol_transformations__WEBPACK_IMPORTED_MODULE_2__.getNucleotidesMol)(smilesCodes, oclRender);
535
+ }
536
+ function sequenceToSmiles(sequence, inverted = false) {
537
+ const obj = getObjectWithCodesAndSmiles(sequence);
538
+ let codes = sortByStringLengthInDescendingOrder(Object.keys(obj));
539
+ let i = 0;
540
+ let smiles = '';
541
+ const codesList = [];
542
+ const links = ['s', 'ps', '*'];
543
+ const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];
544
+ const dropdowns = Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS);
545
+ codes = codes.concat(dropdowns);
546
+ while (i < sequence.length) {
547
+ const code = codes.find((s) => s == sequence.slice(i, i + s.length));
548
+ i += code.length;
549
+ inverted ? codesList.unshift(code) : codesList.push(code);
550
+ }
551
+ for (let i = 0; i < codesList.length; i++) {
552
+ if (dropdowns.includes(codesList[i])) {
553
+ smiles += (i >= codesList.length / 2) ?
554
+ _map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS[codesList[i]].right + _map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles :
555
+ _map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS[codesList[i]].left + _map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles;
556
+ }
557
+ else {
558
+ if (links.includes(codesList[i]) ||
559
+ includesStandardLinkAlready.includes(codesList[i]) ||
560
+ (i < codesList.length - 1 && links.includes(codesList[i + 1])))
561
+ smiles += obj[codesList[i]];
562
+ else
563
+ smiles += obj[codesList[i]] + _map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles;
564
+ }
565
+ }
566
+ smiles = smiles.replace(/OO/g, 'O');
567
+ return ((links.includes(codesList[codesList.length - 1]) &&
568
+ codesList.length > 1 &&
569
+ !includesStandardLinkAlready.includes(codesList[codesList.length - 2])) ||
570
+ dropdowns.includes(codesList[codesList.length - 1]) ||
571
+ includesStandardLinkAlready.includes(codesList[codesList.length - 1])) ?
572
+ smiles :
573
+ smiles.slice(0, smiles.length - _map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles.length + 1);
574
+ }
575
+ function getObjectWithCodesAndSmiles(sequence) {
576
+ const obj = {};
577
+ for (const synthesizer of Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map)) {
578
+ for (const technology of Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer])) {
579
+ for (const code of Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer][technology]))
580
+ obj[code] = _map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer][technology][code].SMILES;
581
+ }
582
+ }
583
+ // TODO: create object based from synthesizer type to avoid key(codes) duplicates
584
+ const output = (0,_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_1__.isValidSequence)(sequence);
585
+ if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.MERMADE_12)
586
+ obj['g'] = _map__WEBPACK_IMPORTED_MODULE_0__.map[_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.MERMADE_12][_map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.SI_RNA]['g'].SMILES;
587
+ else if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.AXOLABS)
588
+ obj['g'] = _map__WEBPACK_IMPORTED_MODULE_0__.map[_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.AXOLABS][_map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.SI_RNA]['g'].SMILES;
589
+ return obj;
590
+ }
591
+ function sortByStringLengthInDescendingOrder(array) {
592
+ return array.sort(function (a, b) { return b.length - a.length; });
593
+ }
594
+
595
+
596
+ /***/ }),
597
+
598
+ /***/ "./src/structures-works/map.ts":
599
+ /*!*************************************!*\
600
+ !*** ./src/structures-works/map.ts ***!
601
+ \*************************************/
602
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
603
+
604
+ __webpack_require__.r(__webpack_exports__);
605
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
606
+ /* harmony export */ "SYNTHESIZERS": () => (/* binding */ SYNTHESIZERS),
607
+ /* harmony export */ "TECHNOLOGIES": () => (/* binding */ TECHNOLOGIES),
608
+ /* harmony export */ "COL_NAMES": () => (/* binding */ COL_NAMES),
609
+ /* harmony export */ "MODIFICATIONS": () => (/* binding */ MODIFICATIONS),
610
+ /* harmony export */ "stadardPhosphateLinkSmiles": () => (/* binding */ stadardPhosphateLinkSmiles),
611
+ /* harmony export */ "map": () => (/* binding */ map)
612
+ /* harmony export */ });
613
+ const SYNTHESIZERS = {
614
+ RAW_NUCLEOTIDES: 'Raw Nucleotides',
615
+ BIOSPRING: 'BioSpring Codes',
616
+ GCRS: 'Janssen GCRS Codes',
617
+ AXOLABS: 'Axolabs Codes',
618
+ MERMADE_12: 'Mermade 12',
619
+ };
620
+ const TECHNOLOGIES = {
621
+ DNA: 'DNA',
622
+ RNA: 'RNA',
623
+ ASO_GAPMERS: 'For ASO Gapmers',
624
+ SI_RNA: 'For 2\'-OMe and 2\'-F modified siRNA',
625
+ };
626
+ const COL_NAMES = {
627
+ CHEMISTRY: 'Chemistry',
628
+ NUMBER: 'Number',
629
+ TYPE: 'Type',
630
+ CHEMISTRY_NAME: 'Chemistry Name',
631
+ INTERNAL_COMPOUND_ID: 'Internal compound ID',
632
+ IDP: 'IDP',
633
+ SEQUENCE: 'Sequence',
634
+ COMPOUND_NAME: 'Compound Name',
635
+ COMPOUND_COMMENTS: 'Compound Comments',
636
+ SALT: 'Salt',
637
+ EQUIVALENTS: 'Equivalents',
638
+ PURITY: 'Purity',
639
+ CPD_MW: 'Cpd MW',
640
+ SALT_MASS: 'Salt mass',
641
+ BATCH_MW: 'Batch MW',
642
+ SOURCE: 'Source',
643
+ ICD: 'ICD',
644
+ OWNER: 'Owner',
645
+ };
646
+ // interface CODES {
647
+ // }
648
+ const MODIFICATIONS = {
649
+ '(invabasic)': {
650
+ molecularWeight: 118.13,
651
+ left: 'O[C@@H]1C[C@@H]O[C@H]1CO',
652
+ right: 'O[C@@H]1C[C@@H]O[C@H]1CO',
653
+ },
654
+ '(GalNAc-2-JNJ)': {
655
+ molecularWeight: 1273.3,
656
+ left: 'C(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
657
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
658
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)NC(=O)CCCC(=O)NCC(O)CO',
659
+ right: 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
660
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
661
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)',
662
+ },
663
+ };
664
+ const stadardPhosphateLinkSmiles = 'OP(=O)(O)O';
665
+ const map = {
666
+ 'Raw Nucleotides': {
667
+ 'DNA': {
668
+ 'A': {
669
+ 'name': 'Adenine',
670
+ 'weight': 313.21,
671
+ 'normalized': 'dA',
672
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',
673
+ },
674
+ 'T': {
675
+ 'name': 'Tyrosine',
676
+ 'weight': 304.2,
677
+ 'normalized': 'dT',
678
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',
679
+ },
680
+ 'G': {
681
+ 'name': 'Guanine',
682
+ 'weight': 329.21,
683
+ 'normalized': 'dG',
684
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',
685
+ },
686
+ 'C': {
687
+ 'name': 'Cytosine',
688
+ 'weight': 289.18,
689
+ 'normalized': 'dC',
690
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',
691
+ },
692
+ },
693
+ 'RNA': {
694
+ 'A': {
695
+ 'name': 'Adenine',
696
+ 'weight': 313.21,
697
+ 'normalized': 'dA',
698
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',
699
+ },
700
+ 'U': {
701
+ 'name': 'Uracil',
702
+ 'weight': 306.17,
703
+ 'normalized': 'rU',
704
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',
705
+ },
706
+ 'G': {
707
+ 'name': 'Guanine',
708
+ 'weight': 329.21,
709
+ 'normalized': 'dG',
710
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',
711
+ },
712
+ 'C': {
713
+ 'name': 'Cytosine',
714
+ 'weight': 289.18,
715
+ 'normalized': 'dC',
716
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',
717
+ },
718
+ },
719
+ },
720
+ 'BioSpring Codes': {
721
+ 'For ASO Gapmers': {
722
+ '5': {
723
+ 'name': '2\'MOE-5Me-rU',
724
+ 'weight': 378.27,
725
+ 'normalized': 'rU',
726
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',
727
+ },
728
+ '6': {
729
+ 'name': '2\'MOE-rA',
730
+ 'weight': 387.29,
731
+ 'normalized': 'rA',
732
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',
733
+ },
734
+ '7': {
735
+ 'name': '2\'MOE-5Me-rC',
736
+ 'weight': 377.29,
737
+ 'normalized': 'rC',
738
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',
739
+ },
740
+ '8': {
741
+ 'name': '2\'MOE-rG',
742
+ 'weight': 403.28,
743
+ 'normalized': 'rG',
744
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',
745
+ },
746
+ '9': {
747
+ 'name': '5-Methyl-dC',
748
+ 'weight': 303.21,
749
+ 'normalized': 'dC',
750
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',
751
+ },
752
+ '*': {
753
+ 'name': 'ps linkage',
754
+ 'weight': 16.07,
755
+ 'normalized': '',
756
+ 'SMILES': 'OP(=O)(S)O',
757
+ },
758
+ 'A': {
759
+ 'name': 'Adenine',
760
+ 'weight': 313.21,
761
+ 'normalized': 'dA',
762
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',
763
+ },
764
+ 'C': {
765
+ 'name': 'Cytosine',
766
+ 'weight': 289.18,
767
+ 'normalized': 'dC',
768
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',
769
+ },
770
+ 'G': {
771
+ 'name': 'Guanine',
772
+ 'weight': 329.21,
773
+ 'normalized': 'dG',
774
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',
775
+ },
776
+ 'T': {
777
+ 'name': 'Tyrosine',
778
+ 'weight': 304.2,
779
+ 'normalized': 'dT',
780
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',
781
+ },
782
+ },
783
+ 'For 2\'-OMe and 2\'-F modified siRNA': {
784
+ '1': {
785
+ 'name': '2\'-fluoro-U',
786
+ 'weight': 308.16,
787
+ 'normalized': 'rU',
788
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',
789
+ },
790
+ '2': {
791
+ 'name': '2\'-fluoro-A',
792
+ 'weight': 331.2,
793
+ 'normalized': 'rA',
794
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',
795
+ },
796
+ '3': {
797
+ 'name': '2\'-fluoro-C',
798
+ 'weight': 307.18,
799
+ 'normalized': 'rC',
800
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',
801
+ },
802
+ '4': {
803
+ 'name': '2\'-fluoro-G',
804
+ 'weight': 347.19,
805
+ 'normalized': 'rG',
806
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',
807
+ },
808
+ '5': {
809
+ 'name': '2\'OMe-rU',
810
+ 'weight': 320.2,
811
+ 'normalized': 'rU',
812
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',
813
+ },
814
+ '6': {
815
+ 'name': '2\'OMe-rA',
816
+ 'weight': 343.24,
817
+ 'normalized': 'rA',
818
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',
819
+ },
820
+ '7': {
821
+ 'name': '2\'OMe-rC',
822
+ 'weight': 319.21,
823
+ 'normalized': 'rC',
824
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',
825
+ },
826
+ '8': {
827
+ 'name': '2\'OMe-rG',
828
+ 'weight': 359.24,
829
+ 'normalized': 'rG',
830
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',
831
+ },
832
+ '*': {
833
+ 'name': 'ps linkage',
834
+ 'weight': 16.07,
835
+ 'normalized': '',
836
+ 'SMILES': 'OP(=O)(S)O',
837
+ },
838
+ },
839
+ },
840
+ 'Axolabs Codes': {
841
+ 'For 2\'-OMe and 2\'-F modified siRNA': {
842
+ 'Uf': {
843
+ 'name': '2\'-fluoro-U',
844
+ 'weight': 308.16,
845
+ 'normalized': 'rU',
846
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',
847
+ },
848
+ 'Af': {
849
+ 'name': '2\'-fluoro-A',
850
+ 'weight': 331.2,
851
+ 'normalized': 'rA',
852
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',
853
+ },
854
+ 'Cf': {
855
+ 'name': '2\'-fluoro-C',
856
+ 'weight': 307.18,
857
+ 'normalized': 'rC',
858
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',
859
+ },
860
+ 'Gf': {
861
+ 'name': '2\'-fluoro-G',
862
+ 'weight': 347.19,
863
+ 'normalized': 'rG',
864
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',
865
+ },
866
+ 'u': {
867
+ 'name': '2\'OMe-rU',
868
+ 'weight': 320.2,
869
+ 'normalized': 'rU',
870
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',
871
+ },
872
+ 'a': {
873
+ 'name': '2\'OMe-rA',
874
+ 'weight': 343.24,
875
+ 'normalized': 'rA',
876
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',
877
+ },
878
+ 'c': {
879
+ 'name': '2\'OMe-rC',
880
+ 'weight': 319.21,
881
+ 'normalized': 'rC',
882
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',
883
+ },
884
+ 'g': {
885
+ 'name': '2\'OMe-rG',
886
+ 'weight': 359.,
887
+ 'normalized': 'rG',
888
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',
889
+ },
890
+ 's': {
891
+ 'name': 'ps linkage',
892
+ 'weight': 16.07,
893
+ 'normalized': '',
894
+ 'SMILES': 'OP(=O)(S)O',
895
+ },
896
+ },
897
+ },
898
+ 'Janssen GCRS Codes': {
899
+ 'For ASO Gapmers': {
900
+ 'moeT': {
901
+ 'name': '2\'MOE-5Me-rU',
902
+ 'weight': 378.27,
903
+ 'normalized': 'rU',
904
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',
905
+ },
906
+ 'moeA': {
907
+ 'name': '2\'MOE-rA',
908
+ 'weight': 387.29,
909
+ 'normalized': 'rA',
910
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',
911
+ },
912
+ 'moe5mC': {
913
+ 'name': '2\'MOE-5Me-rC',
914
+ 'weight': 377.29,
915
+ 'normalized': 'rC',
916
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',
917
+ },
918
+ '(5m)moeC': {
919
+ 'name': '2\'MOE-5Me-rC',
920
+ 'weight': 377.29,
921
+ 'normalized': 'rC',
922
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',
923
+ },
924
+ 'moeG': {
925
+ 'name': '2\'MOE-rG',
926
+ 'weight': 403.28,
927
+ 'normalized': 'rG',
928
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',
929
+ },
930
+ '5mC': {
931
+ 'name': '5-Methyl-dC',
932
+ 'weight': 303.28,
933
+ 'normalized': 'dC',
934
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',
935
+ },
936
+ '(5m)C': {
937
+ 'name': '5-Methyl-dC',
938
+ 'weight': 303.28,
939
+ 'normalized': 'dC',
940
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',
941
+ },
942
+ 'ps': {
943
+ 'name': 'ps linkage',
944
+ 'weight': 16.07,
945
+ 'normalized': '',
946
+ 'SMILES': 'OP(=O)(S)O',
947
+ },
948
+ 'A': {
949
+ 'name': 'Adenine',
950
+ 'weight': 313.21,
951
+ 'normalized': 'dA',
952
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',
953
+ },
954
+ 'dA': {
955
+ 'name': 'Adenine',
956
+ 'weight': 313.21,
957
+ 'normalized': 'dA',
958
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',
959
+ },
960
+ 'C': {
961
+ 'name': 'Cytosine',
962
+ 'weight': 289.18,
963
+ 'normalized': 'dC',
964
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',
965
+ },
966
+ 'dC': {
967
+ 'name': 'Cytosine',
968
+ 'weight': 289.18,
969
+ 'normalized': 'dC',
970
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',
971
+ },
972
+ 'G': {
973
+ 'name': 'Guanine',
974
+ 'weight': 329.21,
975
+ 'normalized': 'dG',
976
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',
977
+ },
978
+ 'dG': {
979
+ 'name': 'Guanine',
980
+ 'weight': 329.21,
981
+ 'normalized': 'dG',
982
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',
983
+ },
984
+ 'T': {
985
+ 'name': 'Tyrosine',
986
+ 'weight': 304.2,
987
+ 'normalized': 'dT',
988
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',
989
+ },
990
+ 'dT': {
991
+ 'name': 'Tyrosine',
992
+ 'weight': 304.2,
993
+ 'normalized': 'dT',
994
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',
995
+ },
996
+ 'rA': {
997
+ 'name': 'Adenine',
998
+ 'weight': 329.21,
999
+ 'normalized': 'rA',
1000
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](O)[C@@H]1O',
1001
+ },
1002
+ 'rC': {
1003
+ 'name': 'Cytosine',
1004
+ 'weight': 305.18,
1005
+ 'normalized': 'rC',
1006
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](O)[C@@H]1O',
1007
+ },
1008
+ 'rG': {
1009
+ 'name': 'Guanine',
1010
+ 'weight': 345.21,
1011
+ 'normalized': 'rG',
1012
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](O)[C@@H]1O',
1013
+ },
1014
+ 'rU': {
1015
+ 'name': 'Uracil',
1016
+ 'weight': 306.17,
1017
+ 'normalized': 'rU',
1018
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',
1019
+ },
1020
+ },
1021
+ 'For 2\'-OMe and 2\'-F modified siRNA': {
1022
+ 'fU': {
1023
+ 'name': '2\'-fluoro-U',
1024
+ 'weight': 308.16,
1025
+ 'normalized': 'rU',
1026
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',
1027
+ },
1028
+ 'fA': {
1029
+ 'name': '2\'-fluoro-A',
1030
+ 'weight': 331.2,
1031
+ 'normalized': 'rA',
1032
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',
1033
+ },
1034
+ 'fC': {
1035
+ 'name': '2\'-fluoro-C',
1036
+ 'weight': 307.18,
1037
+ 'normalized': 'rC',
1038
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',
1039
+ },
1040
+ 'fG': {
1041
+ 'name': '2\'-fluoro-G',
1042
+ 'weight': 347.19,
1043
+ 'normalized': 'rG',
1044
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',
1045
+ },
1046
+ 'mU': {
1047
+ 'name': '2\'OMe-rU',
1048
+ 'weight': 320.2,
1049
+ 'normalized': 'rU',
1050
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',
1051
+ },
1052
+ 'mA': {
1053
+ 'name': '2\'OMe-rA',
1054
+ 'weight': 343.24,
1055
+ 'normalized': 'rA',
1056
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',
1057
+ },
1058
+ 'mC': {
1059
+ 'name': '2\'OMe-rC',
1060
+ 'weight': 319.21,
1061
+ 'normalized': 'rC',
1062
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',
1063
+ },
1064
+ 'mG': {
1065
+ 'name': '2\'OMe-rG',
1066
+ 'weight': 359.24,
1067
+ 'normalized': 'rG',
1068
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',
1069
+ },
1070
+ },
1071
+ },
1072
+ 'Mermade 12': {
1073
+ 'For 2\'-OMe and 2\'-F modified siRNA': {
1074
+ 'e': {
1075
+ 'name': '2\'OMe-rA-ps',
1076
+ 'weight': 359.31,
1077
+ 'normalized': 'rA',
1078
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)O',
1079
+ },
1080
+ 'h': {
1081
+ 'name': '2\'OMe-rU-ps',
1082
+ 'weight': 336.27,
1083
+ 'normalized': 'rU',
1084
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)O',
1085
+ },
1086
+ 'g': {
1087
+ 'name': '2\'OMe-rG-ps',
1088
+ 'weight': 375.31,
1089
+ 'normalized': 'rG',
1090
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)O',
1091
+ },
1092
+ 'f': {
1093
+ 'name': '2\'OMe-rC-ps',
1094
+ 'weight': 335.28,
1095
+ 'normalized': 'rC',
1096
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)O',
1097
+ },
1098
+ 'i': {
1099
+ 'name': '2\'-fluoro-A-ps',
1100
+ 'weight': 347.27,
1101
+ 'normalized': 'rA',
1102
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)O',
1103
+ },
1104
+ 'l': {
1105
+ 'name': '2\'-fluoro-U-ps',
1106
+ 'weight': 324.23,
1107
+ 'normalized': 'rU',
1108
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)O',
1109
+ },
1110
+ 'k': {
1111
+ 'name': '2\'-fluoro-G-ps',
1112
+ 'weight': 363.26,
1113
+ 'normalized': 'rG',
1114
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)O',
1115
+ },
1116
+ 'j': {
1117
+ 'name': '2\'-fluoro-C-ps',
1118
+ 'weight': 323.25,
1119
+ 'normalized': 'rC',
1120
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)O',
1121
+ },
1122
+ 'L': {
1123
+ 'name': '2\'-fluoro-U',
1124
+ 'weight': 308.16,
1125
+ 'normalized': 'rU',
1126
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',
1127
+ },
1128
+ 'I': {
1129
+ 'name': '2\'-fluoro-A',
1130
+ 'weight': 331.2,
1131
+ 'normalized': 'rA',
1132
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',
1133
+ },
1134
+ 'J': {
1135
+ 'name': '2\'-fluoro-C',
1136
+ 'weight': 307.18,
1137
+ 'normalized': 'rC',
1138
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',
1139
+ },
1140
+ 'K': {
1141
+ 'name': '2\'-fluoro-G',
1142
+ 'weight': 347.19,
1143
+ 'normalized': 'rG',
1144
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',
1145
+ },
1146
+ 'H': {
1147
+ 'name': '2\'OMe-rU',
1148
+ 'weight': 320.2,
1149
+ 'normalized': 'rU',
1150
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',
1151
+ },
1152
+ 'E': {
1153
+ 'name': '2\'OMe-rA',
1154
+ 'weight': 343.24,
1155
+ 'normalized': 'rA',
1156
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',
1157
+ },
1158
+ 'F': {
1159
+ 'name': '2\'OMe-rC',
1160
+ 'weight': 319.21,
1161
+ 'normalized': 'rC',
1162
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',
1163
+ },
1164
+ 'G': {
1165
+ 'name': '2\'OMe-rG',
1166
+ 'weight': 359.24,
1167
+ 'normalized': 'rG',
1168
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',
1169
+ },
1170
+ },
1171
+ },
1172
+ };
1173
+
1174
+
1175
+ /***/ }),
1176
+
1177
+ /***/ "./src/structures-works/mol-transformations.ts":
1178
+ /*!*****************************************************!*\
1179
+ !*** ./src/structures-works/mol-transformations.ts ***!
1180
+ \*****************************************************/
1181
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1182
+
1183
+ __webpack_require__.r(__webpack_exports__);
1184
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
1185
+ /* harmony export */ "getNucleotidesMol": () => (/* binding */ getNucleotidesMol),
1186
+ /* harmony export */ "linkV3000": () => (/* binding */ linkV3000)
1187
+ /* harmony export */ });
1188
+ /* harmony import */ var openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! openchemlib/full.js */ "openchemlib/full.js");
1189
+ /* harmony import */ var openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__);
1190
+
1191
+ const PHOSHATE = `
1192
+ Datagrok monomer library Nucleotides
1193
+
1194
+ 0 0 0 0 0 0 0 V3000
1195
+ M V30 BEGIN CTAB
1196
+ M V30 COUNTS 5 4 0 0 0
1197
+ M V30 BEGIN ATOM
1198
+ M V30 1 O -1.5 0 0 0
1199
+ M V30 2 P 0 0 0 0
1200
+ M V30 3 O 0 1 0 0
1201
+ M V30 4 O 0 -1 0 0
1202
+ M V30 5 O 1.5 0 0 0
1203
+ M V30 END ATOM
1204
+ M V30 BEGIN BOND
1205
+ M V30 1 1 1 2
1206
+ M V30 2 2 2 3
1207
+ M V30 3 1 2 4
1208
+ M V30 4 1 2 5
1209
+ M V30 END BOND
1210
+ M V30 END CTAB
1211
+ M V30 BEGIN COLLECTION
1212
+ M V30 END COLLECTION
1213
+ M END`;
1214
+ const THIOPHOSHATE = `
1215
+ Datagrok monomer library Nucleotides
1216
+
1217
+ 0 0 0 0 0 0 0 V3000
1218
+ M V30 BEGIN CTAB
1219
+ M V30 COUNTS 5 4 0 0 0
1220
+ M V30 BEGIN ATOM
1221
+ M V30 1 O -1.5 0 0 0
1222
+ M V30 2 P 0 0 0 0
1223
+ M V30 3 O 0 1 0 0
1224
+ M V30 4 S 0 -1 0 0
1225
+ M V30 5 O 1.5 0 0 0
1226
+ M V30 END ATOM
1227
+ M V30 BEGIN BOND
1228
+ M V30 1 1 1 2
1229
+ M V30 2 2 2 3
1230
+ M V30 3 1 2 4
1231
+ M V30 4 1 2 5
1232
+ M V30 END BOND
1233
+ M V30 END CTAB
1234
+ M V30 BEGIN COLLECTION
1235
+ M V30 END COLLECTION
1236
+ M END`;
1237
+ const INVABASIC = `
1238
+ Datagrok monomer library Nucleotides
1239
+
1240
+ 0 0 0 0 0 0 0 V3000
1241
+ M V30 BEGIN CTAB
1242
+ M V30 COUNTS 8 8 0 0 0
1243
+ M V30 BEGIN ATOM
1244
+ M V30 1 O 1.0934 -2.1636 0 0
1245
+ M V30 2 C 1.8365 -1.4945 0 0 CFG=2
1246
+ M V30 3 C 2.8147 -1.7024 0 0
1247
+ M V30 4 C 3.3147 -0.8364 0 0 VAL=3
1248
+ M V30 5 O 2.6455 -0.0932 0 0
1249
+ M V30 6 C 1.732 -0.5 0 0 CFG=1
1250
+ M V30 7 C 0.866 0 0 0
1251
+ M V30 8 O 0.866 1 0 0
1252
+ M V30 END ATOM
1253
+ M V30 BEGIN BOND
1254
+ M V30 1 1 2 1 CFG=1
1255
+ M V30 2 1 2 3
1256
+ M V30 3 1 3 4
1257
+ M V30 4 1 4 5
1258
+ M V30 5 1 6 5
1259
+ M V30 6 1 2 6
1260
+ M V30 7 1 6 7 CFG=3
1261
+ M V30 8 1 7 8
1262
+ M V30 END BOND
1263
+ M V30 BEGIN COLLECTION
1264
+ M V30 MDLV30/STEABS ATOMS=(2 2 6)
1265
+ M V30 END COLLECTION
1266
+ M V30 END CTAB
1267
+ M END`;
1268
+ function getNucleotidesMol(smilesCodes, oclRender = false) {
1269
+ const molBlocks = [];
1270
+ for (let i = 0; i < smilesCodes.length - 1; i++) {
1271
+ smilesCodes[i] == 'OP(=O)(O)O' ? molBlocks.push(PHOSHATE) :
1272
+ smilesCodes[i] == 'OP(=O)(S)O' ? molBlocks.push(THIOPHOSHATE) :
1273
+ smilesCodes[i] == 'O[C@@H]1C[C@@H]O[C@H]1CO' ? molBlocks.push(rotateNucleotidesV3000(INVABASIC)) :
1274
+ molBlocks.push(rotateNucleotidesV3000(smilesCodes[i]));
1275
+ }
1276
+ return linkV3000(molBlocks, false, oclRender);
1277
+ }
1278
+ function linkV3000(molBlocks, twoMolecules = false, oclRender = false) {
1279
+ let macroMolBlock = '\nDatagrok macromolecule handler\n\n';
1280
+ macroMolBlock += ' 0 0 0 0 0 0 999 V3000\n';
1281
+ macroMolBlock += 'M V30 BEGIN CTAB\n';
1282
+ let atomBlock = '';
1283
+ let bondBlock = '';
1284
+ let collectionBlock = '';
1285
+ const collection = [];
1286
+ let natom = 0;
1287
+ let nbond = 0;
1288
+ let sequenceShift = 0;
1289
+ let xShift = 0;
1290
+ if (twoMolecules && molBlocks.length > 1)
1291
+ molBlocks[1] = invertNucleotidesV3000(molBlocks[1]);
1292
+ for (let i = 0; i < molBlocks.length; i++) {
1293
+ molBlocks[i] = molBlocks[i].replaceAll('(-\nM V30 ', '(')
1294
+ .replaceAll('-\nM V30 ', '').replaceAll(' )', ')');
1295
+ const numbers = extractAtomsBondsNumbersV3000(molBlocks[i]);
1296
+ const coordinates = extractAtomDataV3000(molBlocks[i]);
1297
+ let indexAtoms = molBlocks[i].indexOf('M V30 BEGIN ATOM'); // V3000 index for atoms coordinates
1298
+ indexAtoms = molBlocks[i].indexOf('\n', indexAtoms);
1299
+ let index = indexAtoms;
1300
+ let indexEnd = indexAtoms;
1301
+ for (let j = 0; j < numbers.natom; j++) {
1302
+ if (coordinates.atomIndex[j] != 1 || i == 0 || twoMolecules) {
1303
+ //rewrite atom number
1304
+ index = molBlocks[i].indexOf('V30', index) + 4;
1305
+ indexEnd = molBlocks[i].indexOf(' ', index);
1306
+ const atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;
1307
+ molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);
1308
+ //rewrite coordinates
1309
+ index = molBlocks[i].indexOf(' ', index) + 1;
1310
+ index = molBlocks[i].indexOf(' ', index) + 1;
1311
+ indexEnd = molBlocks[i].indexOf(' ', index);
1312
+ const totalShift = xShift - coordinates.x[0];
1313
+ let coordinate = Math.round(10000 * (parseFloat(molBlocks[i].substring(index, indexEnd)) + totalShift)) / 10000;
1314
+ molBlocks[i] = molBlocks[i].slice(0, index) + coordinate + molBlocks[i].slice(indexEnd);
1315
+ index = molBlocks[i].indexOf(' ', index) + 1;
1316
+ indexEnd = molBlocks[i].indexOf(' ', index);
1317
+ coordinate = Math.round(10000 * (parseFloat(molBlocks[i].substring(index, indexEnd)) + sequenceShift)) / 10000;
1318
+ molBlocks[i] = molBlocks[i].slice(0, index) + coordinate + molBlocks[i].slice(indexEnd);
1319
+ index = molBlocks[i].indexOf('\n', index) + 1;
1320
+ }
1321
+ else {
1322
+ index = molBlocks[i].indexOf('M V30', index) - 1;
1323
+ indexEnd = molBlocks[i].indexOf('\n', index + 1);
1324
+ molBlocks[i] = molBlocks[i].slice(0, index) + molBlocks[i].slice(indexEnd);
1325
+ }
1326
+ }
1327
+ const indexAtomsEnd = molBlocks[i].indexOf('M V30 END ATOM');
1328
+ atomBlock += molBlocks[i].substring(indexAtoms + 1, indexAtomsEnd);
1329
+ let indexBonds = molBlocks[i].indexOf('M V30 BEGIN BOND'); // V3000 index for bonds
1330
+ indexBonds = molBlocks[i].indexOf('\n', indexBonds);
1331
+ index = indexBonds;
1332
+ indexEnd = indexBonds;
1333
+ for (let j = 0; j < numbers.nbond; j++) {
1334
+ //rewrite bond number
1335
+ index = molBlocks[i].indexOf('V30', index) + 4;
1336
+ indexEnd = molBlocks[i].indexOf(' ', index);
1337
+ const bondNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + nbond;
1338
+ molBlocks[i] = molBlocks[i].slice(0, index) + bondNumber + molBlocks[i].slice(indexEnd);
1339
+ //rewrite atom pair in bond
1340
+ index = molBlocks[i].indexOf(' ', index) + 1;
1341
+ index = molBlocks[i].indexOf(' ', index) + 1;
1342
+ indexEnd = molBlocks[i].indexOf(' ', index);
1343
+ let atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;
1344
+ molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);
1345
+ index = molBlocks[i].indexOf(' ', index) + 1;
1346
+ indexEnd = Math.min(molBlocks[i].indexOf('\n', index), molBlocks[i].indexOf(' ', index));
1347
+ atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;
1348
+ molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);
1349
+ index = molBlocks[i].indexOf('\n', index) + 1;
1350
+ }
1351
+ const indexBondEnd = molBlocks[i].indexOf('M V30 END BOND');
1352
+ bondBlock += molBlocks[i].substring(indexBonds + 1, indexBondEnd);
1353
+ let indexCollection = molBlocks[i].indexOf('M V30 MDLV30/STEABS ATOMS=('); // V3000 index for collections
1354
+ while (indexCollection != -1) {
1355
+ indexCollection += 28;
1356
+ const collectionEnd = molBlocks[i].indexOf(')', indexCollection);
1357
+ const collectionEntries = molBlocks[i].substring(indexCollection, collectionEnd).split(' ').slice(1);
1358
+ collectionEntries.forEach((e) => {
1359
+ collection.push(parseInt(e) + natom);
1360
+ });
1361
+ indexCollection = collectionEnd;
1362
+ indexCollection = molBlocks[i].indexOf('M V30 MDLV30/STEABS ATOMS=(', indexCollection);
1363
+ }
1364
+ natom += twoMolecules ? numbers.natom : numbers.natom - 1;
1365
+ nbond += numbers.nbond;
1366
+ xShift += twoMolecules ? 0 : coordinates.x[numbers.natom - 1] - coordinates.x[0];
1367
+ sequenceShift += twoMolecules ? -7 : 0;
1368
+ }
1369
+ const entries = 4;
1370
+ const collNumber = Math.ceil(collection.length / entries);
1371
+ if (oclRender) {
1372
+ collectionBlock += 'M V30 MDLV30/STEABS ATOMS=(' + collection.length;
1373
+ for (let j = 0; j < collection.length; j++)
1374
+ collectionBlock += ' ' + collection[j];
1375
+ collectionBlock += ')\n';
1376
+ }
1377
+ else {
1378
+ collectionBlock += 'M V30 MDLV30/STEABS ATOMS=(' + collection.length + ' -\n';
1379
+ for (let i = 0; i < collNumber; i++) {
1380
+ collectionBlock += 'M V30 ';
1381
+ const entriesCurrent = i + 1 == collNumber ? collection.length - (collNumber - 1) * entries : entries;
1382
+ for (let j = 0; j < entriesCurrent; j++) {
1383
+ collectionBlock += (j + 1 == entriesCurrent) ?
1384
+ (i == collNumber - 1 ? collection[entries * i + j] + ')\n' : collection[entries * i + j] + ' -\n') :
1385
+ collection[entries * i + j] + ' ';
1386
+ }
1387
+ }
1388
+ }
1389
+ //generate file
1390
+ twoMolecules ? natom : natom++;
1391
+ macroMolBlock += 'M V30 COUNTS ' + natom + ' ' + nbond + ' 0 0 0\n';
1392
+ macroMolBlock += 'M V30 BEGIN ATOM\n';
1393
+ macroMolBlock += atomBlock;
1394
+ macroMolBlock += 'M V30 END ATOM\n';
1395
+ macroMolBlock += 'M V30 BEGIN BOND\n';
1396
+ macroMolBlock += bondBlock;
1397
+ macroMolBlock += 'M V30 END BOND\n';
1398
+ macroMolBlock += 'M V30 BEGIN COLLECTION\n';
1399
+ macroMolBlock += collectionBlock;
1400
+ macroMolBlock += 'M V30 END COLLECTION\n';
1401
+ macroMolBlock += 'M V30 END CTAB\n';
1402
+ macroMolBlock += 'M END\n';
1403
+ return macroMolBlock;
1404
+ }
1405
+ function rotateNucleotidesV3000(molecule) {
1406
+ let molBlock = molecule.includes('M END') ? molecule : openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__.Molecule.fromSmiles(molecule).toMolfileV3();
1407
+ const coordinates = extractAtomDataV3000(molBlock);
1408
+ const natom = coordinates.atomIndex.length;
1409
+ const indexFivePrime = coordinates.atomIndex.indexOf(1);
1410
+ const indexThreePrime = coordinates.atomIndex.indexOf(natom);
1411
+ //fix 5 prime if inadequate
1412
+ if (natom > 8)
1413
+ fix5Prime(coordinates, indexFivePrime, indexThreePrime);
1414
+ const xCenter = (coordinates.x[indexThreePrime] + coordinates.x[indexFivePrime]) / 2;
1415
+ const yCenter = (coordinates.y[indexThreePrime] + coordinates.y[indexFivePrime]) / 2;
1416
+ //place to center
1417
+ for (let i = 0; i < natom; i++) {
1418
+ coordinates.x[i] -= xCenter;
1419
+ coordinates.y[i] -= yCenter;
1420
+ }
1421
+ let angle = 0;
1422
+ if (coordinates.x[indexFivePrime] == 0)
1423
+ angle = coordinates.y[indexFivePrime] > coordinates.y[indexThreePrime] ? Math.PI / 2 : 3 * Math.PI / 2;
1424
+ else if (coordinates.y[indexFivePrime] == 0)
1425
+ angle = coordinates.x[indexFivePrime] > coordinates.x[indexThreePrime] ? Math.PI : 0;
1426
+ else {
1427
+ const derivative = coordinates.y[indexFivePrime] / coordinates.x[indexFivePrime];
1428
+ angle = derivative > 0 ? Math.PI - Math.atan(derivative) : Math.atan(derivative);
1429
+ }
1430
+ const cos = Math.cos(angle);
1431
+ const sin = Math.sin(angle);
1432
+ for (let i = 0; i < natom; i++) {
1433
+ const xAdd = coordinates.x[i];
1434
+ coordinates.x[i] = xAdd * cos - coordinates.y[i] * sin;
1435
+ coordinates.y[i] = xAdd * sin + coordinates.y[i] * cos;
1436
+ }
1437
+ //place to right
1438
+ const xShift = coordinates.x[indexFivePrime];
1439
+ for (let i = 0; i < natom; i++)
1440
+ coordinates.x[i] -= xShift;
1441
+ //rewrite molBlock
1442
+ let index = molBlock.indexOf('M V30 BEGIN ATOM'); // V3000 index for atoms coordinates
1443
+ index = molBlock.indexOf('\n', index);
1444
+ let indexEnd = index;
1445
+ for (let i = 0; i < natom; i++) {
1446
+ index = molBlock.indexOf('V30', index) + 4;
1447
+ index = molBlock.indexOf(' ', index) + 1;
1448
+ index = molBlock.indexOf(' ', index) + 1;
1449
+ indexEnd = molBlock.indexOf(' ', index) + 1;
1450
+ indexEnd = molBlock.indexOf(' ', indexEnd);
1451
+ molBlock = molBlock.slice(0, index) +
1452
+ coordinates.x[i] + ' ' + coordinates.y[i] +
1453
+ molBlock.slice(indexEnd);
1454
+ index = molBlock.indexOf('\n', index) + 1;
1455
+ }
1456
+ return molBlock;
1457
+ }
1458
+ function invertNucleotidesV3000(molecule) {
1459
+ let molBlock = molecule.includes('M END') ? molecule : openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__.Molecule.fromSmiles(molecule).toMolfileV3();
1460
+ const coordinates = extractAtomDataV3000(molBlock);
1461
+ const natom = coordinates.atomIndex.length;
1462
+ const xCenter = (Math.max(...coordinates.x) + Math.min(...coordinates.x)) / 2;
1463
+ const yCenter = (Math.max(...coordinates.y) + Math.min(...coordinates.y)) / 2;
1464
+ //place to center
1465
+ for (let i = 0; i < natom; i++) {
1466
+ coordinates.x[i] -= xCenter;
1467
+ coordinates.y[i] -= yCenter;
1468
+ }
1469
+ const angle = Math.PI;
1470
+ const cos = Math.cos(angle);
1471
+ const sin = Math.sin(angle);
1472
+ for (let i = 0; i < natom; i++) {
1473
+ const xAdd = coordinates.x[i];
1474
+ coordinates.x[i] = xAdd * cos - coordinates.y[i] * sin;
1475
+ coordinates.y[i] = xAdd * sin + coordinates.y[i] * cos;
1476
+ }
1477
+ //place back
1478
+ const yShift = Math.max(...coordinates.y);
1479
+ for (let i = 0; i < natom; i++) {
1480
+ coordinates.x[i] += xCenter;
1481
+ coordinates.y[i] -= yShift;
1482
+ }
1483
+ //rewrite molBlock
1484
+ let index = molBlock.indexOf('M V30 BEGIN ATOM'); // V3000 index for atoms coordinates
1485
+ index = molBlock.indexOf('\n', index);
1486
+ let indexEnd = index;
1487
+ for (let i = 0; i < natom; i++) {
1488
+ index = molBlock.indexOf('V30', index) + 4;
1489
+ index = molBlock.indexOf(' ', index) + 1;
1490
+ index = molBlock.indexOf(' ', index) + 1;
1491
+ indexEnd = molBlock.indexOf(' ', index) + 1;
1492
+ indexEnd = molBlock.indexOf(' ', indexEnd);
1493
+ molBlock = molBlock.slice(0, index) +
1494
+ coordinates.x[i] + ' ' + coordinates.y[i] +
1495
+ molBlock.slice(indexEnd);
1496
+ index = molBlock.indexOf('\n', index) + 1;
1497
+ }
1498
+ return molBlock;
1499
+ }
1500
+ function fix5Prime(coordinates, indexFivePrime, indexThreePrime) {
1501
+ const indexFivePrimeNeighbour = indexFivePrime + 1;
1502
+ const xShift = coordinates.x[indexFivePrimeNeighbour];
1503
+ const yShift = coordinates.y[indexFivePrimeNeighbour];
1504
+ const base3PrimeX = coordinates.x[indexThreePrime] - xShift;
1505
+ const base3PrimeY = coordinates.y[indexThreePrime] - yShift;
1506
+ const base5PrimeX = coordinates.x[indexFivePrime] - xShift;
1507
+ const base5PrimeY = coordinates.y[indexFivePrime] - yShift;
1508
+ const rotated5PrimeX = base5PrimeX * Math.cos(Math.PI * 2 / 3) - base5PrimeY * Math.sin(Math.PI * 2 / 3);
1509
+ const rotated5PrimeY = base5PrimeX * Math.sin(Math.PI * 2 / 3) + base5PrimeY * Math.cos(Math.PI * 2 / 3);
1510
+ const dx = base5PrimeX - base3PrimeX;
1511
+ const dy = base5PrimeY - base3PrimeY;
1512
+ const dxRotated = rotated5PrimeX - base3PrimeX;
1513
+ const dyRotated = rotated5PrimeY - base3PrimeY;
1514
+ if (Math.sqrt(dyRotated * dyRotated + dxRotated * dxRotated) >= Math.sqrt(dy * dy + dx * dx)) {
1515
+ coordinates.x[indexFivePrime] = rotated5PrimeX + xShift;
1516
+ coordinates.y[indexFivePrime] = rotated5PrimeY + yShift;
1517
+ }
1518
+ }
1519
+ function extractAtomsBondsNumbersV3000(molBlock) {
1520
+ molBlock = molBlock.replaceAll('\r', ''); //equalize old and new sdf standards
1521
+ let index = molBlock.indexOf('COUNTS') + 7; // V3000 index for atoms and bonds number
1522
+ let indexEnd = molBlock.indexOf(' ', index);
1523
+ const atomsNumber = parseInt(molBlock.substring(index, indexEnd));
1524
+ index = indexEnd + 1;
1525
+ indexEnd = molBlock.indexOf(' ', index);
1526
+ const bondsNumber = parseInt(molBlock.substring(index, indexEnd));
1527
+ return { natom: atomsNumber, nbond: bondsNumber };
1528
+ }
1529
+ function extractAtomDataV3000(molBlock) {
1530
+ const numbers = extractAtomsBondsNumbersV3000(molBlock);
1531
+ let index = molBlock.indexOf('M V30 BEGIN ATOM'); // V3000 index for atoms coordinates
1532
+ index = molBlock.indexOf('\n', index);
1533
+ let indexEnd = index;
1534
+ const indexes = Array(numbers.natom);
1535
+ const types = Array(numbers.natom);
1536
+ const x = Array(numbers.natom);
1537
+ const y = Array(numbers.natom);
1538
+ for (let i = 0; i < numbers.natom; i++) {
1539
+ index = molBlock.indexOf('V30', index) + 4;
1540
+ indexEnd = molBlock.indexOf(' ', index);
1541
+ indexes[i] = parseInt(molBlock.substring(index, indexEnd));
1542
+ index = indexEnd + 1;
1543
+ indexEnd = molBlock.indexOf(' ', index);
1544
+ types[i] = molBlock.substring(index, indexEnd);
1545
+ index = indexEnd + 1;
1546
+ indexEnd = molBlock.indexOf(' ', index);
1547
+ x[i] = parseFloat(molBlock.substring(index, indexEnd));
1548
+ index = indexEnd + 1;
1549
+ indexEnd = molBlock.indexOf(' ', index);
1550
+ y[i] = parseFloat(molBlock.substring(index, indexEnd));
1551
+ index = molBlock.indexOf('\n', index) + 1;
1552
+ }
1553
+ return { atomIndex: indexes, atomType: types, x: x, y: y };
1554
+ }
1555
+
1556
+
1557
+ /***/ }),
1558
+
1559
+ /***/ "./src/structures-works/sequence-codes-tools.ts":
1560
+ /*!******************************************************!*\
1561
+ !*** ./src/structures-works/sequence-codes-tools.ts ***!
1562
+ \******************************************************/
1563
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1564
+
1565
+ __webpack_require__.r(__webpack_exports__);
1566
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
1567
+ /* harmony export */ "undefinedInputSequence": () => (/* binding */ undefinedInputSequence),
1568
+ /* harmony export */ "isValidSequence": () => (/* binding */ isValidSequence),
1569
+ /* harmony export */ "convertSequence": () => (/* binding */ convertSequence)
1570
+ /* harmony export */ });
1571
+ /* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! datagrok-api/grok */ "datagrok-api/grok");
1572
+ /* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__);
1573
+ /* harmony import */ var datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! datagrok-api/ui */ "datagrok-api/ui");
1574
+ /* harmony import */ var datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__);
1575
+ /* harmony import */ var _map__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./map */ "./src/structures-works/map.ts");
1576
+ /* harmony import */ var _converters__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./converters */ "./src/structures-works/converters.ts");
1577
+
1578
+
1579
+ // import * as DG from 'datagrok-api/dg';
1580
+
1581
+
1582
+ const noTranslationTableAvailable = 'No translation table available';
1583
+ const undefinedInputSequence = 'Type of input sequence is undefined';
1584
+ function isValidSequence(sequence) {
1585
+ let possibleSynthesizers = getListOfPossibleSynthesizersByFirstMatchedCode(sequence);
1586
+ if (possibleSynthesizers.length > 1) {
1587
+ const synthesizer = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('Choose synthesizer from list: ', possibleSynthesizers[0], possibleSynthesizers);
1588
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.dialog('Choose Synthesizer')
1589
+ .add(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.panel([synthesizer.root], { style: { fontWeight: 'bold' } }))
1590
+ .onOK(() => possibleSynthesizers = [synthesizer.value])
1591
+ .onCancel(() => {
1592
+ possibleSynthesizers = [possibleSynthesizers[0]];
1593
+ datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.warning('Input sequence is expected to be in format ' + possibleSynthesizers[0]);
1594
+ })
1595
+ .show();
1596
+ }
1597
+ else if (possibleSynthesizers.length == 0)
1598
+ return { indexOfFirstNotValidChar: 0, synthesizer: null, technology: null };
1599
+ let outputIndex = 0;
1600
+ const firstUniqueCharacters = ['r', 'd'];
1601
+ const nucleotides = ['A', 'U', 'T', 'C', 'G'];
1602
+ possibleSynthesizers.forEach((synthesizer) => {
1603
+ const codes = getAllCodesOfSynthesizer(synthesizer);
1604
+ while (outputIndex < sequence.length) {
1605
+ const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));
1606
+ if (matchedCode == null)
1607
+ break;
1608
+ if ( // for mistake pattern 'rAA'
1609
+ outputIndex > 1 &&
1610
+ nucleotides.includes(sequence[outputIndex]) &&
1611
+ firstUniqueCharacters.includes(sequence[outputIndex - 2]))
1612
+ break;
1613
+ if ( // for mistake pattern 'ArA'
1614
+ firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&
1615
+ nucleotides.includes(sequence[outputIndex])) {
1616
+ outputIndex++;
1617
+ break;
1618
+ }
1619
+ outputIndex += matchedCode.length;
1620
+ }
1621
+ });
1622
+ const indexOfFirstNotValidChar = (outputIndex == sequence.length) ? -1 : outputIndex;
1623
+ if (indexOfFirstNotValidChar != -1) {
1624
+ return {
1625
+ indexOfFirstNotValidChar: indexOfFirstNotValidChar,
1626
+ synthesizer: possibleSynthesizers[0],
1627
+ technology: null,
1628
+ };
1629
+ }
1630
+ let possibleTechnologies = getListOfPossibleTechnologiesByFirstMatchedCode(sequence, possibleSynthesizers[0]);
1631
+ if (possibleTechnologies.length > 1) {
1632
+ const technology = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('Choose technology from list: ', possibleTechnologies[0], possibleTechnologies);
1633
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.dialog('Choose Technology')
1634
+ .add(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.panel([technology.root], { style: { fontWeight: 'bold' } }))
1635
+ .onOK(() => possibleTechnologies = [technology.value])
1636
+ .onCancel(() => {
1637
+ possibleTechnologies = [possibleTechnologies[0]];
1638
+ datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.warning('Input sequence is expected to be in format ' + possibleTechnologies[0]);
1639
+ })
1640
+ .show();
1641
+ }
1642
+ else if (possibleTechnologies.length == 0)
1643
+ return { indexOfFirstNotValidChar: 0, synthesizer: null, technology: null };
1644
+ outputIndex = 0;
1645
+ possibleTechnologies.forEach((technology) => {
1646
+ const codes = Object.keys(_map__WEBPACK_IMPORTED_MODULE_2__.map[possibleSynthesizers[0]][technology]);
1647
+ while (outputIndex < sequence.length) {
1648
+ const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));
1649
+ if (matchedCode == null)
1650
+ break;
1651
+ if ( // for mistake pattern 'rAA'
1652
+ outputIndex > 1 &&
1653
+ nucleotides.includes(sequence[outputIndex]) &&
1654
+ firstUniqueCharacters.includes(sequence[outputIndex - 2]))
1655
+ break;
1656
+ if ( // for mistake pattern 'ArA'
1657
+ firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&
1658
+ nucleotides.includes(sequence[outputIndex])) {
1659
+ outputIndex++;
1660
+ break;
1661
+ }
1662
+ outputIndex += matchedCode.length;
1663
+ }
1664
+ });
1665
+ return {
1666
+ indexOfFirstNotValidChar: indexOfFirstNotValidChar,
1667
+ synthesizer: possibleSynthesizers[0],
1668
+ technology: possibleTechnologies[outputIndex],
1669
+ };
1670
+ }
1671
+ function getAllCodesOfSynthesizer(synthesizer) {
1672
+ let codes = [];
1673
+ for (const technology of Object.keys(_map__WEBPACK_IMPORTED_MODULE_2__.map[synthesizer]))
1674
+ codes = codes.concat(Object.keys(_map__WEBPACK_IMPORTED_MODULE_2__.map[synthesizer][technology]));
1675
+ return codes.concat(Object.keys(_map__WEBPACK_IMPORTED_MODULE_2__.MODIFICATIONS));
1676
+ }
1677
+ function getListOfPossibleSynthesizersByFirstMatchedCode(sequence) {
1678
+ const synthesizers = [];
1679
+ Object.keys(_map__WEBPACK_IMPORTED_MODULE_2__.map).forEach((synthesizer) => {
1680
+ const codes = getAllCodesOfSynthesizer(synthesizer);
1681
+ //TODO: get first non-dropdown code when there are two modifications
1682
+ let start = 0;
1683
+ for (let i = 0; i < sequence.length; i++) {
1684
+ if (sequence[i] == ')' && i != sequence.length - 1) {
1685
+ start = i + 1;
1686
+ break;
1687
+ }
1688
+ }
1689
+ if (codes.some((s) => s == sequence.slice(start, start + s.length)))
1690
+ synthesizers.push(synthesizer);
1691
+ });
1692
+ return synthesizers;
1693
+ }
1694
+ function getListOfPossibleTechnologiesByFirstMatchedCode(sequence, synthesizer) {
1695
+ const technologies = [];
1696
+ Object.keys(_map__WEBPACK_IMPORTED_MODULE_2__.map[synthesizer]).forEach((technology) => {
1697
+ const codes = Object.keys(_map__WEBPACK_IMPORTED_MODULE_2__.map[synthesizer][technology]).concat(Object.keys(_map__WEBPACK_IMPORTED_MODULE_2__.MODIFICATIONS));
1698
+ if (codes.some((s) => s == sequence.slice(0, s.length)))
1699
+ technologies.push(technology);
1700
+ });
1701
+ return technologies;
1702
+ }
1703
+ function convertSequence(sequence, output) {
1704
+ if (output.indexOfFirstNotValidChar != -1) {
1705
+ return {
1706
+ // type: '',
1707
+ indexOfFirstNotValidChar: JSON.stringify(output),
1708
+ Error: undefinedInputSequence,
1709
+ };
1710
+ }
1711
+ if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.RAW_NUCLEOTIDES && output.technology == _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.DNA) {
1712
+ return {
1713
+ type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.RAW_NUCLEOTIDES + ' ' + _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.DNA,
1714
+ Nucleotides: sequence,
1715
+ BioSpring: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.asoGapmersNucleotidesToBioSpring)(sequence),
1716
+ GCRS: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.asoGapmersNucleotidesToGcrs)(sequence),
1717
+ };
1718
+ }
1719
+ if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.BIOSPRING && output.technology == _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.ASO_GAPMERS) {
1720
+ return {
1721
+ type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.BIOSPRING + ' ' + _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.ASO_GAPMERS,
1722
+ Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.asoGapmersBioSpringToNucleotides)(sequence),
1723
+ BioSpring: sequence,
1724
+ GCRS: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.asoGapmersBioSpringToGcrs)(sequence),
1725
+ };
1726
+ }
1727
+ if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.GCRS && output.technology == _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.ASO_GAPMERS) {
1728
+ return {
1729
+ type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.GCRS + ' ' + _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.ASO_GAPMERS,
1730
+ Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.asoGapmersGcrsToNucleotides)(sequence),
1731
+ BioSpring: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.asoGapmersGcrsToBioSpring)(sequence),
1732
+ Mermade12: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.gcrsToMermade12)(sequence),
1733
+ GCRS: sequence,
1734
+ };
1735
+ }
1736
+ if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.RAW_NUCLEOTIDES && output.technology == _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.RNA) {
1737
+ return {
1738
+ type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.RAW_NUCLEOTIDES + ' ' + _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.RNA,
1739
+ Nucleotides: sequence,
1740
+ BioSpring: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaNucleotideToBioSpringSenseStrand)(sequence),
1741
+ Axolabs: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaNucleotideToAxolabsSenseStrand)(sequence),
1742
+ GCRS: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaNucleotidesToGcrs)(sequence),
1743
+ };
1744
+ }
1745
+ if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.BIOSPRING && output.technology == _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.SI_RNA) {
1746
+ return {
1747
+ type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.BIOSPRING + ' ' + _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.SI_RNA,
1748
+ Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaBioSpringToNucleotides)(sequence),
1749
+ BioSpring: sequence,
1750
+ Axolabs: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaBioSpringToAxolabs)(sequence),
1751
+ GCRS: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaBioSpringToGcrs)(sequence),
1752
+ };
1753
+ }
1754
+ if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS && output.technology == _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.SI_RNA) {
1755
+ return {
1756
+ type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS + ' ' + _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.SI_RNA,
1757
+ Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaAxolabsToNucleotides)(sequence),
1758
+ BioSpring: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaAxolabsToBioSpring)(sequence),
1759
+ Axolabs: sequence,
1760
+ GCRS: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaAxolabsToGcrs)(sequence),
1761
+ };
1762
+ }
1763
+ if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.GCRS && output.technology == _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.SI_RNA) {
1764
+ return {
1765
+ type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.GCRS + ' ' + _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.SI_RNA,
1766
+ Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaGcrsToNucleotides)(sequence),
1767
+ BioSpring: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaGcrsToBioSpring)(sequence),
1768
+ Axolabs: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaGcrsToAxolabs)(sequence),
1769
+ MM12: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.gcrsToMermade12)(sequence),
1770
+ GCRS: sequence,
1771
+ };
1772
+ }
1773
+ if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.GCRS) {
1774
+ return {
1775
+ type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.GCRS,
1776
+ Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.gcrsToNucleotides)(sequence),
1777
+ GCRS: sequence,
1778
+ Mermade12: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.gcrsToMermade12)(sequence),
1779
+ };
1780
+ }
1781
+ if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.MERMADE_12) {
1782
+ return {
1783
+ type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.MERMADE_12,
1784
+ Nucleotides: noTranslationTableAvailable,
1785
+ GCRS: noTranslationTableAvailable,
1786
+ Mermade12: sequence,
1787
+ };
1788
+ }
1789
+ return {
1790
+ type: undefinedInputSequence,
1791
+ Nucleotides: undefinedInputSequence,
1792
+ };
1793
+ }
1794
+
1795
+
1796
+ /***/ }),
1797
+
1798
+ /***/ "./src/tests/smiles-tests.ts":
1799
+ /*!***********************************!*\
1800
+ !*** ./src/tests/smiles-tests.ts ***!
1801
+ \***********************************/
1802
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1803
+
1804
+ __webpack_require__.r(__webpack_exports__);
1805
+ /* harmony import */ var _datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @datagrok-libraries/utils/src/test */ "./node_modules/@datagrok-libraries/utils/src/test.js");
1806
+ /* harmony import */ var _structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../structures-works/from-monomers */ "./src/structures-works/from-monomers.ts");
1807
+ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
1808
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
1809
+ return new (P || (P = Promise))(function (resolve, reject) {
1810
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
1811
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
1812
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
1813
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
1814
+ });
1815
+ };
1816
+
1817
+
1818
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.category)('sequence-translator', () => {
1819
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('AGGTCCTCTTGACTTAGGCC', () => __awaiter(void 0, void 0, void 0, function* () {
1820
+ const expected = 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1OP(=O)(O)' +
1821
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1822
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1823
+ 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
1824
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +
1825
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +
1826
+ 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
1827
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +
1828
+ 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
1829
+ 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
1830
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1831
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1OP(=O)(O)' +
1832
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +
1833
+ 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
1834
+ 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
1835
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1OP(=O)(O)' +
1836
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1837
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1838
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O';
1839
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('AGGTCCTCTTGACTTAGGCC'), expected);
1840
+ }));
1841
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('invabasic/galnac1', () => __awaiter(void 0, void 0, void 0, function* () {
1842
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
1843
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1844
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1845
+ 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
1846
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
1847
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
1848
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
1849
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sgg(invabasic)(GalNAc-2-JNJ)'), expected);
1850
+ }));
1851
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('invabasic/galnac2', () => __awaiter(void 0, void 0, void 0, function* () {
1852
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
1853
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
1854
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1855
+ 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
1856
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
1857
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
1858
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
1859
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sgsg(invabasic)(GalNAc-2-JNJ)'), expected);
1860
+ }));
1861
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('invabasic/galnac3', () => __awaiter(void 0, void 0, void 0, function* () {
1862
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
1863
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1864
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
1865
+ 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
1866
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
1867
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
1868
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
1869
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sggs(invabasic)(GalNAc-2-JNJ)'), expected);
1870
+ }));
1871
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('invabasic/galnac4', () => __awaiter(void 0, void 0, void 0, function* () {
1872
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
1873
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1874
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1875
+ 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
1876
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
1877
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
1878
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
1879
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sgg(invabasic)s(GalNAc-2-JNJ)'), expected);
1880
+ }));
1881
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('usCfCfUfGfAf', () => __awaiter(void 0, void 0, void 0, function* () {
1882
+ const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1883
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1884
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1885
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1886
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
1887
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O';
1888
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('usCfCfUfGfAf'), expected);
1889
+ }));
1890
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('usAfsusgsgsg', () => __awaiter(void 0, void 0, void 0, function* () {
1891
+ const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1892
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +
1893
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1894
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
1895
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
1896
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O';
1897
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('usAfsusgsgsg'), expected);
1898
+ }));
1899
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('UfUfUfsCfsuacg', () => __awaiter(void 0, void 0, void 0, function* () {
1900
+ const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1901
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1902
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +
1903
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +
1904
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1905
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1906
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1907
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O';
1908
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('UfUfUfsCfsuacg'), expected);
1909
+ }));
1910
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('susususauasu', () => __awaiter(void 0, void 0, void 0, function* () {
1911
+ const expected = 'OP(=O)(S)OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1912
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1913
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1914
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1915
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1916
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
1917
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O';
1918
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('susususauasu'), expected);
1919
+ }));
1920
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('CfGfCfsGfsCf', () => __awaiter(void 0, void 0, void 0, function* () {
1921
+ const expected = 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1922
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
1923
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +
1924
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +
1925
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O';
1926
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('CfGfCfsGfsCf'), expected);
1927
+ }));
1928
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('acacacsacsac', () => __awaiter(void 0, void 0, void 0, function* () {
1929
+ const expected = 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1930
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1931
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1932
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1933
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1934
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1935
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1936
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1937
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1938
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O';
1939
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('acacacsacsac'), expected);
1940
+ }));
1941
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('cccgggusug', () => __awaiter(void 0, void 0, void 0, function* () {
1942
+ const expected = 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1943
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1944
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1945
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1946
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1947
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1948
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1949
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1950
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O';
1951
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('cccgggusug'), expected);
1952
+ }));
1953
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('UfAfCfGfGfCfAfUf', () => __awaiter(void 0, void 0, void 0, function* () {
1954
+ const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1955
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
1956
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1957
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
1958
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
1959
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1960
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
1961
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O';
1962
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('UfAfCfGfGfCfAfUf'), expected);
1963
+ }));
1964
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)sucuCfuUf', () => __awaiter(void 0, void 0, void 0, function* () {
1965
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
1966
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1967
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1968
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1969
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1970
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1971
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O';
1972
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sucuCfuUf'), expected);
1973
+ }));
1974
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)sAfgcugUf', () => __awaiter(void 0, void 0, void 0, function* () {
1975
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
1976
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
1977
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1978
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1979
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1980
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1981
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O';
1982
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sAfgcugUf'), expected);
1983
+ }));
1984
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)cuCfuUfsc', () => __awaiter(void 0, void 0, void 0, function* () {
1985
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
1986
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1987
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1988
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1989
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1990
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +
1991
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O';
1992
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)cuCfuUfsc'), expected);
1993
+ }));
1994
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)scususu(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
1995
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
1996
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1997
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1998
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1999
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2000
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2001
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2002
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
2003
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)scususu(GalNAc-2-JNJ)'), expected);
2004
+ }));
2005
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)usAfsucuCfuUfAfgcugUfgCfacususu', () => __awaiter(void 0, void 0, void 0, function* () {
2006
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
2007
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2008
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +
2009
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2010
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2011
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2012
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2013
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2014
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2015
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2016
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2017
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2018
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2019
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2020
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2021
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2022
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2023
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2024
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2025
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2026
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2027
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O';
2028
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)usAfsucuCfuUfAfgcugUfgCfacususu'), expected);
2029
+ }));
2030
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)asacgGfuGfCfAfacucuauuca', () => __awaiter(void 0, void 0, void 0, function* () {
2031
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
2032
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
2033
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2034
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2035
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2036
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2037
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2038
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2039
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2040
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2041
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2042
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2043
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2044
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2045
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2046
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2047
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2048
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2049
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2050
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';
2051
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)asacgGfuGfCfAfacucuauuca'), expected);
2052
+ }));
2053
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)scsgguGfcAfAfCfucuauucuga', () => __awaiter(void 0, void 0, void 0, function* () {
2054
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2055
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2056
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2057
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2058
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2059
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2060
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2061
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2062
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2063
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2064
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2065
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2066
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2067
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2068
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2069
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2070
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2071
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2072
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2073
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';
2074
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)scsgguGfcAfAfCfucuauucuga'), expected);
2075
+ }));
2076
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)scsaacUfcUfAfUfucuggacuua', () => __awaiter(void 0, void 0, void 0, function* () {
2077
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2078
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2079
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2080
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2081
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2082
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2083
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2084
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2085
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2086
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2087
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2088
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2089
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2090
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2091
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2092
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2093
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2094
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2095
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2096
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';
2097
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)scsaacUfcUfAfUfucuggacuua'), expected);
2098
+ }));
2099
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)sasacuCfuAfUfUfcuggacuuua', () => __awaiter(void 0, void 0, void 0, function* () {
2100
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2101
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
2102
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2103
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2104
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2105
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2106
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2107
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2108
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2109
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2110
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2111
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2112
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2113
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2114
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2115
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2116
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2117
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2118
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2119
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';
2120
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sasacuCfuAfUfUfcuggacuuua'), expected);
2121
+ }));
2122
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)usAfscug(invabasic)(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
2123
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
2124
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2125
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +
2126
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2127
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2128
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2129
+ 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
2130
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2131
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2132
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
2133
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)usAfscug(invabasic)(GalNAc-2-JNJ)'), expected);
2134
+ }));
2135
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)sasuaaCfcUf(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
2136
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2137
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
2138
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2139
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2140
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2141
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2142
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2143
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2144
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2145
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2146
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
2147
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sasuaaCfcUf(GalNAc-2-JNJ)'), expected);
2148
+ }));
2149
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)sasuaaCfcUfCfUfuguaguuaua(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
2150
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2151
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
2152
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2153
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2154
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2155
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2156
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2157
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2158
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2159
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2160
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2161
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2162
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2163
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2164
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2165
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2166
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2167
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2168
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2169
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2170
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2171
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2172
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
2173
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sasuaaCfcUfCfUfuguaguuaua(GalNAc-2-JNJ)'), expected);
2174
+ }));
2175
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)scsaucacguUfGfCfagccgucuua(invabasic)(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
2176
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2177
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2178
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2179
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2180
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2181
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2182
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2183
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2184
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2185
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2186
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2187
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2188
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2189
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2190
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2191
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2192
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2193
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2194
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2195
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2196
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2197
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2198
+ 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
2199
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2200
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2201
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
2202
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)scsaucacguUfGfCfagccgucuua(invabasic)(GalNAc-2-JNJ)'), expected);
2203
+ }));
2204
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)susguuUfgCfCfUfacaucuacua(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
2205
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2206
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2207
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2208
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2209
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2210
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2211
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2212
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2213
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2214
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2215
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2216
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2217
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2218
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2219
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2220
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2221
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2222
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2223
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2224
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2225
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2226
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2227
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
2228
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)susguuUfgCfCfUfacaucuacua(GalNAc-2-JNJ)'), expected);
2229
+ }));
2230
+ });
2231
+
2232
+
2233
+ /***/ }),
2234
+
2235
+ /***/ "datagrok-api/dg":
2236
+ /*!*********************!*\
2237
+ !*** external "DG" ***!
2238
+ \*********************/
2239
+ /***/ ((module) => {
2240
+
2241
+ module.exports = DG;
2242
+
2243
+ /***/ }),
2244
+
2245
+ /***/ "openchemlib/full.js":
2246
+ /*!**********************!*\
2247
+ !*** external "OCL" ***!
2248
+ \**********************/
2249
+ /***/ ((module) => {
2250
+
2251
+ module.exports = OCL;
2252
+
2253
+ /***/ }),
2254
+
2255
+ /***/ "datagrok-api/grok":
2256
+ /*!***********************!*\
2257
+ !*** external "grok" ***!
2258
+ \***********************/
2259
+ /***/ ((module) => {
2260
+
2261
+ module.exports = grok;
2262
+
2263
+ /***/ }),
2264
+
2265
+ /***/ "datagrok-api/ui":
2266
+ /*!*********************!*\
2267
+ !*** external "ui" ***!
2268
+ \*********************/
2269
+ /***/ ((module) => {
2270
+
2271
+ module.exports = ui;
2272
+
2273
+ /***/ })
2274
+
2275
+ /******/ });
2276
+ /************************************************************************/
2277
+ /******/ // The module cache
2278
+ /******/ var __webpack_module_cache__ = {};
2279
+ /******/
2280
+ /******/ // The require function
2281
+ /******/ function __webpack_require__(moduleId) {
2282
+ /******/ // Check if module is in cache
2283
+ /******/ var cachedModule = __webpack_module_cache__[moduleId];
2284
+ /******/ if (cachedModule !== undefined) {
2285
+ /******/ return cachedModule.exports;
2286
+ /******/ }
2287
+ /******/ // Create a new module (and put it into the cache)
2288
+ /******/ var module = __webpack_module_cache__[moduleId] = {
2289
+ /******/ // no module.id needed
2290
+ /******/ // no module.loaded needed
2291
+ /******/ exports: {}
2292
+ /******/ };
2293
+ /******/
2294
+ /******/ // Execute the module function
2295
+ /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
2296
+ /******/
2297
+ /******/ // Return the exports of the module
2298
+ /******/ return module.exports;
2299
+ /******/ }
2300
+ /******/
2301
+ /************************************************************************/
2302
+ /******/ /* webpack/runtime/compat get default export */
2303
+ /******/ (() => {
2304
+ /******/ // getDefaultExport function for compatibility with non-harmony modules
2305
+ /******/ __webpack_require__.n = (module) => {
2306
+ /******/ var getter = module && module.__esModule ?
2307
+ /******/ () => (module['default']) :
2308
+ /******/ () => (module);
2309
+ /******/ __webpack_require__.d(getter, { a: getter });
2310
+ /******/ return getter;
2311
+ /******/ };
2312
+ /******/ })();
2313
+ /******/
2314
+ /******/ /* webpack/runtime/define property getters */
2315
+ /******/ (() => {
2316
+ /******/ // define getter functions for harmony exports
2317
+ /******/ __webpack_require__.d = (exports, definition) => {
2318
+ /******/ for(var key in definition) {
2319
+ /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
2320
+ /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
2321
+ /******/ }
2322
+ /******/ }
2323
+ /******/ };
2324
+ /******/ })();
2325
+ /******/
2326
+ /******/ /* webpack/runtime/hasOwnProperty shorthand */
2327
+ /******/ (() => {
2328
+ /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
2329
+ /******/ })();
2330
+ /******/
2331
+ /******/ /* webpack/runtime/make namespace object */
2332
+ /******/ (() => {
2333
+ /******/ // define __esModule on exports
2334
+ /******/ __webpack_require__.r = (exports) => {
2335
+ /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
2336
+ /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2337
+ /******/ }
2338
+ /******/ Object.defineProperty(exports, '__esModule', { value: true });
2339
+ /******/ };
2340
+ /******/ })();
2341
+ /******/
2342
+ /************************************************************************/
2343
+ var __webpack_exports__ = {};
2344
+ // This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk.
2345
+ (() => {
2346
+ /*!*****************************!*\
2347
+ !*** ./src/package-test.ts ***!
2348
+ \*****************************/
2349
+ __webpack_require__.r(__webpack_exports__);
2350
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2351
+ /* harmony export */ "_package": () => (/* binding */ _package),
2352
+ /* harmony export */ "tests": () => (/* reexport safe */ _datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_1__.tests),
2353
+ /* harmony export */ "test": () => (/* binding */ test)
2354
+ /* harmony export */ });
2355
+ /* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! datagrok-api/dg */ "datagrok-api/dg");
2356
+ /* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__);
2357
+ /* harmony import */ var _datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @datagrok-libraries/utils/src/test */ "./node_modules/@datagrok-libraries/utils/src/test.js");
2358
+ /* harmony import */ var _tests_smiles_tests__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./tests/smiles-tests */ "./src/tests/smiles-tests.ts");
2359
+ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
2360
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
2361
+ return new (P || (P = Promise))(function (resolve, reject) {
2362
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
2363
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
2364
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
2365
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
2366
+ });
2367
+ };
2368
+
2369
+
2370
+
2371
+ const _package = new datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__.Package();
2372
+
2373
+ //name: test
2374
+ //output: dataframe result
2375
+ function test() {
2376
+ return __awaiter(this, void 0, void 0, function* () {
2377
+ const data = yield (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_1__.runTests)();
2378
+ return datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__.DataFrame.fromObjects(data);
2379
+ });
2380
+ }
2381
+
2382
+ })();
2383
+
2384
+ sequencetranslator_test = __webpack_exports__;
2385
+ /******/ })()
2386
+ ;
2387
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"package-test.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AAC0C;AACnC;AACA;AACA;AACP;AACA;AACA;AACA,qBAAqB,+BAA+B;AACpD;AACA;AACA,CAAC,wBAAwB;AAClB;AACP;AACA;AACA;AACA;AACA,wEAAwE;AACxE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,8DAAoB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA,+DAA+D,8DAAoB,CAAC;AACpF;AACA,aAAa;AACb,SAAS;AACT;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,wBAAwB,cAAc;AACtC;AACA,gBAAgB,qEAA2B;AAC3C;AACA;AACA;AACA,KAAK;AACL;AACA;AACO;AACP;AACA,2BAA2B,SAAS,UAAU,OAAO;AACrD;AACO;AACP;AACA;AACA,0BAA0B,SAAS,QAAQ,QAAQ,eAAe,UAAU;AAC5E;AACA;AACO;AACP;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,cAAc;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,wEAAwE;AACpG;AACA,4BAA4B,yEAAyE;AACrG;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA,sBAAsB;AACtB;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA,KAAK;AACL;AACO;AACP;AACA;AACA,KAAK;AACL;AACA,2CAA2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACxJ3C;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA;AACA;AACA;AACA;AACA,2BAA2B;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,gGAAgG,gBAAgB;AAChH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,2HAA2H,gBAAgB;AAC3I;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,iGAAiG,gBAAgB;AACjH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,8BAA8B;AAC9B;AACA,+BAA+B;AAC/B;AACA,gCAAgC;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,8BAA8B;AAC9B;AACA,gCAAgC;AAChC;AACA,+BAA+B;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,gCAAgC;AAChC;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,kCAAkC;AAClC;AACA,gCAAgC;AAChC;AACA,gCAAgC;AAChC;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA;AACA,mJAAmJ,gBAAgB;AACnK;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA;AACA,mJAAmJ,gBAAgB;AACnK;;;;;;;;;;;;;;;;;;;ACxQmG;AAC1C;AACC;AACnD;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,+CAAa;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA,gBAAgB,+CAAa,uBAAuB,+CAAa;AACjE,6BAA6B,4DAA0B;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,4DAA0B;AAC3D;AACA;AACA;AACA,WAAW,uEAAiB;AAC5B;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,+CAAa;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA,gBAAgB,+CAAa,uBAAuB,4DAA0B;AAC9E,gBAAgB,+CAAa,sBAAsB,4DAA0B;AAC7E;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,4DAA0B;AACxE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,mEAAiC;AACzE;AACA;AACA;AACA,0CAA0C,qCAAG;AAC7C,6CAA6C,qCAAG;AAChD,2CAA2C,qCAAG;AAC9C,4BAA4B,qCAAG;AAC/B;AACA;AACA;AACA,mBAAmB,sEAAe;AAClC,8BAA8B,yDAAuB;AACrD,mBAAmB,qCAAG,CAAC,yDAAuB,EAAE,qDAAmB;AACnE,mCAAmC,sDAAoB;AACvD,mBAAmB,qCAAG,CAAC,sDAAoB,EAAE,qDAAmB;AAChE;AACA;AACA;AACA,wCAAwC,6BAA6B;AACrE;;;;;;;;;;;;;;;;;;;;AC9FO;AACP;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACO;AACA;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;;;;;;;;;;;;;;;;;;AC/iB2C;AAC3C;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,oBAAoB,4BAA4B;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA;AACA;AACA,oEAAoE;AACpE;AACA;AACA;AACA,wBAAwB,mBAAmB;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oEAAoE;AACpE;AACA;AACA;AACA,wBAAwB,mBAAmB;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oFAAoF;AACpF;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,uBAAuB;AAC/C;AACA;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA,4BAA4B,oBAAoB;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D,oEAAuB;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA,uDAAuD;AACvD;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D,oEAAuB;AACnF;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA,uDAAuD;AACvD;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C;AAC9C,gDAAgD;AAChD;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,uDAAuD;AACvD;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;;;;;;;;;;;;;;;;;;;;;;;AC5W0C;AACJ;AACtC;AACuE;AACye;AAChjB;AACO;AACA;AACP;AACA;AACA,4BAA4B,wDAAc;AAC1C,QAAQ,mDAAS;AACjB,iBAAiB,kDAAQ,uBAAuB,SAAS,sBAAsB;AAC/E;AACA;AACA;AACA,YAAY,4DAAkB;AAC9B,SAAS;AACT;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,wDAAc;AACzC,QAAQ,mDAAS;AACjB,iBAAiB,kDAAQ,sBAAsB,SAAS,sBAAsB;AAC9E;AACA;AACA;AACA,YAAY,4DAAkB;AAC9B,SAAS;AACT;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,kCAAkC,qCAAG;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC,qCAAG;AAC5C,yCAAyC,qCAAG;AAC5C,oCAAoC,+CAAa;AACjD;AACA;AACA;AACA,gBAAgB,qCAAG;AACnB;AACA;AACA;AACA,wBAAwB,qBAAqB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,gBAAgB,qCAAG;AACnB,kCAAkC,qCAAG,8CAA8C,+CAAa;AAChG;AACA;AACA,KAAK;AACL;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,8DAA4B,yBAAyB,kDAAgB;AACnG;AACA,kBAAkB,8DAA4B,SAAS,kDAAgB;AACvE;AACA,uBAAuB,6EAAgC;AACvD,kBAAkB,wEAA2B;AAC7C;AACA;AACA,8BAA8B,wDAAsB,yBAAyB,0DAAwB;AACrG;AACA,kBAAkB,wDAAsB,SAAS,0DAAwB;AACzE,yBAAyB,6EAAgC;AACzD;AACA,kBAAkB,sEAAyB;AAC3C;AACA;AACA,8BAA8B,mDAAiB,yBAAyB,0DAAwB;AAChG;AACA,kBAAkB,mDAAiB,SAAS,0DAAwB;AACpE,yBAAyB,wEAA2B;AACpD,uBAAuB,sEAAyB;AAChD,uBAAuB,4DAAe;AACtC;AACA;AACA;AACA,8BAA8B,8DAA4B,yBAAyB,kDAAgB;AACnG;AACA,kBAAkB,8DAA4B,SAAS,kDAAgB;AACvE;AACA,uBAAuB,kFAAqC;AAC5D,qBAAqB,gFAAmC;AACxD,kBAAkB,mEAAsB;AACxC;AACA;AACA,8BAA8B,wDAAsB,yBAAyB,qDAAmB;AAChG;AACA,kBAAkB,wDAAsB,SAAS,qDAAmB;AACpE,yBAAyB,wEAA2B;AACpD;AACA,qBAAqB,oEAAuB;AAC5C,kBAAkB,iEAAoB;AACtC;AACA;AACA,8BAA8B,sDAAoB,yBAAyB,qDAAmB;AAC9F;AACA,kBAAkB,sDAAoB,SAAS,qDAAmB;AAClE,yBAAyB,sEAAyB;AAClD,uBAAuB,oEAAuB;AAC9C;AACA,kBAAkB,+DAAkB;AACpC;AACA;AACA,8BAA8B,mDAAiB,yBAAyB,qDAAmB;AAC3F;AACA,kBAAkB,mDAAiB,SAAS,qDAAmB;AAC/D,yBAAyB,mEAAsB;AAC/C,uBAAuB,iEAAoB;AAC3C,qBAAqB,+DAAkB;AACvC,kBAAkB,4DAAe;AACjC;AACA;AACA;AACA,8BAA8B,mDAAiB;AAC/C;AACA,kBAAkB,mDAAiB;AACnC,yBAAyB,8DAAiB;AAC1C;AACA,uBAAuB,4DAAe;AACtC;AACA;AACA,8BAA8B,yDAAuB;AACrD;AACA,kBAAkB,yDAAuB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;ACxNA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AAC4E;AACP;AACrE,4EAAQ;AACR,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,CAAC;;;;;;;;;;;ACvaD;;;;;;;;;;ACAA;;;;;;;;;;ACAA;;;;;;;;;;ACAA;;;;;;UCAA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;WACA;WACA;WACA;WACA;WACA,iCAAiC,WAAW;WAC5C;WACA;;;;;WCPA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA;;;;;WCPA;;;;;WCAA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D;;;;;;;;;;;;;;;;;;;;ACNA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACsC;AAC+B;AACvC;AACvB,qBAAqB,oDAAU;AACrB;AACjB;AACA;AACO;AACP;AACA,2BAA2B,4EAAQ;AACnC,eAAe,kEAAwB;AACvC,KAAK;AACL","sources":["webpack://sequencetranslator/./node_modules/@datagrok-libraries/utils/src/test.js","webpack://sequencetranslator/./src/structures-works/converters.ts","webpack://sequencetranslator/./src/structures-works/from-monomers.ts","webpack://sequencetranslator/./src/structures-works/map.ts","webpack://sequencetranslator/./src/structures-works/mol-transformations.ts","webpack://sequencetranslator/./src/structures-works/sequence-codes-tools.ts","webpack://sequencetranslator/./src/tests/smiles-tests.ts","webpack://sequencetranslator/external var \"DG\"","webpack://sequencetranslator/external var \"OCL\"","webpack://sequencetranslator/external var \"grok\"","webpack://sequencetranslator/external var \"ui\"","webpack://sequencetranslator/webpack/bootstrap","webpack://sequencetranslator/webpack/runtime/compat get default export","webpack://sequencetranslator/webpack/runtime/define property getters","webpack://sequencetranslator/webpack/runtime/hasOwnProperty shorthand","webpack://sequencetranslator/webpack/runtime/make namespace object","webpack://sequencetranslator/./src/package-test.ts"],"sourcesContent":["var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as grok from \"datagrok-api/grok\";\nexport let tests = {};\nexport let currentCategory;\nexport var assure;\n(function (assure) {\n    function notNull(value, name) {\n        if (value == null)\n            throw `${name == null ? 'Value' : name} not defined`;\n    }\n    assure.notNull = notNull;\n})(assure || (assure = {}));\nexport class Test {\n    constructor(category, name, test, options) {\n        var _a, _b;\n        this.category = category;\n        this.name = name;\n        options !== null && options !== void 0 ? options : (options = {});\n        (_a = options.timeout) !== null && _a !== void 0 ? _a : (options.timeout = 30000);\n        (_b = options.unhandledExceptionTimeout) !== null && _b !== void 0 ? _b : (options.unhandledExceptionTimeout = 2000);\n        this.options = options;\n        this.test = () => __awaiter(this, void 0, void 0, function* () {\n            return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {\n                let result = '';\n                try {\n                    grok.shell.lastError = '';\n                    result = yield test();\n                }\n                catch (e) {\n                    reject(e);\n                }\n                if (!(yield assertNoError(options.unhandledExceptionTimeout)))\n                    reject(`Unhandled exception during test: ${grok.shell.lastError}`);\n                resolve(result);\n            }));\n        });\n    }\n}\nexport function test(name, test, options) {\n    if (tests[currentCategory] == undefined)\n        tests[currentCategory] = {};\n    if (tests[currentCategory].tests == undefined)\n        tests[currentCategory].tests = [];\n    tests[currentCategory].tests.push(new Test(currentCategory, name, test, options));\n}\n/** Awaits for a while checking the error status of the platform */\nexport function assertNoError(ms) {\n    return __awaiter(this, void 0, void 0, function* () {\n        for (let i = 0; i < ms / 500; ++i) {\n            yield delay(500);\n            if (grok.shell.lastError.length !== 0)\n                return false;\n        }\n        return true;\n    });\n}\n/** Tests two objects for equality, throws an exception if they are not equal. */\nexport function expect(actual, expected) {\n    if (actual !== expected)\n        throw `Expected \"${expected}\", got \"${actual}\"`;\n}\nexport function expectFloat(actual, expected, tolerance = 0.001) {\n    const areEqual = Math.abs(actual - expected) < 0.001;\n    if (!areEqual)\n        throw `Expected ${expected}, got ${actual} (tolerance = ${tolerance})`;\n}\n/** Defines a test suite. */\nexport function category(category, tests) {\n    currentCategory = category;\n    tests();\n}\n/** Defines a function to be executed before the tests in this category are executed. */\nexport function before(before) {\n    if (tests[currentCategory] == undefined)\n        tests[currentCategory] = {};\n    tests[currentCategory].before = before;\n}\n/** Defines a function to be executed after the tests in this category are executed. */\nexport function after(after) {\n    if (tests[currentCategory] == undefined)\n        tests[currentCategory] = {};\n    tests[currentCategory].after = after;\n}\nexport function runTests(options) {\n    var _a;\n    return __awaiter(this, void 0, void 0, function* () {\n        let results = [];\n        for (const [key, value] of Object.entries(tests)) {\n            if ((options === null || options === void 0 ? void 0 : options.category) != undefined) {\n                if (!key.toLowerCase().startsWith(options === null || options === void 0 ? void 0 : options.category.toLowerCase()))\n                    continue;\n            }\n            try {\n                if (value.before)\n                    yield value.before();\n            }\n            catch (x) {\n                value.beforeStatus = x.toString();\n            }\n            let t = (_a = value.tests) !== null && _a !== void 0 ? _a : [];\n            let res = [];\n            for (let i = 0; i < t.length; i++) {\n                res.push(yield execTest(t[i], options === null || options === void 0 ? void 0 : options.test));\n            }\n            let data = (yield Promise.all(res)).filter((d) => d.result != 'skipped');\n            try {\n                if (value.after)\n                    yield value.after();\n            }\n            catch (x) {\n                value.afterStatus = x.toString();\n            }\n            if (value.afterStatus)\n                data.push({ category: key, name: 'init', result: value.afterStatus, success: false });\n            if (value.beforeStatus)\n                data.push({ category: key, name: 'init', result: value.beforeStatus, success: false });\n            results.push(...data);\n        }\n        return results;\n    });\n}\nfunction execTest(t, predicate) {\n    var _a;\n    return __awaiter(this, void 0, void 0, function* () {\n        let r;\n        try {\n            if (predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase())))\n                r = { success: true, result: 'skipped' };\n            else\n                r = { success: true, result: (_a = yield t.test()) !== null && _a !== void 0 ? _a : 'OK' };\n        }\n        catch (x) {\n            r = { success: false, result: x.toString() };\n        }\n        r.category = t.category;\n        r.name = t.name;\n        return r;\n    });\n}\nexport function delay(ms) {\n    return __awaiter(this, void 0, void 0, function* () {\n        yield new Promise(r => setTimeout(r, ms));\n    });\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.js","sourceRoot":"","sources":["test.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,KAAK,IAAI,MAAM,mBAAmB,CAAC;AAE1C,MAAM,CAAC,IAAI,KAAK,GAA8I,EAAE,CAAC;AAEjK,MAAM,CAAC,IAAI,eAAuB,CAAC;AAEnC,MAAM,KAAW,MAAM,CAMtB;AAND,WAAiB,MAAM;IAErB,SAAgB,OAAO,CAAC,KAAU,EAAE,IAAa;QAC/C,IAAI,KAAK,IAAI,IAAI;YACf,MAAM,GAAG,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,cAAc,CAAC;IACzD,CAAC;IAHe,cAAO,UAGtB,CAAA;AACH,CAAC,EANgB,MAAM,KAAN,MAAM,QAMtB;AAOD,MAAM,OAAO,IAAI;IAMf,YAAY,QAAgB,EAAE,IAAY,EAAE,IAAwB,EAAE,OAAqB;;QACzF,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,OAAO,aAAP,OAAO,cAAP,OAAO,IAAP,OAAO,GAAK,EAAE,EAAC;QACf,MAAA,OAAO,CAAC,OAAO,oCAAf,OAAO,CAAC,OAAO,GAAK,KAAK,EAAC;QAC1B,MAAA,OAAO,CAAC,yBAAyB,oCAAjC,OAAO,CAAC,yBAAyB,GAAK,IAAI,EAAC;QAC3C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,IAAI,GAAG,GAAuB,EAAE;YACnC,OAAO,IAAI,OAAO,CAAC,CAAO,OAAO,EAAE,MAAM,EAAE,EAAE;gBAC3C,IAAI,MAAM,GAAG,EAAE,CAAC;gBAChB,IAAI;oBACF,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,EAAE,CAAC;oBAC1B,MAAM,GAAG,MAAM,IAAI,EAAE,CAAC;iBACvB;gBAAC,OAAO,CAAM,EAAE;oBACf,MAAM,CAAC,CAAC,CAAC,CAAC;iBACX;gBACD,IAAI,CAAC,CAAC,MAAM,aAAa,CAAC,OAAQ,CAAC,yBAA0B,CAAC,CAAC;oBAC7D,MAAM,CAAC,oCAAoC,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC,CAAC;gBACrE,OAAO,CAAC,MAAM,CAAC,CAAC;YAClB,CAAC,CAAA,CAAC,CAAC;QACL,CAAC,CAAA,CAAC;IACJ,CAAC;CACF;AAED,MAAM,UAAU,IAAI,CAAC,IAAY,EAAE,IAAwB,EAAE,OAAqB;IAChF,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,SAAS;QACrC,KAAK,CAAC,eAAe,CAAC,GAAG,EAAE,CAAC;IAC9B,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC,KAAK,IAAI,SAAS;QAC3C,KAAK,CAAC,eAAe,CAAC,CAAC,KAAK,GAAG,EAAE,CAAC;IACpC,KAAK,CAAC,eAAe,CAAC,CAAC,KAAM,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,eAAe,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;AACrF,CAAC;AAED,mEAAmE;AACnE,MAAM,UAAgB,aAAa,CAAC,EAAU;;QAC5C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,CAAC,EAAE;YACjC,MAAM,KAAK,CAAC,GAAG,CAAC,CAAC;YACjB,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC;gBACnC,OAAO,KAAK,CAAC;SAChB;QACD,OAAO,IAAI,CAAC;IACd,CAAC;CAAA;AAED,iFAAiF;AACjF,MAAM,UAAU,MAAM,CAAC,MAAW,EAAE,QAAa;IAC/C,IAAI,MAAM,KAAK,QAAQ;QACrB,MAAM,aAAa,QAAQ,WAAW,MAAM,GAAG,CAAC;AACpD,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,MAAc,EAAE,QAAgB,EAAE,SAAS,GAAG,KAAK;IAC7E,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,QAAQ,CAAC,GAAG,KAAK,CAAC;IACrD,IAAI,CAAC,QAAQ;QACX,MAAM,YAAY,QAAQ,SAAS,MAAM,iBAAiB,SAAS,GAAG,CAAC;AAC3E,CAAC;AAED,4BAA4B;AAC5B,MAAM,UAAU,QAAQ,CAAC,QAAgB,EAAE,KAAiB;IAC1D,eAAe,GAAG,QAAQ,CAAC;IAC3B,KAAK,EAAE,CAAC;AACV,CAAC;AAED,wFAAwF;AACxF,MAAM,UAAU,MAAM,CAAC,MAA2B;IAChD,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,SAAS;QACrC,KAAK,CAAC,eAAe,CAAC,GAAG,EAAE,CAAC;IAC9B,KAAK,CAAC,eAAe,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC;AACzC,CAAC;AAED,uFAAuF;AACvF,MAAM,UAAU,KAAK,CAAC,KAA0B;IAC9C,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,SAAS;QACrC,KAAK,CAAC,eAAe,CAAC,GAAG,EAAE,CAAC;IAC9B,KAAK,CAAC,eAAe,CAAC,CAAC,KAAK,GAAG,KAAK,CAAC;AACvC,CAAC;AAGD,MAAM,UAAgB,QAAQ,CAAC,OAA4C;;;QACzE,IAAI,OAAO,GAA4E,EAAE,CAAC;QAE1F,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YAChD,IAAI,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ,KAAI,SAAS,EAAE;gBAClC,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ,CAAC,WAAW,EAAE,CAAC;oBAChE,SAAS;aACZ;YACD,IAAI;gBACF,IAAI,KAAK,CAAC,MAAM;oBACd,MAAM,KAAK,CAAC,MAAM,EAAE,CAAC;aACxB;YAAC,OAAO,CAAM,EAAE;gBACf,KAAK,CAAC,YAAY,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;aACnC;YACD,IAAI,CAAC,GAAG,MAAA,KAAK,CAAC,KAAK,mCAAI,EAAE,CAAC;YAC1B,IAAI,GAAG,GAAG,EAAE,CAAC;YACb,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAChC,GAAG,CAAC,IAAI,CAAC,MAAM,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,IAAI,CAAC,CAAC,CAAC;aAC/C;YAED,IAAI,IAAI,GAAG,CAAC,MAAM,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,IAAI,SAAS,CAAC,CAAC;YACzE,IAAI;gBACF,IAAI,KAAK,CAAC,KAAK;oBACb,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;aACvB;YAAC,OAAO,CAAM,EAAE;gBACf,KAAK,CAAC,WAAW,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;aAClC;YACD,IAAI,KAAK,CAAC,WAAW;gBACnB,IAAI,CAAC,IAAI,CAAC,EAAC,QAAQ,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,WAAW,EAAE,OAAO,EAAE,KAAK,EAAC,CAAC,CAAC;YACtF,IAAI,KAAK,CAAC,YAAY;gBACpB,IAAI,CAAC,IAAI,CAAC,EAAC,QAAQ,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,YAAY,EAAE,OAAO,EAAE,KAAK,EAAC,CAAC,CAAC;YACvF,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;SACvB;QAED,OAAO,OAAO,CAAC;;CAChB;AAED,SAAe,QAAQ,CAAC,CAAO,EAAE,SAA6B;;;QAC5D,IAAI,CAAyE,CAAC;QAC9E,IAAI;YACF,IAAI,SAAS,IAAI,SAAS,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,CAAC;gBACvF,CAAC,GAAG,EAAC,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAC,CAAC;;gBAEvC,CAAC,GAAG,EAAC,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,MAAA,MAAM,CAAC,CAAC,IAAI,EAAE,mCAAI,IAAI,EAAC,CAAC;SACvD;QAAC,OAAO,CAAM,EAAE;YACf,CAAC,GAAG,EAAC,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE,EAAC,CAAC;SAC5C;QACD,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,QAAQ,CAAC;QACxB,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC;QAChB,OAAO,CAAC,CAAC;;CACV;AAED,MAAM,UAAgB,KAAK,CAAC,EAAU;;QACpC,MAAO,IAAI,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;IAC7C,CAAC;CAAA","sourcesContent":["import * as grok from \"datagrok-api/grok\";\n\nexport let tests: {[key: string]: {tests?: Test[], before?: () => Promise<void>, after?: () => Promise<void>, beforeStatus?: string, afterStatus?: string}} = {};\n\nexport let currentCategory: string;\n\nexport namespace assure {\n\n  export function notNull(value: any, name?: string) {\n    if (value == null)\n      throw `${name == null ? 'Value' : name} not defined`;\n  }\n}\n\nexport interface TestOptions {\n  timeout? : number;\n  unhandledExceptionTimeout? : number;\n}\n\nexport class Test {\n  test: () => Promise<any>;\n  name: string;\n  category: string;\n  options?: TestOptions;\n\n  constructor(category: string, name: string, test: () => Promise<any>, options?: TestOptions) {\n    this.category = category;\n    this.name = name;\n    options ??= {};\n    options.timeout ??= 30000;\n    options.unhandledExceptionTimeout ??= 2000;\n    this.options = options;\n    this.test = async (): Promise<any> => {\n      return new Promise(async (resolve, reject) => {\n        let result = '';\n        try {\n          grok.shell.lastError = '';\n          result = await test();\n        } catch (e: any) {\n          reject(e);\n        }\n        if (!(await assertNoError(options!.unhandledExceptionTimeout!)))\n          reject(`Unhandled exception during test: ${grok.shell.lastError}`);\n        resolve(result);\n      });\n    };\n  }\n}\n\nexport function test(name: string, test: () => Promise<any>, options?: TestOptions): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  if (tests[currentCategory].tests == undefined)\n    tests[currentCategory].tests = [];\n  tests[currentCategory].tests!.push(new Test(currentCategory, name, test, options));\n}\n\n/** Awaits for a while checking the error status of the platform */\nexport async function assertNoError(ms: number): Promise<boolean> {\n  for (let i = 0; i < ms / 500; ++i) {\n    await delay(500);\n    if (grok.shell.lastError.length !== 0)\n      return false;\n  }\n  return true;\n}\n\n/** Tests two objects for equality, throws an exception if they are not equal. */\nexport function expect(actual: any, expected: any): void {\n  if (actual !== expected)\n    throw `Expected \"${expected}\", got \"${actual}\"`;\n}\n\nexport function expectFloat(actual: number, expected: number, tolerance = 0.001): void {\n  const areEqual = Math.abs(actual - expected) < 0.001;\n  if (!areEqual)\n    throw `Expected ${expected}, got ${actual} (tolerance = ${tolerance})`;\n}\n\n/** Defines a test suite. */\nexport function category(category: string, tests: () => void): void {\n  currentCategory = category;\n  tests();\n}\n\n/** Defines a function to be executed before the tests in this category are executed. */\nexport function before(before: () => Promise<void>): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  tests[currentCategory].before = before;\n}\n\n/** Defines a function to be executed after the tests in this category are executed. */\nexport function after(after: () => Promise<void>): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  tests[currentCategory].after = after;\n}\n\n\nexport async function runTests(options?: {category?: string, test?: string}) {\n  let results: { category?: string, name?: string, success: boolean, result: string}[] = [];\n\n  for (const [key, value] of Object.entries(tests)) {\n    if (options?.category != undefined) {\n      if (!key.toLowerCase().startsWith(options?.category.toLowerCase()))\n        continue;\n    }\n    try {\n      if (value.before)\n        await value.before();\n    } catch (x: any) {\n      value.beforeStatus = x.toString();\n    }\n    let t = value.tests ?? [];\n    let res = [];\n    for(let i = 0; i < t.length; i++) {\n      res.push(await execTest(t[i], options?.test));\n    }\n\n    let data = (await Promise.all(res)).filter((d) => d.result != 'skipped');\n    try {\n      if (value.after)\n        await value.after();\n    } catch (x: any) {\n      value.afterStatus = x.toString();\n    }\n    if (value.afterStatus)\n      data.push({category: key, name: 'init', result: value.afterStatus, success: false});\n    if (value.beforeStatus)\n      data.push({category: key, name: 'init', result: value.beforeStatus, success: false});\n    results.push(...data);\n  }\n\n  return results;\n}\n\nasync function execTest(t: Test, predicate: string | undefined) {\n  let r: { category?: string, name?: string, success: boolean, result: string };\n  try {\n    if (predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase())))\n      r = {success: true, result: 'skipped'};\n    else\n      r = {success: true, result: await t.test() ?? 'OK'};\n  } catch (x: any) {\n    r = {success: false, result: x.toString()};\n  }\n  r.category = t.category;\n  r.name = t.name;\n  return r;\n}\n\nexport async function delay(ms: number) {\n  await  new Promise(r => setTimeout(r, ms));\n}\n"]}","//name: asoGapmersNucleotidesToBioSpring\n//input: string nucleotides {semType: DNA nucleotides}\n//output: string result {semType: BioSpring / Gapmers}\nexport function asoGapmersNucleotidesToBioSpring(nucleotides) {\n    let count = -1;\n    const objForEdges = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': '5*', 'A': '6*', 'C': '7*', 'G': '8*'\n    };\n    const objForCenter = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'T*', 'A': 'A*', 'C': '9*', 'G': 'G*'\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|T|C|G)/g, function (x) {\n        count++;\n        return (count > 4 && count < 15) ? objForCenter[x] : objForEdges[x];\n    }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?\n        nucleotides.length : 2 * count + 1);\n}\n//name: asoGapmersNucleotidesToGcrs\n//input: string nucleotides {semType: DNA nucleotides}\n//output: string result {semType: GCRS / Gapmers}\nexport function asoGapmersNucleotidesToGcrs(nucleotides) {\n    let count = -1;\n    const objForEdges = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'moeUnps',\n        'A': 'moeAnps', 'C': 'moe5mCnps', 'G': 'moeGnps'\n    };\n    const objForCenter = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'C': '5mCps', 'A': 'Aps', 'T': 'Tps', 'G': 'Gps' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|T|C|G)/g, function (x) {\n        count++;\n        if (count < 5)\n            return (count == 4) ? objForEdges[x].slice(0, -3) + 'ps' : objForEdges[x];\n        if (count < 15)\n            return (count == 14) ? objForCenter[x].slice(0, -2) + 'nps' : objForCenter[x];\n        return objForEdges[x];\n    }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?\n        nucleotides.length : -3);\n}\n//name: asoGapmersBioSpringToNucleotides\n//input: string nucleotides {semType: BioSpring / Gapmers}\n//output: string result {semType: DNA nucleotides}\nexport function asoGapmersBioSpringToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '*': '', '5': 'T', '6': 'A', '7': 'C', '8': 'G', '9': 'C' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|\\*|5|6|7|8|9)/g, function (x) { return obj[x]; });\n}\n//name: asoGapmersBioSpringToGcrs\n//input: string nucleotides {semType: BioSpring / Gapmers}\n//output: string result {semType: GCRS / Gapmers}\nexport function asoGapmersBioSpringToGcrs(nucleotides) {\n    let count = -1;\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '5*': 'moeUnps', '6*': 'moeAnps', '7*': 'moe5mCnps', '8*': 'moeGnps', '9*': '5mCps', 'A*': 'Aps', 'T*': 'Tps',\n        'G*': 'Gps', 'C*': 'Cps', '5': 'moeU', '6': 'moeA', '7': 'moe5mC', '8': 'moeG',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|5\\*|6\\*|7\\*|8\\*|9\\*|A\\*|T\\*|G\\*|C\\*|5|6|7|8)/g, function (x) {\n        count++;\n        return (count == 4) ? obj[x].slice(0, -3) + 'ps' : (count == 14) ? obj[x].slice(0, -2) + 'nps' : obj[x];\n    });\n}\n//name: asoGapmersGcrsToBioSpring\n//input: string nucleotides {semType: GCRS / Gapmers}\n//output: string result {semType: BioSpring / Gapmers}\nexport function asoGapmersGcrsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'moeT': '5', 'moeA': '6', 'moe5mC': '7', 'moeG': '8', 'moeU': '5', '5mC': '9', 'nps': '*', 'ps': '*', 'U': 'T',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|moeT|moeA|moe5mC|moeG|moeU|5mC|nps|ps|U)/g, function (x) { return obj[x]; });\n}\n//name: asoGapmersGcrsToNucleotides\n//input: string nucleotides {semType: GCRS / Gapmers}\n//output: string result {semType: DNA nucleotides}\nexport function asoGapmersGcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'moe': '', '5m': '', 'n': '', 'ps': '', 'U': 'T' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|moe|5m|n|ps|U)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToNucleotides\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaBioSpringToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'U', '2': 'A', '3': 'C', '4': 'G', '5': 'U', '6': 'A', '7': 'C', '8': 'G', '*': '' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToAxolabs\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: Axolabs / siRNA}\nexport function siRnaBioSpringToAxolabs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'Uf', '2': 'Af', '3': 'Cf', '4': 'Gf', '5': 'u', '6': 'a', '7': 'c', '8': 'g', '*': 's' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToGcrs\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: GCRS}\nexport function siRnaBioSpringToGcrs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'fU', '2': 'fA', '3': 'fC', '4': 'fG', '5': 'mU', '6': 'mA', '7': 'mC', '8': 'mG', '*': 'ps' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToGcrs\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: GCRS}\nexport function siRnaAxolabsToGcrs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': 'fU', 'Af': 'fA', 'Cf': 'fC', 'Gf': 'fG', 'u': 'mU', 'a': 'mA', 'c': 'mC', 'g': 'mG', 's': 'ps',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToBioSpring\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaAxolabsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': '1', 'Af': '2', 'Cf': '3', 'Gf': '4', 'u': '5', 'a': '6', 'c': '7', 'g': '8', 's': '*',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToNucleotides\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaAxolabsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': 'U', 'Af': 'A', 'Cf': 'C', 'Gf': 'G', 'u': 'U', 'a': 'A', 'c': 'C', 'g': 'G', 's': '',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToNucleotides\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaGcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G', 'ps': '',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToBioSpring\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaGcrsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': '1', 'fA': '2', 'fC': '3', 'fG': '4', 'mU': '5', 'mA': '6', 'mC': '7', 'mG': '8', 'ps': '*',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToAxolabs\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: Axolabs / siRNA}\nexport function siRnaGcrsToAxolabs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': 'Uf', 'fA': 'Af', 'fC': 'Cf', 'fG': 'Gf', 'mU': 'u', 'mA': 'a', 'mC': 'c', 'mG': 'g', 'ps': 's',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaNucleotideToBioSpringSenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaNucleotideToBioSpringSenseStrand(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '6*', 'U': '5*', 'G': '8*', 'C': '7*' };\n    const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '*6', 'U': '*5', 'G': '*8', 'C': '*7' };\n    const objForOddIndices = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '6', 'U': '5', 'G': '8', 'C': '7' };\n    const objForEvenIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': '2', 'U': '1', 'G': '4', 'C': '3' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count > nucleotides.length - 3)\n            return objForRightEdge[x];\n        return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];\n    });\n}\n//name: siRnaNucleotidesToGcrs\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: GCRS}\nexport function siRnaNucleotidesToGcrs(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'mAps', 'U': 'mUps', 'G': 'mGps', 'C': 'mCps' };\n    const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'psmA', 'U': 'psmU', 'G': 'psmG', 'C': 'psmC' };\n    const objForEvenIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'fA', 'U': 'fU', 'G': 'fG', 'C': 'fC' };\n    const objForOddIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'mA', 'U': 'mU', 'G': 'mG', 'C': 'mC' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count > nucleotides.length - 3)\n            return objForRightEdge[x];\n        return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];\n    });\n}\n//name: siRnaNucleotideToAxolabsSenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: Axolabs}\nexport function siRnaNucleotideToAxolabsSenseStrand(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };\n    const objForSomeIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count == 6 || (count > 7 && count < 11))\n            return objForSomeIndices[x];\n        if (count == nucleotides.length - 1)\n            return 'a';\n        return obj[x];\n    });\n}\n//name: siRnaNucleotideToAxolabsAntisenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: Axolabs}\nexport function siRnaNucleotideToAxolabsAntisenseStrand(nucleotides) {\n    let count = -1;\n    const objForSmallLinkages = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };\n    const objForBigLinkages = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Afs', 'U': 'Ufs', 'G': 'Gfs', 'C': 'Cfs' };\n    const objForSomeIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };\n    const obj = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count > 19 && count < 22)\n            return objForSmallLinkages[x];\n        if (count == 0)\n            return 'us';\n        if (count == 1)\n            return objForBigLinkages[x];\n        return (count == 5 || count == 7 || count == 8 || count == 13 || count == 15) ? objForSomeIndices[x] : obj[x];\n    });\n}\n//name: gcrsToNucleotides\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: RNA nucleotides}\nexport function gcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'mAps': 'A', 'mUps': 'U', 'mGps': 'G', 'mCps': 'C', 'fAps': 'A', 'fUps': 'U', 'fGps': 'G', 'fCps': 'C',\n        'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });\n}\n//name: gcrsToMermade12\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: Mermade 12 / siRNA}\nexport function gcrsToMermade12(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'mAps': 'e', 'mUps': 'h', 'mGps': 'g', 'mCps': 'f', 'fAps': 'i', 'fUps': 'l', 'fGps': 'k', 'fCps': 'j', 'fU': 'L',\n        'fA': 'I', 'fC': 'J', 'fG': 'K', 'mU': 'H', 'mA': 'E', 'mC': 'F', 'mG': 'G',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });\n}\n","import { map, stadardPhosphateLinkSmiles, SYNTHESIZERS, TECHNOLOGIES, MODIFICATIONS } from './map';\nimport { isValidSequence } from './sequence-codes-tools';\nimport { getNucleotidesMol } from './mol-transformations';\nexport function sequenceToMolV3000(sequence, inverted = false, oclRender = false) {\n    const obj = getObjectWithCodesAndSmiles(sequence);\n    let codes = sortByStringLengthInDescendingOrder(Object.keys(obj));\n    let i = 0;\n    const smilesCodes = [];\n    const codesList = [];\n    const links = ['s', 'ps', '*'];\n    const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];\n    const dropdowns = Object.keys(MODIFICATIONS);\n    codes = codes.concat(dropdowns);\n    while (i < sequence.length) {\n        const code = codes.find((s) => s == sequence.slice(i, i + s.length));\n        i += code.length;\n        inverted ? codesList.unshift(code) : codesList.push(code);\n    }\n    for (let i = 0; i < codesList.length; i++) {\n        if (dropdowns.includes(codesList[i])) {\n            smilesCodes.push((i >= codesList.length / 2) ?\n                MODIFICATIONS[codesList[i]].right : MODIFICATIONS[codesList[i]].left);\n            smilesCodes.push(stadardPhosphateLinkSmiles);\n        }\n        else {\n            if (links.includes(codesList[i]) ||\n                includesStandardLinkAlready.includes(codesList[i]) ||\n                (i < codesList.length - 1 && links.includes(codesList[i + 1])))\n                smilesCodes.push(obj[codesList[i]]);\n            else {\n                smilesCodes.push(obj[codesList[i]]);\n                smilesCodes.push(stadardPhosphateLinkSmiles);\n            }\n        }\n    }\n    return getNucleotidesMol(smilesCodes, oclRender);\n}\nexport function sequenceToSmiles(sequence, inverted = false) {\n    const obj = getObjectWithCodesAndSmiles(sequence);\n    let codes = sortByStringLengthInDescendingOrder(Object.keys(obj));\n    let i = 0;\n    let smiles = '';\n    const codesList = [];\n    const links = ['s', 'ps', '*'];\n    const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];\n    const dropdowns = Object.keys(MODIFICATIONS);\n    codes = codes.concat(dropdowns);\n    while (i < sequence.length) {\n        const code = codes.find((s) => s == sequence.slice(i, i + s.length));\n        i += code.length;\n        inverted ? codesList.unshift(code) : codesList.push(code);\n    }\n    for (let i = 0; i < codesList.length; i++) {\n        if (dropdowns.includes(codesList[i])) {\n            smiles += (i >= codesList.length / 2) ?\n                MODIFICATIONS[codesList[i]].right + stadardPhosphateLinkSmiles :\n                MODIFICATIONS[codesList[i]].left + stadardPhosphateLinkSmiles;\n        }\n        else {\n            if (links.includes(codesList[i]) ||\n                includesStandardLinkAlready.includes(codesList[i]) ||\n                (i < codesList.length - 1 && links.includes(codesList[i + 1])))\n                smiles += obj[codesList[i]];\n            else\n                smiles += obj[codesList[i]] + stadardPhosphateLinkSmiles;\n        }\n    }\n    smiles = smiles.replace(/OO/g, 'O');\n    return ((links.includes(codesList[codesList.length - 1]) &&\n        codesList.length > 1 &&\n        !includesStandardLinkAlready.includes(codesList[codesList.length - 2])) ||\n        dropdowns.includes(codesList[codesList.length - 1]) ||\n        includesStandardLinkAlready.includes(codesList[codesList.length - 1])) ?\n        smiles :\n        smiles.slice(0, smiles.length - stadardPhosphateLinkSmiles.length + 1);\n}\nfunction getObjectWithCodesAndSmiles(sequence) {\n    const obj = {};\n    for (const synthesizer of Object.keys(map)) {\n        for (const technology of Object.keys(map[synthesizer])) {\n            for (const code of Object.keys(map[synthesizer][technology]))\n                obj[code] = map[synthesizer][technology][code].SMILES;\n        }\n    }\n    // TODO: create object based from synthesizer type to avoid key(codes) duplicates\n    const output = isValidSequence(sequence);\n    if (output.synthesizer == SYNTHESIZERS.MERMADE_12)\n        obj['g'] = map[SYNTHESIZERS.MERMADE_12][TECHNOLOGIES.SI_RNA]['g'].SMILES;\n    else if (output.synthesizer == SYNTHESIZERS.AXOLABS)\n        obj['g'] = map[SYNTHESIZERS.AXOLABS][TECHNOLOGIES.SI_RNA]['g'].SMILES;\n    return obj;\n}\nfunction sortByStringLengthInDescendingOrder(array) {\n    return array.sort(function (a, b) { return b.length - a.length; });\n}\n","export const SYNTHESIZERS = {\n    RAW_NUCLEOTIDES: 'Raw Nucleotides',\n    BIOSPRING: 'BioSpring Codes',\n    GCRS: 'Janssen GCRS Codes',\n    AXOLABS: 'Axolabs Codes',\n    MERMADE_12: 'Mermade 12',\n};\nexport const TECHNOLOGIES = {\n    DNA: 'DNA',\n    RNA: 'RNA',\n    ASO_GAPMERS: 'For ASO Gapmers',\n    SI_RNA: 'For 2\\'-OMe and 2\\'-F modified siRNA',\n};\nexport const COL_NAMES = {\n    CHEMISTRY: 'Chemistry',\n    NUMBER: 'Number',\n    TYPE: 'Type',\n    CHEMISTRY_NAME: 'Chemistry Name',\n    INTERNAL_COMPOUND_ID: 'Internal compound ID',\n    IDP: 'IDP',\n    SEQUENCE: 'Sequence',\n    COMPOUND_NAME: 'Compound Name',\n    COMPOUND_COMMENTS: 'Compound Comments',\n    SALT: 'Salt',\n    EQUIVALENTS: 'Equivalents',\n    PURITY: 'Purity',\n    CPD_MW: 'Cpd MW',\n    SALT_MASS: 'Salt mass',\n    BATCH_MW: 'Batch MW',\n    SOURCE: 'Source',\n    ICD: 'ICD',\n    OWNER: 'Owner',\n};\n// interface CODES {\n// }\nexport const MODIFICATIONS = {\n    '(invabasic)': {\n        molecularWeight: 118.13,\n        left: 'O[C@@H]1C[C@@H]O[C@H]1CO',\n        right: 'O[C@@H]1C[C@@H]O[C@H]1CO',\n    },\n    '(GalNAc-2-JNJ)': {\n        molecularWeight: 1273.3,\n        left: 'C(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)NC(=O)CCCC(=O)NCC(O)CO',\n        right: 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)',\n    },\n};\nexport const stadardPhosphateLinkSmiles = 'OP(=O)(O)O';\nexport const map = {\n    'Raw Nucleotides': {\n        'DNA': {\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n        },\n        'RNA': {\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'U': {\n                'name': 'Uracil',\n                'weight': 306.17,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n        },\n    },\n    'BioSpring Codes': {\n        'For ASO Gapmers': {\n            '5': {\n                'name': '2\\'MOE-5Me-rU',\n                'weight': 378.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '6': {\n                'name': '2\\'MOE-rA',\n                'weight': 387.29,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '7': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '8': {\n                'name': '2\\'MOE-rG',\n                'weight': 403.28,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '9': {\n                'name': '5-Methyl-dC',\n                'weight': 303.21,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            '*': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n        },\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            '1': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            '2': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            '3': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            '4': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            '5': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            '6': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            '7': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            '8': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            '*': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n        },\n    },\n    'Axolabs Codes': {\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'Uf': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'Af': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'Cf': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'Gf': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'u': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'a': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'c': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'g': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            's': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n        },\n    },\n    'Janssen GCRS Codes': {\n        'For ASO Gapmers': {\n            'moeT': {\n                'name': '2\\'MOE-5Me-rU',\n                'weight': 378.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            'moeA': {\n                'name': '2\\'MOE-rA',\n                'weight': 387.29,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            'moe5mC': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '(5m)moeC': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            'moeG': {\n                'name': '2\\'MOE-rG',\n                'weight': 403.28,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '5mC': {\n                'name': '5-Methyl-dC',\n                'weight': 303.28,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            '(5m)C': {\n                'name': '5-Methyl-dC',\n                'weight': 303.28,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            'ps': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'dA': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'dC': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'dG': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'dT': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'rA': {\n                'name': 'Adenine',\n                'weight': 329.21,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](O)[C@@H]1O',\n            },\n            'rC': {\n                'name': 'Cytosine',\n                'weight': 305.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](O)[C@@H]1O',\n            },\n            'rG': {\n                'name': 'Guanine',\n                'weight': 345.21,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](O)[C@@H]1O',\n            },\n            'rU': {\n                'name': 'Uracil',\n                'weight': 306.17,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',\n            },\n        },\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'fU': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'fA': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'fC': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'fG': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'mU': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'mA': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'mC': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'mG': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n        },\n    },\n    'Mermade 12': {\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'e': {\n                'name': '2\\'OMe-rA-ps',\n                'weight': 359.31,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'h': {\n                'name': '2\\'OMe-rU-ps',\n                'weight': 336.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'g': {\n                'name': '2\\'OMe-rG-ps',\n                'weight': 375.31,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'f': {\n                'name': '2\\'OMe-rC-ps',\n                'weight': 335.28,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'i': {\n                'name': '2\\'-fluoro-A-ps',\n                'weight': 347.27,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'l': {\n                'name': '2\\'-fluoro-U-ps',\n                'weight': 324.23,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'k': {\n                'name': '2\\'-fluoro-G-ps',\n                'weight': 363.26,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'j': {\n                'name': '2\\'-fluoro-C-ps',\n                'weight': 323.25,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'L': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'I': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'J': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'K': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'H': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'E': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'F': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'G': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n        },\n    },\n};\n","import * as OCL from 'openchemlib/full.js';\nconst PHOSHATE = `\nDatagrok monomer library Nucleotides\n\n  0  0  0  0  0  0              0 V3000\nM  V30 BEGIN CTAB\nM  V30 COUNTS 5 4 0 0 0\nM  V30 BEGIN ATOM\nM  V30 1 O -1.5 0 0 0\nM  V30 2 P 0 0 0 0\nM  V30 3 O 0 1 0 0\nM  V30 4 O 0 -1 0 0\nM  V30 5 O 1.5 0 0 0\nM  V30 END ATOM\nM  V30 BEGIN BOND\nM  V30 1 1 1 2\nM  V30 2 2 2 3\nM  V30 3 1 2 4\nM  V30 4 1 2 5\nM  V30 END BOND\nM  V30 END CTAB\nM  V30 BEGIN COLLECTION\nM  V30 END COLLECTION\nM  END`;\nconst THIOPHOSHATE = `\nDatagrok monomer library Nucleotides\n\n  0  0  0  0  0  0              0 V3000\nM  V30 BEGIN CTAB\nM  V30 COUNTS 5 4 0 0 0\nM  V30 BEGIN ATOM\nM  V30 1 O -1.5 0 0 0\nM  V30 2 P 0 0 0 0\nM  V30 3 O 0 1 0 0\nM  V30 4 S 0 -1 0 0\nM  V30 5 O 1.5 0 0 0\nM  V30 END ATOM\nM  V30 BEGIN BOND\nM  V30 1 1 1 2\nM  V30 2 2 2 3\nM  V30 3 1 2 4\nM  V30 4 1 2 5\nM  V30 END BOND\nM  V30 END CTAB\nM  V30 BEGIN COLLECTION\nM  V30 END COLLECTION\nM  END`;\nconst INVABASIC = `\nDatagrok monomer library Nucleotides\n\n  0  0  0  0  0  0              0 V3000\nM  V30 BEGIN CTAB\nM  V30 COUNTS 8 8 0 0 0\nM  V30 BEGIN ATOM\nM  V30 1 O 1.0934 -2.1636 0 0\nM  V30 2 C 1.8365 -1.4945 0 0 CFG=2\nM  V30 3 C 2.8147 -1.7024 0 0\nM  V30 4 C 3.3147 -0.8364 0 0 VAL=3\nM  V30 5 O 2.6455 -0.0932 0 0\nM  V30 6 C 1.732 -0.5 0 0 CFG=1\nM  V30 7 C 0.866 0 0 0\nM  V30 8 O 0.866 1 0 0\nM  V30 END ATOM\nM  V30 BEGIN BOND\nM  V30 1 1 2 1 CFG=1\nM  V30 2 1 2 3\nM  V30 3 1 3 4\nM  V30 4 1 4 5\nM  V30 5 1 6 5\nM  V30 6 1 2 6\nM  V30 7 1 6 7 CFG=3\nM  V30 8 1 7 8\nM  V30 END BOND\nM  V30 BEGIN COLLECTION\nM  V30 MDLV30/STEABS ATOMS=(2 2 6)\nM  V30 END COLLECTION\nM  V30 END CTAB\nM  END`;\nexport function getNucleotidesMol(smilesCodes, oclRender = false) {\n    const molBlocks = [];\n    for (let i = 0; i < smilesCodes.length - 1; i++) {\n        smilesCodes[i] == 'OP(=O)(O)O' ? molBlocks.push(PHOSHATE) :\n            smilesCodes[i] == 'OP(=O)(S)O' ? molBlocks.push(THIOPHOSHATE) :\n                smilesCodes[i] == 'O[C@@H]1C[C@@H]O[C@H]1CO' ? molBlocks.push(rotateNucleotidesV3000(INVABASIC)) :\n                    molBlocks.push(rotateNucleotidesV3000(smilesCodes[i]));\n    }\n    return linkV3000(molBlocks, false, oclRender);\n}\nexport function linkV3000(molBlocks, twoMolecules = false, oclRender = false) {\n    let macroMolBlock = '\\nDatagrok macromolecule handler\\n\\n';\n    macroMolBlock += '  0  0  0  0  0  0            999 V3000\\n';\n    macroMolBlock += 'M  V30 BEGIN CTAB\\n';\n    let atomBlock = '';\n    let bondBlock = '';\n    let collectionBlock = '';\n    const collection = [];\n    let natom = 0;\n    let nbond = 0;\n    let sequenceShift = 0;\n    let xShift = 0;\n    if (twoMolecules && molBlocks.length > 1)\n        molBlocks[1] = invertNucleotidesV3000(molBlocks[1]);\n    for (let i = 0; i < molBlocks.length; i++) {\n        molBlocks[i] = molBlocks[i].replaceAll('(-\\nM  V30 ', '(')\n            .replaceAll('-\\nM  V30 ', '').replaceAll(' )', ')');\n        const numbers = extractAtomsBondsNumbersV3000(molBlocks[i]);\n        const coordinates = extractAtomDataV3000(molBlocks[i]);\n        let indexAtoms = molBlocks[i].indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n        indexAtoms = molBlocks[i].indexOf('\\n', indexAtoms);\n        let index = indexAtoms;\n        let indexEnd = indexAtoms;\n        for (let j = 0; j < numbers.natom; j++) {\n            if (coordinates.atomIndex[j] != 1 || i == 0 || twoMolecules) {\n                //rewrite atom number\n                index = molBlocks[i].indexOf('V30', index) + 4;\n                indexEnd = molBlocks[i].indexOf(' ', index);\n                const atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;\n                molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);\n                //rewrite coordinates\n                index = molBlocks[i].indexOf(' ', index) + 1;\n                index = molBlocks[i].indexOf(' ', index) + 1;\n                indexEnd = molBlocks[i].indexOf(' ', index);\n                const totalShift = xShift - coordinates.x[0];\n                let coordinate = Math.round(10000 * (parseFloat(molBlocks[i].substring(index, indexEnd)) + totalShift)) / 10000;\n                molBlocks[i] = molBlocks[i].slice(0, index) + coordinate + molBlocks[i].slice(indexEnd);\n                index = molBlocks[i].indexOf(' ', index) + 1;\n                indexEnd = molBlocks[i].indexOf(' ', index);\n                coordinate = Math.round(10000 * (parseFloat(molBlocks[i].substring(index, indexEnd)) + sequenceShift)) / 10000;\n                molBlocks[i] = molBlocks[i].slice(0, index) + coordinate + molBlocks[i].slice(indexEnd);\n                index = molBlocks[i].indexOf('\\n', index) + 1;\n            }\n            else {\n                index = molBlocks[i].indexOf('M  V30', index) - 1;\n                indexEnd = molBlocks[i].indexOf('\\n', index + 1);\n                molBlocks[i] = molBlocks[i].slice(0, index) + molBlocks[i].slice(indexEnd);\n            }\n        }\n        const indexAtomsEnd = molBlocks[i].indexOf('M  V30 END ATOM');\n        atomBlock += molBlocks[i].substring(indexAtoms + 1, indexAtomsEnd);\n        let indexBonds = molBlocks[i].indexOf('M  V30 BEGIN BOND'); // V3000 index for bonds\n        indexBonds = molBlocks[i].indexOf('\\n', indexBonds);\n        index = indexBonds;\n        indexEnd = indexBonds;\n        for (let j = 0; j < numbers.nbond; j++) {\n            //rewrite bond number\n            index = molBlocks[i].indexOf('V30', index) + 4;\n            indexEnd = molBlocks[i].indexOf(' ', index);\n            const bondNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + nbond;\n            molBlocks[i] = molBlocks[i].slice(0, index) + bondNumber + molBlocks[i].slice(indexEnd);\n            //rewrite atom pair in bond\n            index = molBlocks[i].indexOf(' ', index) + 1;\n            index = molBlocks[i].indexOf(' ', index) + 1;\n            indexEnd = molBlocks[i].indexOf(' ', index);\n            let atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;\n            molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);\n            index = molBlocks[i].indexOf(' ', index) + 1;\n            indexEnd = Math.min(molBlocks[i].indexOf('\\n', index), molBlocks[i].indexOf(' ', index));\n            atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;\n            molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);\n            index = molBlocks[i].indexOf('\\n', index) + 1;\n        }\n        const indexBondEnd = molBlocks[i].indexOf('M  V30 END BOND');\n        bondBlock += molBlocks[i].substring(indexBonds + 1, indexBondEnd);\n        let indexCollection = molBlocks[i].indexOf('M  V30 MDLV30/STEABS ATOMS=('); // V3000 index for collections\n        while (indexCollection != -1) {\n            indexCollection += 28;\n            const collectionEnd = molBlocks[i].indexOf(')', indexCollection);\n            const collectionEntries = molBlocks[i].substring(indexCollection, collectionEnd).split(' ').slice(1);\n            collectionEntries.forEach((e) => {\n                collection.push(parseInt(e) + natom);\n            });\n            indexCollection = collectionEnd;\n            indexCollection = molBlocks[i].indexOf('M  V30 MDLV30/STEABS ATOMS=(', indexCollection);\n        }\n        natom += twoMolecules ? numbers.natom : numbers.natom - 1;\n        nbond += numbers.nbond;\n        xShift += twoMolecules ? 0 : coordinates.x[numbers.natom - 1] - coordinates.x[0];\n        sequenceShift += twoMolecules ? -7 : 0;\n    }\n    const entries = 4;\n    const collNumber = Math.ceil(collection.length / entries);\n    if (oclRender) {\n        collectionBlock += 'M  V30 MDLV30/STEABS ATOMS=(' + collection.length;\n        for (let j = 0; j < collection.length; j++)\n            collectionBlock += ' ' + collection[j];\n        collectionBlock += ')\\n';\n    }\n    else {\n        collectionBlock += 'M  V30 MDLV30/STEABS ATOMS=(' + collection.length + ' -\\n';\n        for (let i = 0; i < collNumber; i++) {\n            collectionBlock += 'M  V30 ';\n            const entriesCurrent = i + 1 == collNumber ? collection.length - (collNumber - 1) * entries : entries;\n            for (let j = 0; j < entriesCurrent; j++) {\n                collectionBlock += (j + 1 == entriesCurrent) ?\n                    (i == collNumber - 1 ? collection[entries * i + j] + ')\\n' : collection[entries * i + j] + ' -\\n') :\n                    collection[entries * i + j] + ' ';\n            }\n        }\n    }\n    //generate file\n    twoMolecules ? natom : natom++;\n    macroMolBlock += 'M  V30 COUNTS ' + natom + ' ' + nbond + ' 0 0 0\\n';\n    macroMolBlock += 'M  V30 BEGIN ATOM\\n';\n    macroMolBlock += atomBlock;\n    macroMolBlock += 'M  V30 END ATOM\\n';\n    macroMolBlock += 'M  V30 BEGIN BOND\\n';\n    macroMolBlock += bondBlock;\n    macroMolBlock += 'M  V30 END BOND\\n';\n    macroMolBlock += 'M  V30 BEGIN COLLECTION\\n';\n    macroMolBlock += collectionBlock;\n    macroMolBlock += 'M  V30 END COLLECTION\\n';\n    macroMolBlock += 'M  V30 END CTAB\\n';\n    macroMolBlock += 'M  END\\n';\n    return macroMolBlock;\n}\nfunction rotateNucleotidesV3000(molecule) {\n    let molBlock = molecule.includes('M  END') ? molecule : OCL.Molecule.fromSmiles(molecule).toMolfileV3();\n    const coordinates = extractAtomDataV3000(molBlock);\n    const natom = coordinates.atomIndex.length;\n    const indexFivePrime = coordinates.atomIndex.indexOf(1);\n    const indexThreePrime = coordinates.atomIndex.indexOf(natom);\n    //fix 5 prime if inadequate\n    if (natom > 8)\n        fix5Prime(coordinates, indexFivePrime, indexThreePrime);\n    const xCenter = (coordinates.x[indexThreePrime] + coordinates.x[indexFivePrime]) / 2;\n    const yCenter = (coordinates.y[indexThreePrime] + coordinates.y[indexFivePrime]) / 2;\n    //place to center\n    for (let i = 0; i < natom; i++) {\n        coordinates.x[i] -= xCenter;\n        coordinates.y[i] -= yCenter;\n    }\n    let angle = 0;\n    if (coordinates.x[indexFivePrime] == 0)\n        angle = coordinates.y[indexFivePrime] > coordinates.y[indexThreePrime] ? Math.PI / 2 : 3 * Math.PI / 2;\n    else if (coordinates.y[indexFivePrime] == 0)\n        angle = coordinates.x[indexFivePrime] > coordinates.x[indexThreePrime] ? Math.PI : 0;\n    else {\n        const derivative = coordinates.y[indexFivePrime] / coordinates.x[indexFivePrime];\n        angle = derivative > 0 ? Math.PI - Math.atan(derivative) : Math.atan(derivative);\n    }\n    const cos = Math.cos(angle);\n    const sin = Math.sin(angle);\n    for (let i = 0; i < natom; i++) {\n        const xAdd = coordinates.x[i];\n        coordinates.x[i] = xAdd * cos - coordinates.y[i] * sin;\n        coordinates.y[i] = xAdd * sin + coordinates.y[i] * cos;\n    }\n    //place to right\n    const xShift = coordinates.x[indexFivePrime];\n    for (let i = 0; i < natom; i++)\n        coordinates.x[i] -= xShift;\n    //rewrite molBlock\n    let index = molBlock.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n    index = molBlock.indexOf('\\n', index);\n    let indexEnd = index;\n    for (let i = 0; i < natom; i++) {\n        index = molBlock.indexOf('V30', index) + 4;\n        index = molBlock.indexOf(' ', index) + 1;\n        index = molBlock.indexOf(' ', index) + 1;\n        indexEnd = molBlock.indexOf(' ', index) + 1;\n        indexEnd = molBlock.indexOf(' ', indexEnd);\n        molBlock = molBlock.slice(0, index) +\n            coordinates.x[i] + ' ' + coordinates.y[i] +\n            molBlock.slice(indexEnd);\n        index = molBlock.indexOf('\\n', index) + 1;\n    }\n    return molBlock;\n}\nfunction invertNucleotidesV3000(molecule) {\n    let molBlock = molecule.includes('M  END') ? molecule : OCL.Molecule.fromSmiles(molecule).toMolfileV3();\n    const coordinates = extractAtomDataV3000(molBlock);\n    const natom = coordinates.atomIndex.length;\n    const xCenter = (Math.max(...coordinates.x) + Math.min(...coordinates.x)) / 2;\n    const yCenter = (Math.max(...coordinates.y) + Math.min(...coordinates.y)) / 2;\n    //place to center\n    for (let i = 0; i < natom; i++) {\n        coordinates.x[i] -= xCenter;\n        coordinates.y[i] -= yCenter;\n    }\n    const angle = Math.PI;\n    const cos = Math.cos(angle);\n    const sin = Math.sin(angle);\n    for (let i = 0; i < natom; i++) {\n        const xAdd = coordinates.x[i];\n        coordinates.x[i] = xAdd * cos - coordinates.y[i] * sin;\n        coordinates.y[i] = xAdd * sin + coordinates.y[i] * cos;\n    }\n    //place back\n    const yShift = Math.max(...coordinates.y);\n    for (let i = 0; i < natom; i++) {\n        coordinates.x[i] += xCenter;\n        coordinates.y[i] -= yShift;\n    }\n    //rewrite molBlock\n    let index = molBlock.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n    index = molBlock.indexOf('\\n', index);\n    let indexEnd = index;\n    for (let i = 0; i < natom; i++) {\n        index = molBlock.indexOf('V30', index) + 4;\n        index = molBlock.indexOf(' ', index) + 1;\n        index = molBlock.indexOf(' ', index) + 1;\n        indexEnd = molBlock.indexOf(' ', index) + 1;\n        indexEnd = molBlock.indexOf(' ', indexEnd);\n        molBlock = molBlock.slice(0, index) +\n            coordinates.x[i] + ' ' + coordinates.y[i] +\n            molBlock.slice(indexEnd);\n        index = molBlock.indexOf('\\n', index) + 1;\n    }\n    return molBlock;\n}\nfunction fix5Prime(coordinates, indexFivePrime, indexThreePrime) {\n    const indexFivePrimeNeighbour = indexFivePrime + 1;\n    const xShift = coordinates.x[indexFivePrimeNeighbour];\n    const yShift = coordinates.y[indexFivePrimeNeighbour];\n    const base3PrimeX = coordinates.x[indexThreePrime] - xShift;\n    const base3PrimeY = coordinates.y[indexThreePrime] - yShift;\n    const base5PrimeX = coordinates.x[indexFivePrime] - xShift;\n    const base5PrimeY = coordinates.y[indexFivePrime] - yShift;\n    const rotated5PrimeX = base5PrimeX * Math.cos(Math.PI * 2 / 3) - base5PrimeY * Math.sin(Math.PI * 2 / 3);\n    const rotated5PrimeY = base5PrimeX * Math.sin(Math.PI * 2 / 3) + base5PrimeY * Math.cos(Math.PI * 2 / 3);\n    const dx = base5PrimeX - base3PrimeX;\n    const dy = base5PrimeY - base3PrimeY;\n    const dxRotated = rotated5PrimeX - base3PrimeX;\n    const dyRotated = rotated5PrimeY - base3PrimeY;\n    if (Math.sqrt(dyRotated * dyRotated + dxRotated * dxRotated) >= Math.sqrt(dy * dy + dx * dx)) {\n        coordinates.x[indexFivePrime] = rotated5PrimeX + xShift;\n        coordinates.y[indexFivePrime] = rotated5PrimeY + yShift;\n    }\n}\nfunction extractAtomsBondsNumbersV3000(molBlock) {\n    molBlock = molBlock.replaceAll('\\r', ''); //equalize old and new sdf standards\n    let index = molBlock.indexOf('COUNTS') + 7; // V3000 index for atoms and bonds number\n    let indexEnd = molBlock.indexOf(' ', index);\n    const atomsNumber = parseInt(molBlock.substring(index, indexEnd));\n    index = indexEnd + 1;\n    indexEnd = molBlock.indexOf(' ', index);\n    const bondsNumber = parseInt(molBlock.substring(index, indexEnd));\n    return { natom: atomsNumber, nbond: bondsNumber };\n}\nfunction extractAtomDataV3000(molBlock) {\n    const numbers = extractAtomsBondsNumbersV3000(molBlock);\n    let index = molBlock.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n    index = molBlock.indexOf('\\n', index);\n    let indexEnd = index;\n    const indexes = Array(numbers.natom);\n    const types = Array(numbers.natom);\n    const x = Array(numbers.natom);\n    const y = Array(numbers.natom);\n    for (let i = 0; i < numbers.natom; i++) {\n        index = molBlock.indexOf('V30', index) + 4;\n        indexEnd = molBlock.indexOf(' ', index);\n        indexes[i] = parseInt(molBlock.substring(index, indexEnd));\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        types[i] = molBlock.substring(index, indexEnd);\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        x[i] = parseFloat(molBlock.substring(index, indexEnd));\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        y[i] = parseFloat(molBlock.substring(index, indexEnd));\n        index = molBlock.indexOf('\\n', index) + 1;\n    }\n    return { atomIndex: indexes, atomType: types, x: x, y: y };\n}\n","import * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\n// import * as DG from 'datagrok-api/dg';\nimport { map, SYNTHESIZERS, TECHNOLOGIES, MODIFICATIONS } from './map';\nimport { asoGapmersNucleotidesToBioSpring, asoGapmersNucleotidesToGcrs, asoGapmersBioSpringToNucleotides, asoGapmersBioSpringToGcrs, asoGapmersGcrsToNucleotides, asoGapmersGcrsToBioSpring, gcrsToMermade12, siRnaNucleotideToBioSpringSenseStrand, siRnaNucleotideToAxolabsSenseStrand, siRnaNucleotidesToGcrs, siRnaBioSpringToNucleotides, siRnaBioSpringToAxolabs, siRnaBioSpringToGcrs, siRnaAxolabsToNucleotides, siRnaAxolabsToBioSpring, siRnaAxolabsToGcrs, siRnaGcrsToNucleotides, siRnaGcrsToBioSpring, siRnaGcrsToAxolabs, gcrsToNucleotides } from './converters';\nconst noTranslationTableAvailable = 'No translation table available';\nexport const undefinedInputSequence = 'Type of input sequence is undefined';\nexport function isValidSequence(sequence) {\n    let possibleSynthesizers = getListOfPossibleSynthesizersByFirstMatchedCode(sequence);\n    if (possibleSynthesizers.length > 1) {\n        const synthesizer = ui.choiceInput('Choose synthesizer from list: ', possibleSynthesizers[0], possibleSynthesizers);\n        ui.dialog('Choose Synthesizer')\n            .add(ui.panel([synthesizer.root], { style: { fontWeight: 'bold' } }))\n            .onOK(() => possibleSynthesizers = [synthesizer.value])\n            .onCancel(() => {\n            possibleSynthesizers = [possibleSynthesizers[0]];\n            grok.shell.warning('Input sequence is expected to be in format ' + possibleSynthesizers[0]);\n        })\n            .show();\n    }\n    else if (possibleSynthesizers.length == 0)\n        return { indexOfFirstNotValidChar: 0, synthesizer: null, technology: null };\n    let outputIndex = 0;\n    const firstUniqueCharacters = ['r', 'd'];\n    const nucleotides = ['A', 'U', 'T', 'C', 'G'];\n    possibleSynthesizers.forEach((synthesizer) => {\n        const codes = getAllCodesOfSynthesizer(synthesizer);\n        while (outputIndex < sequence.length) {\n            const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));\n            if (matchedCode == null)\n                break;\n            if ( // for mistake pattern 'rAA'\n            outputIndex > 1 &&\n                nucleotides.includes(sequence[outputIndex]) &&\n                firstUniqueCharacters.includes(sequence[outputIndex - 2]))\n                break;\n            if ( // for mistake pattern 'ArA'\n            firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&\n                nucleotides.includes(sequence[outputIndex])) {\n                outputIndex++;\n                break;\n            }\n            outputIndex += matchedCode.length;\n        }\n    });\n    const indexOfFirstNotValidChar = (outputIndex == sequence.length) ? -1 : outputIndex;\n    if (indexOfFirstNotValidChar != -1) {\n        return {\n            indexOfFirstNotValidChar: indexOfFirstNotValidChar,\n            synthesizer: possibleSynthesizers[0],\n            technology: null,\n        };\n    }\n    let possibleTechnologies = getListOfPossibleTechnologiesByFirstMatchedCode(sequence, possibleSynthesizers[0]);\n    if (possibleTechnologies.length > 1) {\n        const technology = ui.choiceInput('Choose technology from list: ', possibleTechnologies[0], possibleTechnologies);\n        ui.dialog('Choose Technology')\n            .add(ui.panel([technology.root], { style: { fontWeight: 'bold' } }))\n            .onOK(() => possibleTechnologies = [technology.value])\n            .onCancel(() => {\n            possibleTechnologies = [possibleTechnologies[0]];\n            grok.shell.warning('Input sequence is expected to be in format ' + possibleTechnologies[0]);\n        })\n            .show();\n    }\n    else if (possibleTechnologies.length == 0)\n        return { indexOfFirstNotValidChar: 0, synthesizer: null, technology: null };\n    outputIndex = 0;\n    possibleTechnologies.forEach((technology) => {\n        const codes = Object.keys(map[possibleSynthesizers[0]][technology]);\n        while (outputIndex < sequence.length) {\n            const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));\n            if (matchedCode == null)\n                break;\n            if ( // for mistake pattern 'rAA'\n            outputIndex > 1 &&\n                nucleotides.includes(sequence[outputIndex]) &&\n                firstUniqueCharacters.includes(sequence[outputIndex - 2]))\n                break;\n            if ( // for mistake pattern 'ArA'\n            firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&\n                nucleotides.includes(sequence[outputIndex])) {\n                outputIndex++;\n                break;\n            }\n            outputIndex += matchedCode.length;\n        }\n    });\n    return {\n        indexOfFirstNotValidChar: indexOfFirstNotValidChar,\n        synthesizer: possibleSynthesizers[0],\n        technology: possibleTechnologies[outputIndex],\n    };\n}\nfunction getAllCodesOfSynthesizer(synthesizer) {\n    let codes = [];\n    for (const technology of Object.keys(map[synthesizer]))\n        codes = codes.concat(Object.keys(map[synthesizer][technology]));\n    return codes.concat(Object.keys(MODIFICATIONS));\n}\nfunction getListOfPossibleSynthesizersByFirstMatchedCode(sequence) {\n    const synthesizers = [];\n    Object.keys(map).forEach((synthesizer) => {\n        const codes = getAllCodesOfSynthesizer(synthesizer);\n        //TODO: get first non-dropdown code when there are two modifications\n        let start = 0;\n        for (let i = 0; i < sequence.length; i++) {\n            if (sequence[i] == ')' && i != sequence.length - 1) {\n                start = i + 1;\n                break;\n            }\n        }\n        if (codes.some((s) => s == sequence.slice(start, start + s.length)))\n            synthesizers.push(synthesizer);\n    });\n    return synthesizers;\n}\nfunction getListOfPossibleTechnologiesByFirstMatchedCode(sequence, synthesizer) {\n    const technologies = [];\n    Object.keys(map[synthesizer]).forEach((technology) => {\n        const codes = Object.keys(map[synthesizer][technology]).concat(Object.keys(MODIFICATIONS));\n        if (codes.some((s) => s == sequence.slice(0, s.length)))\n            technologies.push(technology);\n    });\n    return technologies;\n}\nexport function convertSequence(sequence, output) {\n    if (output.indexOfFirstNotValidChar != -1) {\n        return {\n            // type: '',\n            indexOfFirstNotValidChar: JSON.stringify(output),\n            Error: undefinedInputSequence,\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.RAW_NUCLEOTIDES && output.technology == TECHNOLOGIES.DNA) {\n        return {\n            type: SYNTHESIZERS.RAW_NUCLEOTIDES + ' ' + TECHNOLOGIES.DNA,\n            Nucleotides: sequence,\n            BioSpring: asoGapmersNucleotidesToBioSpring(sequence),\n            GCRS: asoGapmersNucleotidesToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.BIOSPRING && output.technology == TECHNOLOGIES.ASO_GAPMERS) {\n        return {\n            type: SYNTHESIZERS.BIOSPRING + ' ' + TECHNOLOGIES.ASO_GAPMERS,\n            Nucleotides: asoGapmersBioSpringToNucleotides(sequence),\n            BioSpring: sequence,\n            GCRS: asoGapmersBioSpringToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.GCRS && output.technology == TECHNOLOGIES.ASO_GAPMERS) {\n        return {\n            type: SYNTHESIZERS.GCRS + ' ' + TECHNOLOGIES.ASO_GAPMERS,\n            Nucleotides: asoGapmersGcrsToNucleotides(sequence),\n            BioSpring: asoGapmersGcrsToBioSpring(sequence),\n            Mermade12: gcrsToMermade12(sequence),\n            GCRS: sequence,\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.RAW_NUCLEOTIDES && output.technology == TECHNOLOGIES.RNA) {\n        return {\n            type: SYNTHESIZERS.RAW_NUCLEOTIDES + ' ' + TECHNOLOGIES.RNA,\n            Nucleotides: sequence,\n            BioSpring: siRnaNucleotideToBioSpringSenseStrand(sequence),\n            Axolabs: siRnaNucleotideToAxolabsSenseStrand(sequence),\n            GCRS: siRnaNucleotidesToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.BIOSPRING && output.technology == TECHNOLOGIES.SI_RNA) {\n        return {\n            type: SYNTHESIZERS.BIOSPRING + ' ' + TECHNOLOGIES.SI_RNA,\n            Nucleotides: siRnaBioSpringToNucleotides(sequence),\n            BioSpring: sequence,\n            Axolabs: siRnaBioSpringToAxolabs(sequence),\n            GCRS: siRnaBioSpringToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.AXOLABS && output.technology == TECHNOLOGIES.SI_RNA) {\n        return {\n            type: SYNTHESIZERS.AXOLABS + ' ' + TECHNOLOGIES.SI_RNA,\n            Nucleotides: siRnaAxolabsToNucleotides(sequence),\n            BioSpring: siRnaAxolabsToBioSpring(sequence),\n            Axolabs: sequence,\n            GCRS: siRnaAxolabsToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.GCRS && output.technology == TECHNOLOGIES.SI_RNA) {\n        return {\n            type: SYNTHESIZERS.GCRS + ' ' + TECHNOLOGIES.SI_RNA,\n            Nucleotides: siRnaGcrsToNucleotides(sequence),\n            BioSpring: siRnaGcrsToBioSpring(sequence),\n            Axolabs: siRnaGcrsToAxolabs(sequence),\n            MM12: gcrsToMermade12(sequence),\n            GCRS: sequence,\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.GCRS) {\n        return {\n            type: SYNTHESIZERS.GCRS,\n            Nucleotides: gcrsToNucleotides(sequence),\n            GCRS: sequence,\n            Mermade12: gcrsToMermade12(sequence),\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.MERMADE_12) {\n        return {\n            type: SYNTHESIZERS.MERMADE_12,\n            Nucleotides: noTranslationTableAvailable,\n            GCRS: noTranslationTableAvailable,\n            Mermade12: sequence,\n        };\n    }\n    return {\n        type: undefinedInputSequence,\n        Nucleotides: undefinedInputSequence,\n    };\n}\n","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport { category, expect, test } from '@datagrok-libraries/utils/src/test';\nimport { sequenceToSmiles } from '../structures-works/from-monomers';\ncategory('sequence-translator', () => {\n    test('AGGTCCTCTTGACTTAGGCC', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O';\n        expect(sequenceToSmiles('AGGTCCTCTTGACTTAGGCC'), expected);\n    }));\n    test('invabasic/galnac1', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)sgg(invabasic)(GalNAc-2-JNJ)'), expected);\n    }));\n    test('invabasic/galnac2', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)sgsg(invabasic)(GalNAc-2-JNJ)'), expected);\n    }));\n    test('invabasic/galnac3', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)sggs(invabasic)(GalNAc-2-JNJ)'), expected);\n    }));\n    test('invabasic/galnac4', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)sgg(invabasic)s(GalNAc-2-JNJ)'), expected);\n    }));\n    test('usCfCfUfGfAf', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O';\n        expect(sequenceToSmiles('usCfCfUfGfAf'), expected);\n    }));\n    test('usAfsusgsgsg', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('usAfsusgsgsg'), expected);\n    }));\n    test('UfUfUfsCfsuacg', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('UfUfUfsCfsuacg'), expected);\n    }));\n    test('susususauasu', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OP(=O)(S)OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('susususauasu'), expected);\n    }));\n    test('CfGfCfsGfsCf', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O';\n        expect(sequenceToSmiles('CfGfCfsGfsCf'), expected);\n    }));\n    test('acacacsacsac', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('acacacsacsac'), expected);\n    }));\n    test('cccgggusug', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('cccgggusug'), expected);\n    }));\n    test('UfAfCfGfGfCfAfUf', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O';\n        expect(sequenceToSmiles('UfAfCfGfGfCfAfUf'), expected);\n    }));\n    test('(invabasic)sucuCfuUf', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O';\n        expect(sequenceToSmiles('(invabasic)sucuCfuUf'), expected);\n    }));\n    test('(invabasic)sAfgcugUf', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O';\n        expect(sequenceToSmiles('(invabasic)sAfgcugUf'), expected);\n    }));\n    test('(invabasic)cuCfuUfsc', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('(invabasic)cuCfuUfsc'), expected);\n    }));\n    test('(invabasic)scususu(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)scususu(GalNAc-2-JNJ)'), expected);\n    }));\n    test('(invabasic)usAfsucuCfuUfAfgcugUfgCfacususu', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('(invabasic)usAfsucuCfuUfAfgcugUfgCfacususu'), expected);\n    }));\n    test('(invabasic)asacgGfuGfCfAfacucuauuca', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('(invabasic)asacgGfuGfCfAfacucuauuca'), expected);\n    }));\n    test('(invabasic)scsgguGfcAfAfCfucuauucuga', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('(invabasic)scsgguGfcAfAfCfucuauucuga'), expected);\n    }));\n    test('(invabasic)scsaacUfcUfAfUfucuggacuua', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('(invabasic)scsaacUfcUfAfUfucuggacuua'), expected);\n    }));\n    test('(invabasic)sasacuCfuAfUfUfcuggacuuua', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('(invabasic)sasacuCfuAfUfUfcuggacuuua'), expected);\n    }));\n    test('(invabasic)usAfscug(invabasic)(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)usAfscug(invabasic)(GalNAc-2-JNJ)'), expected);\n    }));\n    test('(invabasic)sasuaaCfcUf(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)sasuaaCfcUf(GalNAc-2-JNJ)'), expected);\n    }));\n    test('(invabasic)sasuaaCfcUfCfUfuguaguuaua(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)sasuaaCfcUfCfUfuguaguuaua(GalNAc-2-JNJ)'), expected);\n    }));\n    test('(invabasic)scsaucacguUfGfCfagccgucuua(invabasic)(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)scsaucacguUfGfCfagccgucuua(invabasic)(GalNAc-2-JNJ)'), expected);\n    }));\n    test('(invabasic)susguuUfgCfCfUfacaucuacua(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)susguuUfgCfCfUfacaucuacua(GalNAc-2-JNJ)'), expected);\n    }));\n});\n","module.exports = DG;","module.exports = OCL;","module.exports = grok;","module.exports = ui;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as DG from 'datagrok-api/dg';\nimport { runTests, tests } from '@datagrok-libraries/utils/src/test';\nimport './tests/smiles-tests';\nexport const _package = new DG.Package();\nexport { tests };\n//name: test\n//output: dataframe result\nexport function test() {\n    return __awaiter(this, void 0, void 0, function* () {\n        const data = yield runTests();\n        return DG.DataFrame.fromObjects(data);\n    });\n}\n"],"names":[],"sourceRoot":""}