@datagrok/sequence-translator 1.0.7 → 1.0.9

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.
@@ -15,18 +15,24 @@ __webpack_require__.r(__webpack_exports__);
15
15
  /* harmony export */ "currentCategory": () => (/* binding */ currentCategory),
16
16
  /* harmony export */ "assure": () => (/* binding */ assure),
17
17
  /* harmony export */ "Test": () => (/* binding */ Test),
18
+ /* harmony export */ "testEvent": () => (/* binding */ testEvent),
18
19
  /* harmony export */ "test": () => (/* binding */ test),
19
- /* harmony export */ "assertNoError": () => (/* binding */ assertNoError),
20
20
  /* harmony export */ "expect": () => (/* binding */ expect),
21
21
  /* harmony export */ "expectFloat": () => (/* binding */ expectFloat),
22
+ /* harmony export */ "expectObject": () => (/* binding */ expectObject),
23
+ /* harmony export */ "expectArray": () => (/* binding */ expectArray),
22
24
  /* harmony export */ "category": () => (/* binding */ category),
23
25
  /* harmony export */ "before": () => (/* binding */ before),
24
26
  /* harmony export */ "after": () => (/* binding */ after),
25
27
  /* harmony export */ "runTests": () => (/* binding */ runTests),
26
- /* harmony export */ "delay": () => (/* binding */ delay)
28
+ /* harmony export */ "delay": () => (/* binding */ delay),
29
+ /* harmony export */ "awaitCheck": () => (/* binding */ awaitCheck),
30
+ /* harmony export */ "isDialogPresent": () => (/* binding */ isDialogPresent)
27
31
  /* harmony export */ });
28
32
  /* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! datagrok-api/grok */ "datagrok-api/grok");
29
33
  /* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__);
34
+ /* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! datagrok-api/dg */ "datagrok-api/dg");
35
+ /* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__);
30
36
  var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
31
37
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
32
38
  return new (P || (P = Promise))(function (resolve, reject) {
@@ -37,42 +43,62 @@ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _argume
37
43
  });
38
44
  };
39
45
 
40
- let tests = {};
46
+
47
+ const tests = {};
41
48
  let currentCategory;
42
49
  var assure;
43
50
  (function (assure) {
44
51
  function notNull(value, name) {
45
52
  if (value == null)
46
- throw `${name == null ? 'Value' : name} not defined`;
53
+ throw new Error(`${name == null ? 'Value' : name} not defined`);
47
54
  }
48
55
  assure.notNull = notNull;
49
56
  })(assure || (assure = {}));
50
57
  class Test {
51
58
  constructor(category, name, test, options) {
52
- var _a, _b;
59
+ var _a;
53
60
  this.category = category;
54
61
  this.name = name;
55
62
  options !== null && options !== void 0 ? options : (options = {});
56
63
  (_a = options.timeout) !== null && _a !== void 0 ? _a : (options.timeout = 30000);
57
- (_b = options.unhandledExceptionTimeout) !== null && _b !== void 0 ? _b : (options.unhandledExceptionTimeout = 2000);
58
64
  this.options = options;
59
65
  this.test = () => __awaiter(this, void 0, void 0, function* () {
60
66
  return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {
61
67
  let result = '';
62
68
  try {
63
- datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.lastError = '';
64
69
  result = yield test();
65
70
  }
66
71
  catch (e) {
67
72
  reject(e);
68
73
  }
69
- if (!(yield assertNoError(options.unhandledExceptionTimeout)))
70
- reject(`Unhandled exception during test: ${datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.lastError}`);
71
74
  resolve(result);
72
75
  }));
73
76
  });
74
77
  }
75
78
  }
79
+ function testEvent(event, handler, trigger, ms = 0) {
80
+ return __awaiter(this, void 0, void 0, function* () {
81
+ let sub;
82
+ return new Promise((resolve, reject) => {
83
+ sub = event.subscribe((args) => {
84
+ try {
85
+ handler(args);
86
+ }
87
+ catch (e) {
88
+ reject(e);
89
+ }
90
+ sub.unsubscribe();
91
+ resolve('OK');
92
+ });
93
+ setTimeout(() => {
94
+ sub.unsubscribe();
95
+ // eslint-disable-next-line prefer-promise-reject-errors
96
+ reject('timeout');
97
+ }, ms);
98
+ trigger();
99
+ });
100
+ });
101
+ }
76
102
  function test(name, test, options) {
77
103
  if (tests[currentCategory] == undefined)
78
104
  tests[currentCategory] = {};
@@ -80,39 +106,57 @@ function test(name, test, options) {
80
106
  tests[currentCategory].tests = [];
81
107
  tests[currentCategory].tests.push(new Test(currentCategory, name, test, options));
82
108
  }
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. */
109
+ /* Tests two objects for equality, throws an exception if they are not equal. */
95
110
  function expect(actual, expected) {
96
111
  if (actual !== expected)
97
- throw `Expected "${expected}", got "${actual}"`;
112
+ throw new Error(`Expected "${expected}", got "${actual}"`);
98
113
  }
99
114
  function expectFloat(actual, expected, tolerance = 0.001) {
100
- const areEqual = Math.abs(actual - expected) < 0.001;
115
+ const areEqual = Math.abs(actual - expected) < tolerance;
101
116
  if (!areEqual)
102
- throw `Expected ${expected}, got ${actual} (tolerance = ${tolerance})`;
117
+ throw new Error(`Expected ${expected}, got ${actual} (tolerance = ${tolerance})`);
103
118
  }
104
- /** Defines a test suite. */
119
+ function expectObject(actual, expected) {
120
+ for (const [expectedKey, expectedValue] of Object.entries(expected)) {
121
+ if (!actual.hasOwnProperty(expectedKey))
122
+ throw new Error(`Expected property "${expectedKey}" not found`);
123
+ const actualValue = actual[expectedKey];
124
+ if (actualValue instanceof Array && expectedValue instanceof Array)
125
+ expectArray(actualValue, expectedValue);
126
+ else if (actualValue instanceof Object && expectedValue instanceof Object)
127
+ expectObject(actualValue, expectedValue);
128
+ else if (actualValue != expectedValue)
129
+ throw new Error(`Expected ${expectedValue} for key ${expectedKey}, got ${actualValue}`);
130
+ }
131
+ }
132
+ function expectArray(actual, expected) {
133
+ const actualLength = actual.length;
134
+ const expectedLength = expected.length;
135
+ if (actualLength != expectedLength) {
136
+ throw new Error(`Arrays are of different length: actual array length is ${actualLength} ` +
137
+ `and expected array length is ${expectedLength}`);
138
+ }
139
+ for (let i = 0; i < actualLength; i++) {
140
+ if (actual[i] instanceof Array && expected[i] instanceof Array)
141
+ expectArray(actual[i], expected[i]);
142
+ else if (actual[i] instanceof Object && expected[i] instanceof Object)
143
+ expectObject(actual[i], expected[i]);
144
+ else if (actual[i] != expected[i])
145
+ throw new Error(`Expected ${expected[i]} at position ${i}, got ${actual[i]}`);
146
+ }
147
+ }
148
+ /* Defines a test suite. */
105
149
  function category(category, tests) {
106
150
  currentCategory = category;
107
151
  tests();
108
152
  }
109
- /** Defines a function to be executed before the tests in this category are executed. */
153
+ /* Defines a function to be executed before the tests in this category are executed. */
110
154
  function before(before) {
111
155
  if (tests[currentCategory] == undefined)
112
156
  tests[currentCategory] = {};
113
157
  tests[currentCategory].before = before;
114
158
  }
115
- /** Defines a function to be executed after the tests in this category are executed. */
159
+ /* Defines a function to be executed after the tests in this category are executed. */
116
160
  function after(after) {
117
161
  if (tests[currentCategory] == undefined)
118
162
  tests[currentCategory] = {};
@@ -121,12 +165,15 @@ function after(after) {
121
165
  function runTests(options) {
122
166
  var _a;
123
167
  return __awaiter(this, void 0, void 0, function* () {
124
- let results = [];
168
+ const results = [];
169
+ console.log(`Running tests`);
170
+ datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.lastError = '';
125
171
  for (const [key, value] of Object.entries(tests)) {
126
172
  if ((options === null || options === void 0 ? void 0 : options.category) != undefined) {
127
173
  if (!key.toLowerCase().startsWith(options === null || options === void 0 ? void 0 : options.category.toLowerCase()))
128
174
  continue;
129
175
  }
176
+ console.log(`Started ${key} category`);
130
177
  try {
131
178
  if (value.before)
132
179
  yield value.before();
@@ -134,12 +181,11 @@ function runTests(options) {
134
181
  catch (x) {
135
182
  value.beforeStatus = x.toString();
136
183
  }
137
- let t = (_a = value.tests) !== null && _a !== void 0 ? _a : [];
138
- let res = [];
139
- for (let i = 0; i < t.length; i++) {
184
+ const t = (_a = value.tests) !== null && _a !== void 0 ? _a : [];
185
+ const res = [];
186
+ for (let i = 0; i < t.length; i++)
140
187
  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');
188
+ const data = (yield Promise.all(res)).filter((d) => d.result != 'skipped');
143
189
  try {
144
190
  if (value.after)
145
191
  yield value.after();
@@ -148,11 +194,19 @@ function runTests(options) {
148
194
  value.afterStatus = x.toString();
149
195
  }
150
196
  if (value.afterStatus)
151
- data.push({ category: key, name: 'init', result: value.afterStatus, success: false });
197
+ data.push({ category: key, name: 'init', result: value.afterStatus, success: false, ms: 0 });
152
198
  if (value.beforeStatus)
153
- data.push({ category: key, name: 'init', result: value.beforeStatus, success: false });
199
+ data.push({ category: key, name: 'init', result: value.beforeStatus, success: false, ms: 0 });
154
200
  results.push(...data);
155
201
  }
202
+ yield delay(1000);
203
+ if (datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.lastError.length > 0) {
204
+ results.push({
205
+ category: 'Unhandled exceptions',
206
+ name: 'exceptions',
207
+ result: datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.lastError, success: false, ms: 0
208
+ });
209
+ }
156
210
  return results;
157
211
  });
158
212
  }
@@ -160,26 +214,64 @@ function execTest(t, predicate) {
160
214
  var _a;
161
215
  return __awaiter(this, void 0, void 0, function* () {
162
216
  let r;
217
+ const skip = predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase()));
218
+ if (!skip)
219
+ console.log(`Started ${t.category} ${t.name}`);
220
+ const start = new Date();
163
221
  try {
164
- if (predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase())))
165
- r = { success: true, result: 'skipped' };
222
+ if (skip)
223
+ r = { success: true, result: 'skipped', ms: 0 };
166
224
  else
167
- r = { success: true, result: (_a = yield t.test()) !== null && _a !== void 0 ? _a : 'OK' };
225
+ r = { success: true, result: (_a = yield t.test()) !== null && _a !== void 0 ? _a : 'OK', ms: 0 };
168
226
  }
169
227
  catch (x) {
170
- r = { success: false, result: x.toString() };
228
+ r = { success: false, result: x.toString(), ms: 0 };
171
229
  }
230
+ const stop = new Date();
231
+ // @ts-ignore
232
+ r.ms = stop - start;
233
+ if (!skip)
234
+ console.log(`Finished ${t.category} ${t.name} for ${r.ms} ms`);
172
235
  r.category = t.category;
173
236
  r.name = t.name;
174
237
  return r;
175
238
  });
176
239
  }
240
+ /* Waits [ms] milliseconds */
177
241
  function delay(ms) {
178
242
  return __awaiter(this, void 0, void 0, function* () {
179
- yield new Promise(r => setTimeout(r, ms));
243
+ yield new Promise((r) => setTimeout(r, ms));
180
244
  });
181
245
  }
182
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.js","sourceRoot":"","sources":["test.ts"],"names":[],"mappings":"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","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"]}
246
+ function awaitCheck(checkHandler) {
247
+ return __awaiter(this, void 0, void 0, function* () {
248
+ return new Promise((resolve, reject) => {
249
+ let stop = false;
250
+ setTimeout(() => {
251
+ stop = true;
252
+ // eslint-disable-next-line prefer-promise-reject-errors
253
+ reject('Timeout exceeded');
254
+ }, 500);
255
+ function check() {
256
+ if (checkHandler()) {
257
+ stop = false;
258
+ resolve();
259
+ }
260
+ if (!stop)
261
+ setTimeout(check, 50);
262
+ }
263
+ check();
264
+ });
265
+ });
266
+ }
267
+ function isDialogPresent(dialogTitle) {
268
+ for (let i = 0; i < datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__.Dialog.getOpenDialogs().length; i++) {
269
+ if (datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__.Dialog.getOpenDialogs()[i].title == dialogTitle)
270
+ return true;
271
+ }
272
+ return false;
273
+ }
274
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.js","sourceRoot":"","sources":["test.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,KAAK,IAAI,MAAM,mBAAmB,CAAC;AAC1C,OAAO,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAGtC,MAAM,CAAC,MAAM,KAAK,GAKd,EAAE,CAAC;AAEP,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,IAAI,KAAK,CAAC,GAAG,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,cAAc,CAAC,CAAC;IACpE,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,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,MAAM,GAAG,MAAM,IAAI,EAAE,CAAC;iBACvB;gBAAC,OAAO,CAAM,EAAE;oBACf,MAAM,CAAC,CAAC,CAAC,CAAC;iBACX;gBACD,OAAO,CAAC,MAAM,CAAC,CAAC;YAClB,CAAC,CAAA,CAAC,CAAC;QACL,CAAC,CAAA,CAAC;IACJ,CAAC;CACF;AAED,MAAM,UAAgB,SAAS,CAAI,KAAoB,EAAE,OAA0B,EAAE,OAAmB,EAAE,KAAa,CAAC;;QACtH,IAAI,GAAiB,CAAC;QACtB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,GAAG,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;gBAC7B,IAAI;oBACF,OAAO,CAAC,IAAI,CAAC,CAAC;iBACf;gBAAC,OAAO,CAAC,EAAE;oBACV,MAAM,CAAC,CAAC,CAAC,CAAC;iBACX;gBACD,GAAG,CAAC,WAAW,EAAE,CAAC;gBAClB,OAAO,CAAC,IAAI,CAAC,CAAC;YAChB,CAAC,CAAC,CAAC;YACH,UAAU,CAAC,GAAG,EAAE;gBACd,GAAG,CAAC,WAAW,EAAE,CAAC;gBAClB,wDAAwD;gBACxD,MAAM,CAAC,SAAS,CAAC,CAAC;YACpB,CAAC,EAAE,EAAE,CAAC,CAAC;YACP,OAAO,EAAE,CAAC;QACZ,CAAC,CAAC,CAAC;IACL,CAAC;CAAA;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,gFAAgF;AAChF,MAAM,UAAU,MAAM,CAAC,MAAW,EAAE,QAAa;IAC/C,IAAI,MAAM,KAAK,QAAQ;QACrB,MAAM,IAAI,KAAK,CAAC,aAAa,QAAQ,WAAW,MAAM,GAAG,CAAC,CAAC;AAC/D,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,SAAS,CAAC;IACzD,IAAI,CAAC,QAAQ;QACX,MAAM,IAAI,KAAK,CAAC,YAAY,QAAQ,SAAS,MAAM,iBAAiB,SAAS,GAAG,CAAC,CAAC;AACtF,CAAC;AAED,MAAM,UAAU,YAAY,CAAC,MAA8B,EAAE,QAAgC;IAC3F,KAAK,MAAM,CAAC,WAAW,EAAE,aAAa,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE;QACnE,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC;YACrC,MAAM,IAAI,KAAK,CAAC,sBAAsB,WAAW,aAAa,CAAC,CAAC;QAElE,MAAM,WAAW,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QACxC,IAAI,WAAW,YAAY,KAAK,IAAI,aAAa,YAAY,KAAK;YAChE,WAAW,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC;aACrC,IAAI,WAAW,YAAY,MAAM,IAAI,aAAa,YAAY,MAAM;YACvE,YAAY,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC;aACtC,IAAI,WAAW,IAAI,aAAa;YACnC,MAAM,IAAI,KAAK,CAAC,YAAY,aAAa,YAAY,WAAW,SAAS,WAAW,EAAE,CAAC,CAAC;KAC3F;AACH,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,MAAsB,EAAE,QAAwB;IAC1E,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC;IACnC,MAAM,cAAc,GAAG,QAAQ,CAAC,MAAM,CAAC;IAEvC,IAAI,YAAY,IAAI,cAAc,EAAE;QAClC,MAAM,IAAI,KAAK,CAAC,0DAA0D,YAAY,GAAG;YACvF,gCAAgC,cAAc,EAAE,CAAC,CAAC;KACrD;IAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,EAAE,CAAC,EAAE,EAAE;QACrC,IAAI,MAAM,CAAC,CAAC,CAAC,YAAY,KAAK,IAAI,QAAQ,CAAC,CAAC,CAAC,YAAY,KAAK;YAC5D,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;aACjC,IAAI,MAAM,CAAC,CAAC,CAAC,YAAY,MAAM,IAAI,QAAQ,CAAC,CAAC,CAAC,YAAY,MAAM;YACnE,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;aAClC,IAAI,MAAM,CAAC,CAAC,CAAC,IAAI,QAAQ,CAAC,CAAC,CAAC;YAC/B,MAAM,IAAI,KAAK,CAAC,YAAY,QAAQ,CAAC,CAAC,CAAC,gBAAgB,CAAC,SAAS,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;KACjF;AACH,CAAC;AAED,2BAA2B;AAC3B,MAAM,UAAU,QAAQ,CAAC,QAAgB,EAAE,KAAiB;IAC1D,eAAe,GAAG,QAAQ,CAAC;IAC3B,KAAK,EAAE,CAAC;AACV,CAAC;AAED,uFAAuF;AACvF,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,sFAAsF;AACtF,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,OAA8C;;;QAC3E,MAAM,OAAO,GAAyF,EAAE,CAAC;QACzG,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;QAC7B,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,EAAE,CAAC;QAC1B,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,OAAO,CAAC,GAAG,CAAC,WAAW,GAAG,WAAW,CAAC,CAAC;YACvC,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,MAAM,CAAC,GAAG,MAAA,KAAK,CAAC,KAAK,mCAAI,EAAE,CAAC;YAC5B,MAAM,GAAG,GAAG,EAAE,CAAC;YACf,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE;gBAC/B,GAAG,CAAC,IAAI,CAAC,MAAM,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,IAAI,CAAC,CAAC,CAAC;YAEhD,MAAM,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;YAC3E,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,EAAE,EAAE,EAAE,CAAC,EAAC,CAAC,CAAC;YAC7F,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,EAAE,EAAE,EAAE,CAAC,EAAC,CAAC,CAAC;YAC9F,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;SACvB;QACD,MAAM,KAAK,CAAC,IAAI,CAAC,CAAC;QAClB,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;YACnC,OAAO,CAAC,IAAI,CAAC;gBACX,QAAQ,EAAE,sBAAsB;gBAChC,IAAI,EAAE,YAAY;gBAClB,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;aACpD,CAAC,CAAC;SACJ;QACD,OAAO,OAAO,CAAC;;CAChB;AAED,SAAe,QAAQ,CAAC,CAAO,EAAE,SAA6B;;;QAC5D,IAAI,CAAqF,CAAC;QAC1F,MAAM,IAAI,GAAG,SAAS,IAAI,SAAS,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QACnG,IAAI,CAAC,IAAI;YACP,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;QACjD,MAAM,KAAK,GAAG,IAAI,IAAI,EAAE,CAAC;QAEzB,IAAI;YACF,IAAI,IAAI;gBACN,CAAC,GAAG,EAAC,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC,EAAC,CAAC;;gBAE9C,CAAC,GAAG,EAAC,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,MAAA,MAAM,CAAC,CAAC,IAAI,EAAE,mCAAI,IAAI,EAAE,EAAE,EAAE,CAAC,EAAC,CAAC;SAC9D;QAAC,OAAO,CAAM,EAAE;YACf,CAAC,GAAG,EAAC,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE,EAAE,EAAE,EAAE,CAAC,EAAC,CAAC;SACnD;QACD,MAAM,IAAI,GAAG,IAAI,IAAI,EAAE,CAAC;QACxB,aAAa;QACb,CAAC,CAAC,EAAE,GAAG,IAAI,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,IAAI;YACP,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,IAAI,QAAQ,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;QAEjE,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,QAAQ,CAAC;QACxB,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC;QAChB,OAAO,CAAC,CAAC;;CACV;AAED,6BAA6B;AAC7B,MAAM,UAAgB,KAAK,CAAC,EAAU;;QACpC,MAAM,IAAI,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;IAC9C,CAAC;CAAA;AAED,MAAM,UAAgB,UAAU,CAAC,YAA2B;;QAC1D,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,IAAI,IAAI,GAAY,KAAK,CAAC;YAC1B,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,GAAG,IAAI,CAAC;gBACZ,wDAAwD;gBACxD,MAAM,CAAC,kBAAkB,CAAC,CAAC;YAC7B,CAAC,EAAE,GAAG,CAAC,CAAC;YACR,SAAS,KAAK;gBACZ,IAAI,YAAY,EAAE,EAAE;oBAClB,IAAI,GAAG,KAAK,CAAC;oBACb,OAAO,EAAE,CAAC;iBACX;gBACD,IAAI,CAAC,IAAI;oBACP,UAAU,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;YAC1B,CAAC;YACD,KAAK,EAAE,CAAC;QACV,CAAC,CAAC,CAAC;IACL,CAAC;CAAA;AAED,MAAM,UAAU,eAAe,CAAC,WAAkB;IAChD,KAAK,IAAI,CAAC,GAAC,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACxD,IAAI,EAAE,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,WAAW;YACpD,OAAO,IAAI,CAAC;KACf;IACD,OAAO,KAAK,CAAC;AACf,CAAC","sourcesContent":["import * as grok from 'datagrok-api/grok';\nimport * as DG from 'datagrok-api/dg';\nimport {Observable, Subscription} from 'rxjs';\n\nexport const tests: {\n  [key: string]: {\n    tests?: Test[], before?: () => Promise<void>, after?: () => Promise<void>,\n    beforeStatus?: string, afterStatus?: string\n  }\n} = {};\n\nexport let currentCategory: string;\n\nexport namespace assure {\n\n  export function notNull(value: any, name?: string) {\n    if (value == null)\n      throw new Error(`${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    this.options = options;\n    this.test = async (): Promise<any> => {\n      return new Promise(async (resolve, reject) => {\n        let result = '';\n        try {\n          result = await test();\n        } catch (e: any) {\n          reject(e);\n        }\n        resolve(result);\n      });\n    };\n  }\n}\n\nexport async function testEvent<T>(event: Observable<T>, handler: (args: T) => void, trigger: () => void, ms: number = 0): Promise<string> {\n  let sub: Subscription;\n  return new Promise((resolve, reject) => {\n    sub = event.subscribe((args) => {\n      try {\n        handler(args);\n      } catch (e) {\n        reject(e);\n      }\n      sub.unsubscribe();\n      resolve('OK');\n    });\n    setTimeout(() => {\n      sub.unsubscribe();\n      // eslint-disable-next-line prefer-promise-reject-errors\n      reject('timeout');\n    }, ms);\n    trigger();\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/* 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 new Error(`Expected \"${expected}\", got \"${actual}\"`);\n}\n\nexport function expectFloat(actual: number, expected: number, tolerance = 0.001): void {\n  const areEqual = Math.abs(actual - expected) < tolerance;\n  if (!areEqual)\n    throw new Error(`Expected ${expected}, got ${actual} (tolerance = ${tolerance})`);\n}\n\nexport function expectObject(actual: { [key: string]: any }, expected: { [key: string]: any }) {\n  for (const [expectedKey, expectedValue] of Object.entries(expected)) {\n    if (!actual.hasOwnProperty(expectedKey))\n      throw new Error(`Expected property \"${expectedKey}\" not found`);\n\n    const actualValue = actual[expectedKey];\n    if (actualValue instanceof Array && expectedValue instanceof Array)\n      expectArray(actualValue, expectedValue);\n    else if (actualValue instanceof Object && expectedValue instanceof Object)\n      expectObject(actualValue, expectedValue);\n    else if (actualValue != expectedValue)\n      throw new Error(`Expected ${expectedValue} for key ${expectedKey}, got ${actualValue}`);\n  }\n}\n\nexport function expectArray(actual: ArrayLike<any>, expected: ArrayLike<any>) {\n  const actualLength = actual.length;\n  const expectedLength = expected.length;\n\n  if (actualLength != expectedLength) {\n    throw new Error(`Arrays are of different length: actual array length is ${actualLength} ` +\n      `and expected array length is ${expectedLength}`);\n  }\n\n  for (let i = 0; i < actualLength; i++) {\n    if (actual[i] instanceof Array && expected[i] instanceof Array)\n      expectArray(actual[i], expected[i]);\n    else if (actual[i] instanceof Object && expected[i] instanceof Object)\n      expectObject(actual[i], expected[i]);\n    else if (actual[i] != expected[i])\n      throw new Error(`Expected ${expected[i]} at position ${i}, got ${actual[i]}`);\n  }\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  const results: { category?: string, name?: string, success: boolean, result: string, ms: number }[] = [];\n  console.log(`Running tests`);\n  grok.shell.lastError = '';\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    console.log(`Started ${key} category`);\n    try {\n      if (value.before)\n        await value.before();\n    } catch (x: any) {\n      value.beforeStatus = x.toString();\n    }\n    const t = value.tests ?? [];\n    const res = [];\n    for (let i = 0; i < t.length; i++)\n      res.push(await execTest(t[i], options?.test));\n\n    const 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, ms: 0});\n    if (value.beforeStatus)\n      data.push({category: key, name: 'init', result: value.beforeStatus, success: false, ms: 0});\n    results.push(...data);\n  }\n  await delay(1000);\n  if (grok.shell.lastError.length > 0) {\n    results.push({\n      category: 'Unhandled exceptions',\n      name: 'exceptions',\n      result: grok.shell.lastError, success: false, ms: 0\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, ms: number };\n  const skip = predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase()));\n  if (!skip)\n    console.log(`Started ${t.category} ${t.name}`);\n  const start = new Date();\n\n  try {\n    if (skip)\n      r = {success: true, result: 'skipped', ms: 0};\n    else\n      r = {success: true, result: await t.test() ?? 'OK', ms: 0};\n  } catch (x: any) {\n    r = {success: false, result: x.toString(), ms: 0};\n  }\n  const stop = new Date();\n  // @ts-ignore\n  r.ms = stop - start;\n  if (!skip)\n    console.log(`Finished ${t.category} ${t.name} for ${r.ms} ms`);\n\n  r.category = t.category;\n  r.name = t.name;\n  return r;\n}\n\n/* Waits [ms] milliseconds */\nexport async function delay(ms: number) {\n  await new Promise((r) => setTimeout(r, ms));\n}\n\nexport async function awaitCheck(checkHandler: () => boolean): Promise<void> {\n  return new Promise((resolve, reject) => {\n    let stop: boolean = false;\n    setTimeout(() => {\n      stop = true;\n      // eslint-disable-next-line prefer-promise-reject-errors\n      reject('Timeout exceeded');\n    }, 500);\n    function check() {\n      if (checkHandler()) {\n        stop = false;\n        resolve();\n      }\n      if (!stop)\n        setTimeout(check, 50);\n    }\n    check();\n  });\n}\n\nexport function isDialogPresent(dialogTitle:string): boolean {\n  for (let i=0; i < DG.Dialog.getOpenDialogs().length; i++) {\n    if (DG.Dialog.getOpenDialogs()[i].title == dialogTitle)\n      return true;\n  }\n  return false;\n}\n"]}
183
275
 
184
276
  /***/ }),
185
277
 
@@ -1461,7 +1553,7 @@ M V30 BEGIN ATOM
1461
1553
  M V30 1 O 1.0934 -2.1636 0 0
1462
1554
  M V30 2 C 1.8365 -1.4945 0 0 CFG=2
1463
1555
  M V30 3 C 2.8147 -1.7024 0 0
1464
- M V30 4 C 3.3147 -0.8364 0 0 VAL=3
1556
+ M V30 4 C 3.3147 -0.8364 0 0
1465
1557
  M V30 5 O 2.6455 -0.0932 0 0
1466
1558
  M V30 6 C 1.732 -0.5 0 0 CFG=1
1467
1559
  M V30 7 C 0.866 0 0 0
@@ -2673,4 +2765,4 @@ function test() {
2673
2765
  sequencetranslator_test = __webpack_exports__;
2674
2766
  /******/ })()
2675
2767
  ;
2676
- //# 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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACxJR;AACG;AACJ;AAClC;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,eAAe,8DAAoB,CAAC,4CAAU;AAC9C;AACA;AACA;AACA;AACA,QAAQ,2CAAS,IAAI,2CAAS;AAC9B,uBAAuB,iBAAiB;AACxC;AACA;AACA;AACA;AACA,yDAAyD,kBAAkB;AAC3E,8BAA8B,2CAAS,yBAAyB,6BAA6B;AAC7F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;;;;;;;;;;;;;;;;;;ACvS8G;AACrD;AACC;AACnD;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,+CAAa;AAC/C,2CAA2C,2CAAS;AACpD;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA,gBAAgB,+CAAa,uBAAuB,+CAAa;AACjE;AACA,iCAAiC,4DAA0B;AAC3D;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,2CAA2C,2CAAS;AACpD;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;AACA,8CAA8C,qCAAG;AACjD,iDAAiD,qCAAG;AACpD,+CAA+C,qCAAG;AAClD,gCAAgC,qCAAG;AACnC;AACA;AACA;AACA;AACA,6CAA6C,qCAAG;AAChD,2CAA2C,qCAAG;AAC9C,4BAA4B,qCAAG;AAC/B;AACA;AACA,QAAQ,2CAAS;AACjB;AACA,mBAAmB,sEAAe;AAClC,oCAAoC,yDAAuB;AAC3D,mBAAmB,qCAAG,CAAC,yDAAuB,EAAE,qDAAmB;AACnE,yCAAyC,sDAAoB;AAC7D,mBAAmB,qCAAG,CAAC,sDAAoB,EAAE,qDAAmB;AAChE;AACA;AACA;AACA,wCAAwC,6BAA6B;AACrE;;;;;;;;;;;;;;;;;;;;;;;;;;ACxGsC;AAC4B;AAC3D,oBAAoB;AACpB;AACP;AACA;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;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;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,oBAAoB;AACpB,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;AACA;AACA;AACO;AACP;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;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;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;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,+EAAwB;AAChD,qBAAqB,8DAAoB;AAClC;AACP;AACA,4CAA4C;;;;;;;;;;;;;;;;ACxtB5C;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,oBAAoB,sBAAsB;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,0BAA0B;AACtD;AACA,4BAA4B,0BAA0B;AACtD;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;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,uBAAuB,uBAAuB;AAC9C;AACA;AACA,QAAQ;AACR;AACA,oBAAoB,gBAAgB;AACpC;AACA;AACA,wBAAwB,oBAAoB;AAC5C;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;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;AACA;AACA;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;;;;;;;;;;;;;;;;;;;;;AC1X0G;AACkd;AAC5jB;AACO;AACA;AACP;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,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;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,wCAAwC,6BAA6B;AACrE;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,QAAQ,oBAAoB;AAC1E;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA,SAAS;AACT;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;AACA;AACA;AACA,6CAA6C,QAAQ,oBAAoB;AACzE;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA,SAAS;AACT;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,yCAAyC,qCAAG;AAC5C,yCAAyC,qCAAG;AAC5C,oCAAoC,+CAAa,UAAU,2CAAS;AACpE;AACA;AACA;AACA,gBAAgB,qCAAG;AACnB;AACA;AACA,iCAAiC,wDAAsB;AACvD;AACA;AACA,wBAAwB,qBAAqB;AAC7C;AACA;AACA;AACA;AACA;AACA,YAAY,6DAA2B;AACvC;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,oCAAoC,8DAA4B,KAAK;AACrE;AACA,kBAAkB,8DAA4B;AAC9C;AACA,uBAAuB,6EAAgC;AACvD,kBAAkB,wEAA2B;AAC7C;AACA;AACA,oCAAoC,wDAAsB,gCAAgC,0DAAwB;AAClH;AACA,kBAAkB,wDAAsB,SAAS,0DAAwB;AACzE,yBAAyB,6EAAgC;AACzD;AACA,kBAAkB,sEAAyB;AAC3C;AACA;AACA,oCAAoC,mDAAiB,gCAAgC,0DAAwB;AAC7G;AACA,kBAAkB,mDAAiB,SAAS,0DAAwB;AACpE,yBAAyB,wEAA2B;AACpD,uBAAuB,sEAAyB;AAChD,uBAAuB,4DAAe;AACtC;AACA,kBAAkB,uDAAU;AAC5B;AACA;AACA,oCAAoC,8DAA4B,gCAAgC,kDAAgB;AAChH;AACA,kBAAkB,8DAA4B,SAAS,kDAAgB;AACvE;AACA,uBAAuB,kFAAqC;AAC5D,qBAAqB,gFAAmC;AACxD,kBAAkB,mEAAsB;AACxC;AACA;AACA,oCAAoC,wDAAsB,gCAAgC,qDAAmB;AAC7G;AACA,kBAAkB,wDAAsB,SAAS,qDAAmB;AACpE,yBAAyB,wEAA2B;AACpD;AACA,qBAAqB,oEAAuB;AAC5C,kBAAkB,iEAAoB;AACtC;AACA;AACA,oCAAoC,sDAAoB;AACxD;AACA,kBAAkB,sDAAoB,SAAS,qDAAmB;AAClE,yBAAyB,sEAAyB;AAClD,uBAAuB,oEAAuB;AAC9C;AACA,kBAAkB,+DAAkB;AACpC;AACA;AACA,oCAAoC,mDAAiB,gCAAgC,qDAAmB;AACxG;AACA,kBAAkB,mDAAiB,SAAS,qDAAmB;AAC/D,yBAAyB,mEAAsB;AAC/C,uBAAuB,iEAAoB;AAC3C,qBAAqB,+DAAkB;AACvC,kBAAkB,4DAAe;AACjC;AACA,kBAAkB,uDAAU;AAC5B;AACA;AACA,oCAAoC,mDAAiB;AACrD;AACA,kBAAkB,mDAAiB;AACnC,yBAAyB,8DAAiB;AAC1C;AACA,uBAAuB,4DAAe;AACtC,kBAAkB,uDAAU;AAC5B;AACA;AACA,oCAAoC,yDAAuB;AAC3D;AACA,kBAAkB,yDAAuB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;AC5RA,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;AACd;AACvD,4EAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,wBAAwB,uEAAoB;AAC3E,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,wBAAwB,uEAAoB;AAC3E,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,0BAA0B,uEAAoB;AAC7E,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,wBAAwB,uEAAoB;AAC3E,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,wBAAwB,uEAAoB;AAC3E,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,wBAAwB,uEAAoB;AAC3E,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,sBAAsB,uEAAoB;AACzE,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,4BAA4B,uEAAoB;AAC/E,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,gCAAgC,uEAAoB;AACnF,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR,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,sDAAsD,uEAAoB;AACzG,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,+CAA+C,uEAAoB;AAClG,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;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;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;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;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;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;AACA;AACA;AACA,QAAQ;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;AACR,CAAC;;;;;;;;;;;ACjbD;;;;;;;;;;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 \"grok\"","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"]}","import { lcmsToGcrs } from './map';\nimport * as DG from 'datagrok-api/dg';\nimport { delimiter } from './map';\n//name: gcrsToLcms\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: LCMS}\nexport function gcrsToLcms(sequence) {\n    const df = DG.DataFrame.fromCsv(lcmsToGcrs);\n    const arr1 = df.getCol('GCRS').toList();\n    const arr2 = df.getCol('LCMS').toList();\n    const obj = {};\n    arr1.forEach((element, index) => obj[element] = arr2[index]);\n    obj[delimiter] = delimiter;\n    // for (let i = 0; i < arr1.length; i++) {\n    //   arr1[i] = arr1[i].replace('(', '\\\\(');\n    //   arr1[i] = arr1[i].replace(')', '\\\\)');\n    // }\n    // const regExp = new RegExp('(' + arr1.join('|') + ')', 'g');\n    // let r1 = sequence.replace(regExp, function(code) {return obj[code];});\n    const codes = arr1.concat(delimiter).sort(function (a, b) { return b.length - a.length; });\n    let i = 0;\n    let r1 = '';\n    while (i < sequence.length) {\n        const matchedCode = codes.find((c) => c == sequence.slice(i, i + c.length));\n        r1 += obj[sequence.slice(i, i + matchedCode.length)];\n        i += matchedCode.length;\n    }\n    while (r1.indexOf('//') != -1)\n        r1 = r1.replace('//', '/');\n    return r1;\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, delimiter } from './map';\nimport { isValidSequence } from './sequence-codes-tools';\nimport { getNucleotidesMol } from './mol-transformations';\nexport function sequenceToMolV3000(sequence, inverted = false, oclRender = false, format) {\n    const obj = getObjectWithCodesAndSmiles(sequence, format);\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).concat(delimiter);\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            if (!(i < codesList.length - 1 && links.includes(codesList[i + 1])))\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);\n}\nexport function sequenceToSmiles(sequence, inverted = false, format) {\n    const obj = getObjectWithCodesAndSmiles(sequence, format);\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).concat(delimiter);\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, format) {\n    const obj = {};\n    if (format == null) {\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    }\n    else {\n        for (const technology of Object.keys(map[format])) {\n            for (const code of Object.keys(map[format][technology]))\n                obj[code] = map[format][technology][code].SMILES;\n        }\n    }\n    obj[delimiter] = '';\n    // TODO: create object based from synthesizer type to avoid key(codes) duplicates\n    const output = isValidSequence(sequence, format);\n    if (output.synthesizer.includes(SYNTHESIZERS.MERMADE_12))\n        obj['g'] = map[SYNTHESIZERS.MERMADE_12][TECHNOLOGIES.SI_RNA]['g'].SMILES;\n    else if (output.synthesizer.includes(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","import * as DG from 'datagrok-api/dg';\nimport { getAllCodesOfSynthesizer } from './sequence-codes-tools';\nexport const delimiter = ';';\nexport 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    LCMS: 'LCMS',\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_MOL_WEIGHT: 'Salt 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            's': {\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        'Others': {},\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    // 'LCMS': {\n    //   'For 2\\'-OMe and 2\\'-F modified siRNA': {\n};\nexport const lcmsToGcrs = `LCMS, GCRS\nA, A\nC, C\n/5mC/, (5m)C\nG, G\nT, T\nrA, rA\nrC, rC\nrG, rG\nrU, rU\nmA, mA\nmC, mC\n/5mmC/, (5m)mC\nmG, mG\nmU, mU\nfA, fA\nfC, fC\n/5mfC/, (5m)fC\nfG, fG\nfU, fU\n/afA/, afA\n/afC/, afC\n/afG/, afG\n/afU/, afU\n+A, lna A\n+C, lna C\n+G, lna G\n+T, lna T\n/moeA/, moeA\n/moeC/, moeC\n/5mmoeC/, (5m)moeC\n/moeG/, moeG\n/moeT/, moeT\n/moeU/, moeU\n/xA/, Anp\n/xC/, Cnp\n/x5mC/, (5m)Cnp\n/xG/, Gnp\n/xT/, Tnp\n/xrA/, rAnp\n/xrC/, rCnp\n/xrG/, rGnp\n/xrU/, rUnp\n/xmA/, mAnp\n/xmC/, mCnp\n/x5mmC/, (5m)mCnp\n/xmG/, mGnp\n/xmU/, mUnp\n/xfA/, fAnp\n/xfC/, fCnp\n/xfG/, fGnp\n/xfT/, fTnp\n/xfU/, fUnp\n/xafA/, afAnp\n/xafC/, afCnp\n/xafG/, afGnp\n/xafU/, afUnp\n/xeA/, eAnp\n/xeC/, eCnp\n/xeG/, eGnp\n/xeU/, eUnp\n/xmoeA/, moeAnp\n/xmoeC/, moeCnp\n/x5mmoeC/, (5m)moeCnp\n/xmoeG/, moeGnp\n/xmoeU/, moeUnp\n/UNA-A/, (UNA-A)\n/UNA-C/, (UNA-C)\n/UNA-G/, (UNA-G)\n/UNA-T/, (UNA-T)\n/UNA-U/, (UNA-U)\n/GNA-A/, (GNA-A)\n/GNA-C/, (GNA-C)\n/GNA-G/, (GNA-G)\n/GNA-T/, (GNA-T)\n/GNA-U/, (GNA-U)\n/5CholTEG/, (5-CholTEG)\n/3CholTEG/, (TEGChol-3)\n/Toco/, Toco\n/Palm/, Palm\n/GalNAc/, GalNAc\n/GalNAc2/, GalNAc2\n/GalNAc3/, GalNAc3\n/GalNAc6/, GalNAc6\n/GalNAc7/, GalNAc7\n/GalNAc9/, GalNAc9\n/GalNAc14/, GalNAc14\n/NAG37/, NAG37\n/HEG/, (HEG)\n/TEG/, (TEG)\n/AmmC6/, (NHC6)\n/AmmC7/, (NHC7)\n/AmmC12/, (NHC12)\n/invAb/, (invabasic)\n/invdT/, (invdT)\n/VPmU/, (vinu)\n*, ps\n/2-C16U/, 2-C16U \n/2-C18w9U/, 2-C18w9U\n/JDi-Palm/, JDi-Palm\n/J2-CONC16U/, J2-CONC16U\n/J2-C3NC16U/, J2-C3NC16U\n/J-C15Ada/, J-C15Ada\n/J-2C15AdaU/, J-2C15AdaU\n/J-C16NC6/, J-C16NC6\n/R2-C6NH-U/, R2-C6NH-U\n/J-M1/, J-M1\n/J-B1/, J-B1\n/J-B2/, J-B2\n/J-M2/, J-M2\n/2-C16C/, 2-C16C\n/2-C16A/, 2-C16A\n/2-C16G/, 2-C16G\n/R2-C6NH-G/, R2-C6NH-G\n/R2-C6NH-C/, R2-C6NH-C\n/J2-CONC16A/, J2-CONC16A\n/J2-CONC16C/, J2-CONC16C\n/J2-CONC16G/, J2-CONC16G\n/J2-C15AdaC/, J2-C15AdaC\n/J2-M2U/, J2-M2U\n/J2-B2U/, J2-B2U\n/J2-C3NC16C/, J2-C3NC16C\n/J2-C3NC16G/, J2-C3NC16G\n/R2-C6NH-A/, R2-C6NH-A\n/J2-C15AdaA/, J2-C15AdaA\n/J2-C3NC16A/, J2-C3NC16A\n/J-C5-SER-1/, J-C5-SER-1\n/J-C16-SER-1/, J-C16-SER-1\n/J-A2/, J-A2\n/J-A1/, J-A1\n/J2-C15AdaG/, J2-C15AdaG\n/J-C16NAsp/, J-C16NAsp\n/J2-C16NC6U/, J2-C16NC6U\n/J-C5-REBO-1/, J-C5-REBO-1\n/J-C16-REBO-1/, J-C16-REBO-1\n/J-C16-IND-1/, J-C16-IND-1\n/J-C5-IND-1/, J-C5-IND-1\n/J-1C15Ada-2Man/, J-1C15Ada-2Man\n/JG-1C15Ada-23DiMan/, JG-1C15Ada-2,3DiMan\n/J-TriManPC/, J-TriManPC\n/J-triManPO/, J-triManPO\n/J-A4/, J-A4\n/J-Ara-1/, J-Ara-1\n/J-Ara-2/, J-Ara-2\n/J-AcCS/, J-AcCS\n/J-CbCS/, J-CbCS\n/J-MtCD/, J-MtCD`;\nfunction differenceOfTwoArrays(a, b) {\n    return a.filter((x) => !b.includes(x));\n}\nconst codesWithSmiles = getAllCodesOfSynthesizer(SYNTHESIZERS.GCRS);\nconst allGcrsCodes = DG.DataFrame.fromCsv(lcmsToGcrs).getCol('GCRS').toList();\nexport const gcrsCodesWithoutSmiles = differenceOfTwoArrays(allGcrsCodes, codesWithSmiles);\nfor (const e of gcrsCodesWithoutSmiles)\n    map[SYNTHESIZERS.GCRS]['Others'][e] = { 'SMILES': '' };\n","const 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) {\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);\n}\nexport function linkV3000(molBlocks, twoChains = false, useChirality = true) {\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 xShift = 0;\n    if (twoChains && 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        if (twoChains) {\n            const xShiftRight = Math.min(...coordinates.x);\n            const yShift = i == 0 ? Math.min(...coordinates.y) - 1 : Math.max(...coordinates.y) + 1;\n            for (let j = 0; j < coordinates.x.length; j++)\n                coordinates.x[j] -= xShiftRight;\n            for (let j = 0; j < coordinates.y.length; j++)\n                coordinates.y[j] -= yShift;\n        }\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 || twoChains) {\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 = twoChains ? 0 : xShift - coordinates.x[0];\n                let coordinate = twoChains ?\n                    Math.round(10000 * coordinates.x[j]) / 10000 :\n                    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 = twoChains ?\n                    Math.round(10000 * coordinates.y[j]) / 10000 :\n                    Math.round(10000 * (parseFloat(molBlocks[i].substring(index, indexEnd)))) / 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 += twoChains ? numbers.natom : numbers.natom - 1;\n        nbond += numbers.nbond;\n        xShift += twoChains ? 0 : coordinates.x[numbers.natom - 1] - coordinates.x[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    //} 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    twoChains ? 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    if (useChirality) {\n        macroMolBlock += 'M  V30 BEGIN COLLECTION\\n';\n        macroMolBlock += collectionBlock;\n        macroMolBlock += 'M  V30 END COLLECTION\\n';\n    }\n    else\n        macroMolBlock = macroMolBlock.replace(/ CFG=\\d/g, ' ');\n    macroMolBlock += 'M  V30 END CTAB\\n';\n    macroMolBlock += 'M  END';\n    return macroMolBlock;\n}\nfunction rotateNucleotidesV3000(molecule) {\n    // @ts-ignore\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    // @ts-ignore\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 { map, SYNTHESIZERS, TECHNOLOGIES, MODIFICATIONS, delimiter, gcrsCodesWithoutSmiles } from './map';\nimport { asoGapmersNucleotidesToBioSpring, asoGapmersNucleotidesToGcrs, asoGapmersBioSpringToNucleotides, asoGapmersBioSpringToGcrs, asoGapmersGcrsToNucleotides, asoGapmersGcrsToBioSpring, gcrsToMermade12, siRnaNucleotideToBioSpringSenseStrand, siRnaNucleotideToAxolabsSenseStrand, siRnaNucleotidesToGcrs, siRnaBioSpringToNucleotides, siRnaBioSpringToAxolabs, siRnaBioSpringToGcrs, siRnaAxolabsToNucleotides, siRnaAxolabsToBioSpring, siRnaAxolabsToGcrs, siRnaGcrsToNucleotides, siRnaGcrsToBioSpring, siRnaGcrsToAxolabs, gcrsToNucleotides, gcrsToLcms } from './converters';\nconst noTranslationTableAvailable = 'No translation table available';\nexport const undefinedInputSequence = 'Type of input sequence is undefined';\nexport function getFormat(sequence) {\n    const possibleSynthesizers = getListOfPossibleSynthesizersByFirstMatchedCode(sequence);\n    if (possibleSynthesizers.length == 0)\n        return 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 possibleSynthesizers[0];\n    const possibleTechnologies = getListOfPossibleTechnologiesByFirstMatchedCode(sequence, possibleSynthesizers[0]);\n    if (possibleTechnologies.length == 0)\n        return 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 possibleSynthesizers[0];\n}\nfunction sortByStringLengthInDescendingOrder(array) {\n    return array.sort(function (a, b) { return b.length - a.length; });\n}\nexport function isValidSequence(sequence, format) {\n    const possibleSynthesizers = format == null ?\n        getListOfPossibleSynthesizersByFirstMatchedCode(sequence) :\n        [format];\n    // if (possibleSynthesizers.length > 1) {\n    //   const synthesizer = ui.choiceInput('Choose synthesizer from list: ', possibleSynthesizers[0],\n    //  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    // } else if (possibleSynthesizers.length == 0)\n    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 = sortByStringLengthInDescendingOrder(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,\n            technology: null,\n        };\n    }\n    const possibleTechnologies = getListOfPossibleTechnologiesByFirstMatchedCode(sequence, possibleSynthesizers[0]);\n    // if (possibleTechnologies.length > 1) {\n    //   const technology = ui.choiceInput('Choose technology from list: ', possibleTechnologies[0],\n    // 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    // } else if (possibleTechnologies.length == 0)\n    // if (possibleTechnologies.length == 0)\n    //   return {indexOfFirstNotValidChar: 0, synthesizer: [possibleSynthesizers[3]], technology: null};\n    outputIndex = 0;\n    // possibleTechnologies.forEach((technology: string) => {\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    //     ) {\n    //       outputIndex++;\n    //       break;\n    //     }\n    //     outputIndex += matchedCode.length;\n    //   }\n    // });\n    return {\n        indexOfFirstNotValidChar: indexOfFirstNotValidChar,\n        synthesizer: possibleSynthesizers,\n        technology: [possibleTechnologies[outputIndex]],\n    };\n}\nexport function 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)).concat(delimiter);\n}\nfunction getListOfPossibleSynthesizersByFirstMatchedCode(sequence) {\n    let synthesizers = [];\n    Object.keys(map).forEach((synthesizer) => {\n        let codes = sortByStringLengthInDescendingOrder(getAllCodesOfSynthesizer(synthesizer));\n        if (synthesizer == 'Janssen GCRS Codes')\n            codes = codes.concat(gcrsCodesWithoutSmiles);\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 (gcrsCodesWithoutSmiles.some((s) => s == sequence.slice(start, start + s.length)))\n            synthesizers = ['Janssen GCRS Codes'];\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.includes(SYNTHESIZERS.RAW_NUCLEOTIDES)) { //&& output.technology!.includes(TECHNOLOGIES.DNA)) {\n        return {\n            type: SYNTHESIZERS.RAW_NUCLEOTIDES,\n            Nucleotides: sequence,\n            BioSpring: asoGapmersNucleotidesToBioSpring(sequence),\n            GCRS: asoGapmersNucleotidesToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.BIOSPRING) && output.technology.includes(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.includes(SYNTHESIZERS.GCRS) && output.technology.includes(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            LCMS: gcrsToLcms(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.RAW_NUCLEOTIDES) && output.technology.includes(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.includes(SYNTHESIZERS.BIOSPRING) && output.technology.includes(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.includes(SYNTHESIZERS.AXOLABS)) {\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.includes(SYNTHESIZERS.GCRS) && output.technology.includes(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            LCMS: gcrsToLcms(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.GCRS)) {\n        return {\n            type: SYNTHESIZERS.GCRS,\n            Nucleotides: gcrsToNucleotides(sequence),\n            GCRS: sequence,\n            Mermade12: gcrsToMermade12(sequence),\n            LCMS: gcrsToLcms(sequence),\n        };\n    }\n    if (output.synthesizer.includes(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';\nimport { SYNTHESIZERS } from '../structures-works/map';\ncategory('sequence-translator', () => {\n    // test('AGGTCCTCTTGACTTAGGCC', async () => {\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', false, SYNTHESIZERS.RAW_NUCLEOTIDES), expected);\n    // });\n    // test('invabasic/galnac1', async () => {\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)', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('invabasic/galnac2', async () => {\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)', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('invabasic/galnac3', async () => {\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)', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('invabasic/galnac4', async () => {\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)', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), expected);\n    }));\n    // test('(invabasic)sucuCfuUf', async () => {\n    //   const expected =\n    //   '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', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('(invabasic)sAfgcugUf', async () => {\n    //   const expected =\n    //   '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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), expected);\n    }));\n    // test('(invabasic)scususu(GalNAc-2-JNJ)', async () => {\n    //   const expected =\n    //   '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)', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), expected);\n    }));\n    // test('(invabasic)scsgguGfcAfAfCfucuauucuga', async () => {\n    //   const expected =\n    //   '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', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('(invabasic)scsaacUfcUfAfUfucuggacuua', async () => {\n    //   const expected =\n    //   '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', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('(invabasic)sasacuCfuAfUfUfcuggacuuua', async () => {\n    //   const expected =\n    //   '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', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('(invabasic)usAfscug(invabasic)(GalNAc-2-JNJ)', async () => {\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)', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('(invabasic)sasuaaCfcUf(GalNAc-2-JNJ)', async () => {\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)', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('(invabasic)sasuaaCfcUfCfUfuguaguuaua(GalNAc-2-JNJ)', async () => {\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)', false, SYNTHESIZERS.AXOLABS),\n    //     expected);\n    // });\n    // test('(invabasic)scsaucacguUfGfCfagccgucuua(invabasic)(GalNAc-2-JNJ)', async () => {\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)',\n    //     false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('(invabasic)susguuUfgCfCfUfacaucuacua(GalNAc-2-JNJ)', async () => {\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)', false, SYNTHESIZERS.AXOLABS),\n    //     expected);\n    // });\n});\n","module.exports = DG;","module.exports = grok;","// 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":""}
2768
+ //# 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;AACJ;AAC/B;AACA;AACA;AACP;AACA;AACA;AACA,+BAA+B,+BAA+B;AAC9D;AACA;AACA,CAAC,wBAAwB;AAClB;AACP;AACA;AACA;AACA;AACA,wEAAwE;AACxE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,SAAS;AACT,KAAK;AACL;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,qCAAqC,SAAS,UAAU,OAAO;AAC/D;AACO;AACP;AACA;AACA,oCAAoC,SAAS,QAAQ,QAAQ,eAAe,UAAU;AACtF;AACO;AACP;AACA;AACA,kDAAkD,YAAY;AAC9D;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,eAAe,UAAU,YAAY,QAAQ,YAAY;AACjG;AACA;AACO;AACP;AACA;AACA;AACA,kFAAkF,cAAc;AAChG,4CAA4C,eAAe;AAC3D;AACA,oBAAoB,kBAAkB;AACtC;AACA;AACA;AACA;AACA;AACA,wCAAwC,aAAa,cAAc,EAAE,QAAQ,UAAU;AACvF;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,QAAQ,8DAAoB;AAC5B;AACA;AACA;AACA;AACA;AACA,mCAAmC,KAAK;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,cAAc;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,+EAA+E;AAC3G;AACA,4BAA4B,gFAAgF;AAC5G;AACA;AACA;AACA,YAAY,qEAA2B;AACvC;AACA;AACA;AACA,wBAAwB,8DAAoB;AAC5C,aAAa;AACb;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,YAAY,EAAE,OAAO;AACxD;AACA;AACA;AACA,sBAAsB;AACtB;AACA,sBAAsB;AACtB;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA,oCAAoC,YAAY,EAAE,QAAQ,MAAM,MAAM;AACtE;AACA;AACA;AACA,KAAK;AACL;AACA;AACO;AACP;AACA;AACA,KAAK;AACL;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,KAAK;AACL;AACO;AACP,oBAAoB,IAAI,kEAAwB,WAAW;AAC3D,YAAY,kEAAwB;AACpC;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC9OR;AACG;AACJ;AAClC;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,eAAe,8DAAoB,CAAC,4CAAU;AAC9C;AACA;AACA;AACA;AACA,QAAQ,2CAAS,IAAI,2CAAS;AAC9B,uBAAuB,iBAAiB;AACxC;AACA;AACA;AACA;AACA,yDAAyD,kBAAkB;AAC3E,8BAA8B,2CAAS,yBAAyB,6BAA6B;AAC7F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;;;;;;;;;;;;;;;;;;ACvS8G;AACrD;AACC;AACnD;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,+CAAa;AAC/C,2CAA2C,2CAAS;AACpD;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA,gBAAgB,+CAAa,uBAAuB,+CAAa;AACjE;AACA,iCAAiC,4DAA0B;AAC3D;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,2CAA2C,2CAAS;AACpD;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;AACA,8CAA8C,qCAAG;AACjD,iDAAiD,qCAAG;AACpD,+CAA+C,qCAAG;AAClD,gCAAgC,qCAAG;AACnC;AACA;AACA;AACA;AACA,6CAA6C,qCAAG;AAChD,2CAA2C,qCAAG;AAC9C,4BAA4B,qCAAG;AAC/B;AACA;AACA,QAAQ,2CAAS;AACjB;AACA,mBAAmB,sEAAe;AAClC,oCAAoC,yDAAuB;AAC3D,mBAAmB,qCAAG,CAAC,yDAAuB,EAAE,qDAAmB;AACnE,yCAAyC,sDAAoB;AAC7D,mBAAmB,qCAAG,CAAC,sDAAoB,EAAE,qDAAmB;AAChE;AACA;AACA;AACA,wCAAwC,6BAA6B;AACrE;;;;;;;;;;;;;;;;;;;;;;;;;;ACxGsC;AAC4B;AAC3D,oBAAoB;AACpB;AACP;AACA;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;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;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,oBAAoB;AACpB,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;AACA;AACA;AACO;AACP;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;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;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;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,+EAAwB;AAChD,qBAAqB,8DAAoB;AAClC;AACP;AACA,4CAA4C;;;;;;;;;;;;;;;;ACxtB5C;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,oBAAoB,sBAAsB;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,0BAA0B;AACtD;AACA,4BAA4B,0BAA0B;AACtD;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;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,uBAAuB,uBAAuB;AAC9C;AACA;AACA,QAAQ;AACR;AACA,oBAAoB,gBAAgB;AACpC;AACA;AACA,wBAAwB,oBAAoB;AAC5C;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;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;AACA;AACA;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;;;;;;;;;;;;;;;;;;;;;AC1X0G;AACkd;AAC5jB;AACO;AACA;AACP;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,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;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,wCAAwC,6BAA6B;AACrE;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,QAAQ,oBAAoB;AAC1E;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA,SAAS;AACT;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;AACA;AACA;AACA,6CAA6C,QAAQ,oBAAoB;AACzE;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA,SAAS;AACT;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,yCAAyC,qCAAG;AAC5C,yCAAyC,qCAAG;AAC5C,oCAAoC,+CAAa,UAAU,2CAAS;AACpE;AACA;AACA;AACA,gBAAgB,qCAAG;AACnB;AACA;AACA,iCAAiC,wDAAsB;AACvD;AACA;AACA,wBAAwB,qBAAqB;AAC7C;AACA;AACA;AACA;AACA;AACA,YAAY,6DAA2B;AACvC;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,oCAAoC,8DAA4B,KAAK;AACrE;AACA,kBAAkB,8DAA4B;AAC9C;AACA,uBAAuB,6EAAgC;AACvD,kBAAkB,wEAA2B;AAC7C;AACA;AACA,oCAAoC,wDAAsB,gCAAgC,0DAAwB;AAClH;AACA,kBAAkB,wDAAsB,SAAS,0DAAwB;AACzE,yBAAyB,6EAAgC;AACzD;AACA,kBAAkB,sEAAyB;AAC3C;AACA;AACA,oCAAoC,mDAAiB,gCAAgC,0DAAwB;AAC7G;AACA,kBAAkB,mDAAiB,SAAS,0DAAwB;AACpE,yBAAyB,wEAA2B;AACpD,uBAAuB,sEAAyB;AAChD,uBAAuB,4DAAe;AACtC;AACA,kBAAkB,uDAAU;AAC5B;AACA;AACA,oCAAoC,8DAA4B,gCAAgC,kDAAgB;AAChH;AACA,kBAAkB,8DAA4B,SAAS,kDAAgB;AACvE;AACA,uBAAuB,kFAAqC;AAC5D,qBAAqB,gFAAmC;AACxD,kBAAkB,mEAAsB;AACxC;AACA;AACA,oCAAoC,wDAAsB,gCAAgC,qDAAmB;AAC7G;AACA,kBAAkB,wDAAsB,SAAS,qDAAmB;AACpE,yBAAyB,wEAA2B;AACpD;AACA,qBAAqB,oEAAuB;AAC5C,kBAAkB,iEAAoB;AACtC;AACA;AACA,oCAAoC,sDAAoB;AACxD;AACA,kBAAkB,sDAAoB,SAAS,qDAAmB;AAClE,yBAAyB,sEAAyB;AAClD,uBAAuB,oEAAuB;AAC9C;AACA,kBAAkB,+DAAkB;AACpC;AACA;AACA,oCAAoC,mDAAiB,gCAAgC,qDAAmB;AACxG;AACA,kBAAkB,mDAAiB,SAAS,qDAAmB;AAC/D,yBAAyB,mEAAsB;AAC/C,uBAAuB,iEAAoB;AAC3C,qBAAqB,+DAAkB;AACvC,kBAAkB,4DAAe;AACjC;AACA,kBAAkB,uDAAU;AAC5B;AACA;AACA,oCAAoC,mDAAiB;AACrD;AACA,kBAAkB,mDAAiB;AACnC,yBAAyB,8DAAiB;AAC1C;AACA,uBAAuB,4DAAe;AACtC,kBAAkB,uDAAU;AAC5B;AACA;AACA,oCAAoC,yDAAuB;AAC3D;AACA,kBAAkB,yDAAuB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;AC5RA,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;AACd;AACvD,4EAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,wBAAwB,uEAAoB;AAC3E,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,wBAAwB,uEAAoB;AAC3E,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,0BAA0B,uEAAoB;AAC7E,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,wBAAwB,uEAAoB;AAC3E,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,wBAAwB,uEAAoB;AAC3E,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,wBAAwB,uEAAoB;AAC3E,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,sBAAsB,uEAAoB;AACzE,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,4BAA4B,uEAAoB;AAC/E,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB,gCAAgC,uEAAoB;AACnF,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR,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,sDAAsD,uEAAoB;AACzG,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,+CAA+C,uEAAoB;AAClG,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;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;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;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;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;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;AACA;AACA;AACA,QAAQ;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;AACR,CAAC;;;;;;;;;;;ACjbD;;;;;;;;;;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 \"grok\"","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';\nimport * as DG from 'datagrok-api/dg';\nexport const tests = {};\nexport let currentCategory;\nexport var assure;\n(function (assure) {\n    function notNull(value, name) {\n        if (value == null)\n            throw new Error(`${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;\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        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                    result = yield test();\n                }\n                catch (e) {\n                    reject(e);\n                }\n                resolve(result);\n            }));\n        });\n    }\n}\nexport function testEvent(event, handler, trigger, ms = 0) {\n    return __awaiter(this, void 0, void 0, function* () {\n        let sub;\n        return new Promise((resolve, reject) => {\n            sub = event.subscribe((args) => {\n                try {\n                    handler(args);\n                }\n                catch (e) {\n                    reject(e);\n                }\n                sub.unsubscribe();\n                resolve('OK');\n            });\n            setTimeout(() => {\n                sub.unsubscribe();\n                // eslint-disable-next-line prefer-promise-reject-errors\n                reject('timeout');\n            }, ms);\n            trigger();\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/* Tests two objects for equality, throws an exception if they are not equal. */\nexport function expect(actual, expected) {\n    if (actual !== expected)\n        throw new Error(`Expected \"${expected}\", got \"${actual}\"`);\n}\nexport function expectFloat(actual, expected, tolerance = 0.001) {\n    const areEqual = Math.abs(actual - expected) < tolerance;\n    if (!areEqual)\n        throw new Error(`Expected ${expected}, got ${actual} (tolerance = ${tolerance})`);\n}\nexport function expectObject(actual, expected) {\n    for (const [expectedKey, expectedValue] of Object.entries(expected)) {\n        if (!actual.hasOwnProperty(expectedKey))\n            throw new Error(`Expected property \"${expectedKey}\" not found`);\n        const actualValue = actual[expectedKey];\n        if (actualValue instanceof Array && expectedValue instanceof Array)\n            expectArray(actualValue, expectedValue);\n        else if (actualValue instanceof Object && expectedValue instanceof Object)\n            expectObject(actualValue, expectedValue);\n        else if (actualValue != expectedValue)\n            throw new Error(`Expected ${expectedValue} for key ${expectedKey}, got ${actualValue}`);\n    }\n}\nexport function expectArray(actual, expected) {\n    const actualLength = actual.length;\n    const expectedLength = expected.length;\n    if (actualLength != expectedLength) {\n        throw new Error(`Arrays are of different length: actual array length is ${actualLength} ` +\n            `and expected array length is ${expectedLength}`);\n    }\n    for (let i = 0; i < actualLength; i++) {\n        if (actual[i] instanceof Array && expected[i] instanceof Array)\n            expectArray(actual[i], expected[i]);\n        else if (actual[i] instanceof Object && expected[i] instanceof Object)\n            expectObject(actual[i], expected[i]);\n        else if (actual[i] != expected[i])\n            throw new Error(`Expected ${expected[i]} at position ${i}, got ${actual[i]}`);\n    }\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        const results = [];\n        console.log(`Running tests`);\n        grok.shell.lastError = '';\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            console.log(`Started ${key} category`);\n            try {\n                if (value.before)\n                    yield value.before();\n            }\n            catch (x) {\n                value.beforeStatus = x.toString();\n            }\n            const t = (_a = value.tests) !== null && _a !== void 0 ? _a : [];\n            const 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            const 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, ms: 0 });\n            if (value.beforeStatus)\n                data.push({ category: key, name: 'init', result: value.beforeStatus, success: false, ms: 0 });\n            results.push(...data);\n        }\n        yield delay(1000);\n        if (grok.shell.lastError.length > 0) {\n            results.push({\n                category: 'Unhandled exceptions',\n                name: 'exceptions',\n                result: grok.shell.lastError, success: false, ms: 0\n            });\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        const skip = predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase()));\n        if (!skip)\n            console.log(`Started ${t.category} ${t.name}`);\n        const start = new Date();\n        try {\n            if (skip)\n                r = { success: true, result: 'skipped', ms: 0 };\n            else\n                r = { success: true, result: (_a = yield t.test()) !== null && _a !== void 0 ? _a : 'OK', ms: 0 };\n        }\n        catch (x) {\n            r = { success: false, result: x.toString(), ms: 0 };\n        }\n        const stop = new Date();\n        // @ts-ignore\n        r.ms = stop - start;\n        if (!skip)\n            console.log(`Finished ${t.category} ${t.name} for ${r.ms} ms`);\n        r.category = t.category;\n        r.name = t.name;\n        return r;\n    });\n}\n/* Waits [ms] milliseconds */\nexport function delay(ms) {\n    return __awaiter(this, void 0, void 0, function* () {\n        yield new Promise((r) => setTimeout(r, ms));\n    });\n}\nexport function awaitCheck(checkHandler) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return new Promise((resolve, reject) => {\n            let stop = false;\n            setTimeout(() => {\n                stop = true;\n                // eslint-disable-next-line prefer-promise-reject-errors\n                reject('Timeout exceeded');\n            }, 500);\n            function check() {\n                if (checkHandler()) {\n                    stop = false;\n                    resolve();\n                }\n                if (!stop)\n                    setTimeout(check, 50);\n            }\n            check();\n        });\n    });\n}\nexport function isDialogPresent(dialogTitle) {\n    for (let i = 0; i < DG.Dialog.getOpenDialogs().length; i++) {\n        if (DG.Dialog.getOpenDialogs()[i].title == dialogTitle)\n            return true;\n    }\n    return false;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.js","sourceRoot":"","sources":["test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as grok from 'datagrok-api/grok';\nimport * as DG from 'datagrok-api/dg';\nimport {Observable, Subscription} from 'rxjs';\n\nexport const tests: {\n  [key: string]: {\n    tests?: Test[], before?: () => Promise<void>, after?: () => Promise<void>,\n    beforeStatus?: string, afterStatus?: string\n  }\n} = {};\n\nexport let currentCategory: string;\n\nexport namespace assure {\n\n  export function notNull(value: any, name?: string) {\n    if (value == null)\n      throw new Error(`${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    this.options = options;\n    this.test = async (): Promise<any> => {\n      return new Promise(async (resolve, reject) => {\n        let result = '';\n        try {\n          result = await test();\n        } catch (e: any) {\n          reject(e);\n        }\n        resolve(result);\n      });\n    };\n  }\n}\n\nexport async function testEvent<T>(event: Observable<T>, handler: (args: T) => void, trigger: () => void, ms: number = 0): Promise<string> {\n  let sub: Subscription;\n  return new Promise((resolve, reject) => {\n    sub = event.subscribe((args) => {\n      try {\n        handler(args);\n      } catch (e) {\n        reject(e);\n      }\n      sub.unsubscribe();\n      resolve('OK');\n    });\n    setTimeout(() => {\n      sub.unsubscribe();\n      // eslint-disable-next-line prefer-promise-reject-errors\n      reject('timeout');\n    }, ms);\n    trigger();\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/* 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 new Error(`Expected \"${expected}\", got \"${actual}\"`);\n}\n\nexport function expectFloat(actual: number, expected: number, tolerance = 0.001): void {\n  const areEqual = Math.abs(actual - expected) < tolerance;\n  if (!areEqual)\n    throw new Error(`Expected ${expected}, got ${actual} (tolerance = ${tolerance})`);\n}\n\nexport function expectObject(actual: { [key: string]: any }, expected: { [key: string]: any }) {\n  for (const [expectedKey, expectedValue] of Object.entries(expected)) {\n    if (!actual.hasOwnProperty(expectedKey))\n      throw new Error(`Expected property \"${expectedKey}\" not found`);\n\n    const actualValue = actual[expectedKey];\n    if (actualValue instanceof Array && expectedValue instanceof Array)\n      expectArray(actualValue, expectedValue);\n    else if (actualValue instanceof Object && expectedValue instanceof Object)\n      expectObject(actualValue, expectedValue);\n    else if (actualValue != expectedValue)\n      throw new Error(`Expected ${expectedValue} for key ${expectedKey}, got ${actualValue}`);\n  }\n}\n\nexport function expectArray(actual: ArrayLike<any>, expected: ArrayLike<any>) {\n  const actualLength = actual.length;\n  const expectedLength = expected.length;\n\n  if (actualLength != expectedLength) {\n    throw new Error(`Arrays are of different length: actual array length is ${actualLength} ` +\n      `and expected array length is ${expectedLength}`);\n  }\n\n  for (let i = 0; i < actualLength; i++) {\n    if (actual[i] instanceof Array && expected[i] instanceof Array)\n      expectArray(actual[i], expected[i]);\n    else if (actual[i] instanceof Object && expected[i] instanceof Object)\n      expectObject(actual[i], expected[i]);\n    else if (actual[i] != expected[i])\n      throw new Error(`Expected ${expected[i]} at position ${i}, got ${actual[i]}`);\n  }\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  const results: { category?: string, name?: string, success: boolean, result: string, ms: number }[] = [];\n  console.log(`Running tests`);\n  grok.shell.lastError = '';\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    console.log(`Started ${key} category`);\n    try {\n      if (value.before)\n        await value.before();\n    } catch (x: any) {\n      value.beforeStatus = x.toString();\n    }\n    const t = value.tests ?? [];\n    const res = [];\n    for (let i = 0; i < t.length; i++)\n      res.push(await execTest(t[i], options?.test));\n\n    const 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, ms: 0});\n    if (value.beforeStatus)\n      data.push({category: key, name: 'init', result: value.beforeStatus, success: false, ms: 0});\n    results.push(...data);\n  }\n  await delay(1000);\n  if (grok.shell.lastError.length > 0) {\n    results.push({\n      category: 'Unhandled exceptions',\n      name: 'exceptions',\n      result: grok.shell.lastError, success: false, ms: 0\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, ms: number };\n  const skip = predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase()));\n  if (!skip)\n    console.log(`Started ${t.category} ${t.name}`);\n  const start = new Date();\n\n  try {\n    if (skip)\n      r = {success: true, result: 'skipped', ms: 0};\n    else\n      r = {success: true, result: await t.test() ?? 'OK', ms: 0};\n  } catch (x: any) {\n    r = {success: false, result: x.toString(), ms: 0};\n  }\n  const stop = new Date();\n  // @ts-ignore\n  r.ms = stop - start;\n  if (!skip)\n    console.log(`Finished ${t.category} ${t.name} for ${r.ms} ms`);\n\n  r.category = t.category;\n  r.name = t.name;\n  return r;\n}\n\n/* Waits [ms] milliseconds */\nexport async function delay(ms: number) {\n  await new Promise((r) => setTimeout(r, ms));\n}\n\nexport async function awaitCheck(checkHandler: () => boolean): Promise<void> {\n  return new Promise((resolve, reject) => {\n    let stop: boolean = false;\n    setTimeout(() => {\n      stop = true;\n      // eslint-disable-next-line prefer-promise-reject-errors\n      reject('Timeout exceeded');\n    }, 500);\n    function check() {\n      if (checkHandler()) {\n        stop = false;\n        resolve();\n      }\n      if (!stop)\n        setTimeout(check, 50);\n    }\n    check();\n  });\n}\n\nexport function isDialogPresent(dialogTitle:string): boolean {\n  for (let i=0; i < DG.Dialog.getOpenDialogs().length; i++) {\n    if (DG.Dialog.getOpenDialogs()[i].title == dialogTitle)\n      return true;\n  }\n  return false;\n}\n"]}","import { lcmsToGcrs } from './map';\nimport * as DG from 'datagrok-api/dg';\nimport { delimiter } from './map';\n//name: gcrsToLcms\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: LCMS}\nexport function gcrsToLcms(sequence) {\n    const df = DG.DataFrame.fromCsv(lcmsToGcrs);\n    const arr1 = df.getCol('GCRS').toList();\n    const arr2 = df.getCol('LCMS').toList();\n    const obj = {};\n    arr1.forEach((element, index) => obj[element] = arr2[index]);\n    obj[delimiter] = delimiter;\n    // for (let i = 0; i < arr1.length; i++) {\n    //   arr1[i] = arr1[i].replace('(', '\\\\(');\n    //   arr1[i] = arr1[i].replace(')', '\\\\)');\n    // }\n    // const regExp = new RegExp('(' + arr1.join('|') + ')', 'g');\n    // let r1 = sequence.replace(regExp, function(code) {return obj[code];});\n    const codes = arr1.concat(delimiter).sort(function (a, b) { return b.length - a.length; });\n    let i = 0;\n    let r1 = '';\n    while (i < sequence.length) {\n        const matchedCode = codes.find((c) => c == sequence.slice(i, i + c.length));\n        r1 += obj[sequence.slice(i, i + matchedCode.length)];\n        i += matchedCode.length;\n    }\n    while (r1.indexOf('//') != -1)\n        r1 = r1.replace('//', '/');\n    return r1;\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, delimiter } from './map';\nimport { isValidSequence } from './sequence-codes-tools';\nimport { getNucleotidesMol } from './mol-transformations';\nexport function sequenceToMolV3000(sequence, inverted = false, oclRender = false, format) {\n    const obj = getObjectWithCodesAndSmiles(sequence, format);\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).concat(delimiter);\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            if (!(i < codesList.length - 1 && links.includes(codesList[i + 1])))\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);\n}\nexport function sequenceToSmiles(sequence, inverted = false, format) {\n    const obj = getObjectWithCodesAndSmiles(sequence, format);\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).concat(delimiter);\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, format) {\n    const obj = {};\n    if (format == null) {\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    }\n    else {\n        for (const technology of Object.keys(map[format])) {\n            for (const code of Object.keys(map[format][technology]))\n                obj[code] = map[format][technology][code].SMILES;\n        }\n    }\n    obj[delimiter] = '';\n    // TODO: create object based from synthesizer type to avoid key(codes) duplicates\n    const output = isValidSequence(sequence, format);\n    if (output.synthesizer.includes(SYNTHESIZERS.MERMADE_12))\n        obj['g'] = map[SYNTHESIZERS.MERMADE_12][TECHNOLOGIES.SI_RNA]['g'].SMILES;\n    else if (output.synthesizer.includes(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","import * as DG from 'datagrok-api/dg';\nimport { getAllCodesOfSynthesizer } from './sequence-codes-tools';\nexport const delimiter = ';';\nexport 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    LCMS: 'LCMS',\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_MOL_WEIGHT: 'Salt 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            's': {\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        'Others': {},\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    // 'LCMS': {\n    //   'For 2\\'-OMe and 2\\'-F modified siRNA': {\n};\nexport const lcmsToGcrs = `LCMS, GCRS\nA, A\nC, C\n/5mC/, (5m)C\nG, G\nT, T\nrA, rA\nrC, rC\nrG, rG\nrU, rU\nmA, mA\nmC, mC\n/5mmC/, (5m)mC\nmG, mG\nmU, mU\nfA, fA\nfC, fC\n/5mfC/, (5m)fC\nfG, fG\nfU, fU\n/afA/, afA\n/afC/, afC\n/afG/, afG\n/afU/, afU\n+A, lna A\n+C, lna C\n+G, lna G\n+T, lna T\n/moeA/, moeA\n/moeC/, moeC\n/5mmoeC/, (5m)moeC\n/moeG/, moeG\n/moeT/, moeT\n/moeU/, moeU\n/xA/, Anp\n/xC/, Cnp\n/x5mC/, (5m)Cnp\n/xG/, Gnp\n/xT/, Tnp\n/xrA/, rAnp\n/xrC/, rCnp\n/xrG/, rGnp\n/xrU/, rUnp\n/xmA/, mAnp\n/xmC/, mCnp\n/x5mmC/, (5m)mCnp\n/xmG/, mGnp\n/xmU/, mUnp\n/xfA/, fAnp\n/xfC/, fCnp\n/xfG/, fGnp\n/xfT/, fTnp\n/xfU/, fUnp\n/xafA/, afAnp\n/xafC/, afCnp\n/xafG/, afGnp\n/xafU/, afUnp\n/xeA/, eAnp\n/xeC/, eCnp\n/xeG/, eGnp\n/xeU/, eUnp\n/xmoeA/, moeAnp\n/xmoeC/, moeCnp\n/x5mmoeC/, (5m)moeCnp\n/xmoeG/, moeGnp\n/xmoeU/, moeUnp\n/UNA-A/, (UNA-A)\n/UNA-C/, (UNA-C)\n/UNA-G/, (UNA-G)\n/UNA-T/, (UNA-T)\n/UNA-U/, (UNA-U)\n/GNA-A/, (GNA-A)\n/GNA-C/, (GNA-C)\n/GNA-G/, (GNA-G)\n/GNA-T/, (GNA-T)\n/GNA-U/, (GNA-U)\n/5CholTEG/, (5-CholTEG)\n/3CholTEG/, (TEGChol-3)\n/Toco/, Toco\n/Palm/, Palm\n/GalNAc/, GalNAc\n/GalNAc2/, GalNAc2\n/GalNAc3/, GalNAc3\n/GalNAc6/, GalNAc6\n/GalNAc7/, GalNAc7\n/GalNAc9/, GalNAc9\n/GalNAc14/, GalNAc14\n/NAG37/, NAG37\n/HEG/, (HEG)\n/TEG/, (TEG)\n/AmmC6/, (NHC6)\n/AmmC7/, (NHC7)\n/AmmC12/, (NHC12)\n/invAb/, (invabasic)\n/invdT/, (invdT)\n/VPmU/, (vinu)\n*, ps\n/2-C16U/, 2-C16U \n/2-C18w9U/, 2-C18w9U\n/JDi-Palm/, JDi-Palm\n/J2-CONC16U/, J2-CONC16U\n/J2-C3NC16U/, J2-C3NC16U\n/J-C15Ada/, J-C15Ada\n/J-2C15AdaU/, J-2C15AdaU\n/J-C16NC6/, J-C16NC6\n/R2-C6NH-U/, R2-C6NH-U\n/J-M1/, J-M1\n/J-B1/, J-B1\n/J-B2/, J-B2\n/J-M2/, J-M2\n/2-C16C/, 2-C16C\n/2-C16A/, 2-C16A\n/2-C16G/, 2-C16G\n/R2-C6NH-G/, R2-C6NH-G\n/R2-C6NH-C/, R2-C6NH-C\n/J2-CONC16A/, J2-CONC16A\n/J2-CONC16C/, J2-CONC16C\n/J2-CONC16G/, J2-CONC16G\n/J2-C15AdaC/, J2-C15AdaC\n/J2-M2U/, J2-M2U\n/J2-B2U/, J2-B2U\n/J2-C3NC16C/, J2-C3NC16C\n/J2-C3NC16G/, J2-C3NC16G\n/R2-C6NH-A/, R2-C6NH-A\n/J2-C15AdaA/, J2-C15AdaA\n/J2-C3NC16A/, J2-C3NC16A\n/J-C5-SER-1/, J-C5-SER-1\n/J-C16-SER-1/, J-C16-SER-1\n/J-A2/, J-A2\n/J-A1/, J-A1\n/J2-C15AdaG/, J2-C15AdaG\n/J-C16NAsp/, J-C16NAsp\n/J2-C16NC6U/, J2-C16NC6U\n/J-C5-REBO-1/, J-C5-REBO-1\n/J-C16-REBO-1/, J-C16-REBO-1\n/J-C16-IND-1/, J-C16-IND-1\n/J-C5-IND-1/, J-C5-IND-1\n/J-1C15Ada-2Man/, J-1C15Ada-2Man\n/JG-1C15Ada-23DiMan/, JG-1C15Ada-2,3DiMan\n/J-TriManPC/, J-TriManPC\n/J-triManPO/, J-triManPO\n/J-A4/, J-A4\n/J-Ara-1/, J-Ara-1\n/J-Ara-2/, J-Ara-2\n/J-AcCS/, J-AcCS\n/J-CbCS/, J-CbCS\n/J-MtCD/, J-MtCD`;\nfunction differenceOfTwoArrays(a, b) {\n    return a.filter((x) => !b.includes(x));\n}\nconst codesWithSmiles = getAllCodesOfSynthesizer(SYNTHESIZERS.GCRS);\nconst allGcrsCodes = DG.DataFrame.fromCsv(lcmsToGcrs).getCol('GCRS').toList();\nexport const gcrsCodesWithoutSmiles = differenceOfTwoArrays(allGcrsCodes, codesWithSmiles);\nfor (const e of gcrsCodesWithoutSmiles)\n    map[SYNTHESIZERS.GCRS]['Others'][e] = { 'SMILES': '' };\n","const 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\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) {\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);\n}\nexport function linkV3000(molBlocks, twoChains = false, useChirality = true) {\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 xShift = 0;\n    if (twoChains && 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        if (twoChains) {\n            const xShiftRight = Math.min(...coordinates.x);\n            const yShift = i == 0 ? Math.min(...coordinates.y) - 1 : Math.max(...coordinates.y) + 1;\n            for (let j = 0; j < coordinates.x.length; j++)\n                coordinates.x[j] -= xShiftRight;\n            for (let j = 0; j < coordinates.y.length; j++)\n                coordinates.y[j] -= yShift;\n        }\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 || twoChains) {\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 = twoChains ? 0 : xShift - coordinates.x[0];\n                let coordinate = twoChains ?\n                    Math.round(10000 * coordinates.x[j]) / 10000 :\n                    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 = twoChains ?\n                    Math.round(10000 * coordinates.y[j]) / 10000 :\n                    Math.round(10000 * (parseFloat(molBlocks[i].substring(index, indexEnd)))) / 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 += twoChains ? numbers.natom : numbers.natom - 1;\n        nbond += numbers.nbond;\n        xShift += twoChains ? 0 : coordinates.x[numbers.natom - 1] - coordinates.x[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    //} 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    twoChains ? 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    if (useChirality) {\n        macroMolBlock += 'M  V30 BEGIN COLLECTION\\n';\n        macroMolBlock += collectionBlock;\n        macroMolBlock += 'M  V30 END COLLECTION\\n';\n    }\n    else\n        macroMolBlock = macroMolBlock.replace(/ CFG=\\d/g, ' ');\n    macroMolBlock += 'M  V30 END CTAB\\n';\n    macroMolBlock += 'M  END';\n    return macroMolBlock;\n}\nfunction rotateNucleotidesV3000(molecule) {\n    // @ts-ignore\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    // @ts-ignore\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 { map, SYNTHESIZERS, TECHNOLOGIES, MODIFICATIONS, delimiter, gcrsCodesWithoutSmiles } from './map';\nimport { asoGapmersNucleotidesToBioSpring, asoGapmersNucleotidesToGcrs, asoGapmersBioSpringToNucleotides, asoGapmersBioSpringToGcrs, asoGapmersGcrsToNucleotides, asoGapmersGcrsToBioSpring, gcrsToMermade12, siRnaNucleotideToBioSpringSenseStrand, siRnaNucleotideToAxolabsSenseStrand, siRnaNucleotidesToGcrs, siRnaBioSpringToNucleotides, siRnaBioSpringToAxolabs, siRnaBioSpringToGcrs, siRnaAxolabsToNucleotides, siRnaAxolabsToBioSpring, siRnaAxolabsToGcrs, siRnaGcrsToNucleotides, siRnaGcrsToBioSpring, siRnaGcrsToAxolabs, gcrsToNucleotides, gcrsToLcms } from './converters';\nconst noTranslationTableAvailable = 'No translation table available';\nexport const undefinedInputSequence = 'Type of input sequence is undefined';\nexport function getFormat(sequence) {\n    const possibleSynthesizers = getListOfPossibleSynthesizersByFirstMatchedCode(sequence);\n    if (possibleSynthesizers.length == 0)\n        return 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 possibleSynthesizers[0];\n    const possibleTechnologies = getListOfPossibleTechnologiesByFirstMatchedCode(sequence, possibleSynthesizers[0]);\n    if (possibleTechnologies.length == 0)\n        return 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 possibleSynthesizers[0];\n}\nfunction sortByStringLengthInDescendingOrder(array) {\n    return array.sort(function (a, b) { return b.length - a.length; });\n}\nexport function isValidSequence(sequence, format) {\n    const possibleSynthesizers = format == null ?\n        getListOfPossibleSynthesizersByFirstMatchedCode(sequence) :\n        [format];\n    // if (possibleSynthesizers.length > 1) {\n    //   const synthesizer = ui.choiceInput('Choose synthesizer from list: ', possibleSynthesizers[0],\n    //  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    // } else if (possibleSynthesizers.length == 0)\n    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 = sortByStringLengthInDescendingOrder(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,\n            technology: null,\n        };\n    }\n    const possibleTechnologies = getListOfPossibleTechnologiesByFirstMatchedCode(sequence, possibleSynthesizers[0]);\n    // if (possibleTechnologies.length > 1) {\n    //   const technology = ui.choiceInput('Choose technology from list: ', possibleTechnologies[0],\n    // 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    // } else if (possibleTechnologies.length == 0)\n    // if (possibleTechnologies.length == 0)\n    //   return {indexOfFirstNotValidChar: 0, synthesizer: [possibleSynthesizers[3]], technology: null};\n    outputIndex = 0;\n    // possibleTechnologies.forEach((technology: string) => {\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    //     ) {\n    //       outputIndex++;\n    //       break;\n    //     }\n    //     outputIndex += matchedCode.length;\n    //   }\n    // });\n    return {\n        indexOfFirstNotValidChar: indexOfFirstNotValidChar,\n        synthesizer: possibleSynthesizers,\n        technology: [possibleTechnologies[outputIndex]],\n    };\n}\nexport function 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)).concat(delimiter);\n}\nfunction getListOfPossibleSynthesizersByFirstMatchedCode(sequence) {\n    let synthesizers = [];\n    Object.keys(map).forEach((synthesizer) => {\n        let codes = sortByStringLengthInDescendingOrder(getAllCodesOfSynthesizer(synthesizer));\n        if (synthesizer == 'Janssen GCRS Codes')\n            codes = codes.concat(gcrsCodesWithoutSmiles);\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 (gcrsCodesWithoutSmiles.some((s) => s == sequence.slice(start, start + s.length)))\n            synthesizers = ['Janssen GCRS Codes'];\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.includes(SYNTHESIZERS.RAW_NUCLEOTIDES)) { //&& output.technology!.includes(TECHNOLOGIES.DNA)) {\n        return {\n            type: SYNTHESIZERS.RAW_NUCLEOTIDES,\n            Nucleotides: sequence,\n            BioSpring: asoGapmersNucleotidesToBioSpring(sequence),\n            GCRS: asoGapmersNucleotidesToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.BIOSPRING) && output.technology.includes(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.includes(SYNTHESIZERS.GCRS) && output.technology.includes(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            LCMS: gcrsToLcms(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.RAW_NUCLEOTIDES) && output.technology.includes(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.includes(SYNTHESIZERS.BIOSPRING) && output.technology.includes(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.includes(SYNTHESIZERS.AXOLABS)) {\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.includes(SYNTHESIZERS.GCRS) && output.technology.includes(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            LCMS: gcrsToLcms(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.GCRS)) {\n        return {\n            type: SYNTHESIZERS.GCRS,\n            Nucleotides: gcrsToNucleotides(sequence),\n            GCRS: sequence,\n            Mermade12: gcrsToMermade12(sequence),\n            LCMS: gcrsToLcms(sequence),\n        };\n    }\n    if (output.synthesizer.includes(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';\nimport { SYNTHESIZERS } from '../structures-works/map';\ncategory('sequence-translator', () => {\n    // test('AGGTCCTCTTGACTTAGGCC', async () => {\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', false, SYNTHESIZERS.RAW_NUCLEOTIDES), expected);\n    // });\n    // test('invabasic/galnac1', async () => {\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)', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('invabasic/galnac2', async () => {\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)', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('invabasic/galnac3', async () => {\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)', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('invabasic/galnac4', async () => {\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)', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), expected);\n    }));\n    // test('(invabasic)sucuCfuUf', async () => {\n    //   const expected =\n    //   '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', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('(invabasic)sAfgcugUf', async () => {\n    //   const expected =\n    //   '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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), expected);\n    }));\n    // test('(invabasic)scususu(GalNAc-2-JNJ)', async () => {\n    //   const expected =\n    //   '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)', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), 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', false, SYNTHESIZERS.AXOLABS), expected);\n    }));\n    // test('(invabasic)scsgguGfcAfAfCfucuauucuga', async () => {\n    //   const expected =\n    //   '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', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('(invabasic)scsaacUfcUfAfUfucuggacuua', async () => {\n    //   const expected =\n    //   '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', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('(invabasic)sasacuCfuAfUfUfcuggacuuua', async () => {\n    //   const expected =\n    //   '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', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('(invabasic)usAfscug(invabasic)(GalNAc-2-JNJ)', async () => {\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)', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('(invabasic)sasuaaCfcUf(GalNAc-2-JNJ)', async () => {\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)', false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('(invabasic)sasuaaCfcUfCfUfuguaguuaua(GalNAc-2-JNJ)', async () => {\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)', false, SYNTHESIZERS.AXOLABS),\n    //     expected);\n    // });\n    // test('(invabasic)scsaucacguUfGfCfagccgucuua(invabasic)(GalNAc-2-JNJ)', async () => {\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)',\n    //     false, SYNTHESIZERS.AXOLABS), expected);\n    // });\n    // test('(invabasic)susguuUfgCfCfUfacaucuacua(GalNAc-2-JNJ)', async () => {\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)', false, SYNTHESIZERS.AXOLABS),\n    //     expected);\n    // });\n});\n","module.exports = DG;","module.exports = grok;","// 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":""}