@datagrok/sequence-translator 1.0.1 → 1.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/detectors.js +17 -16
- package/dist/package-test.js +199 -21
- package/dist/package.js +352 -107
- package/package.json +9 -8
- package/package.png +0 -0
- package/src/__jest__/remote.test.ts +33 -14
- package/src/defineAxolabsPattern.ts +48 -24
- package/src/package.ts +46 -6
- package/src/structures-works/converters.ts +20 -0
- package/src/structures-works/map.ts +166 -1
- package/src/structures-works/mol-transformations.ts +2 -2
- package/src/structures-works/sequence-codes-tools.ts +7 -6
- package/test-SequenceTranslator-4f0c8bae6479-18ff1615.html +276 -0
- package/vendors/openchemlib-full.js +293 -0
- package/webpack.config.js +1 -1
- package/test-SequenceTranslator-089b6516ed77-2280593f.html +0 -245
package/dist/package.js
CHANGED
|
@@ -2091,7 +2091,9 @@ function addColumnWithIds(tableName, columnName, patternName) {
|
|
|
2091
2091
|
if (columns.contains(nameOfNewColumn))
|
|
2092
2092
|
columns.remove(nameOfNewColumn);
|
|
2093
2093
|
const columnWithIds = columns.byName(columnName);
|
|
2094
|
-
return columns.addNewString(nameOfNewColumn).init((i) =>
|
|
2094
|
+
return columns.addNewString(nameOfNewColumn).init((i) => {
|
|
2095
|
+
return (columnWithIds.getString(i) == '') ? '' : columnWithIds.get(i) + '_' + patternName;
|
|
2096
|
+
});
|
|
2095
2097
|
}
|
|
2096
2098
|
function addColumnWithTranslatedSequences(tableName, columnName, bases, ptoLinkages, startModification, endModification, firstPtoExist) {
|
|
2097
2099
|
const nameOfNewColumn = 'Axolabs ' + columnName;
|
|
@@ -2100,7 +2102,9 @@ function addColumnWithTranslatedSequences(tableName, columnName, bases, ptoLinka
|
|
|
2100
2102
|
columns.remove(nameOfNewColumn);
|
|
2101
2103
|
const columnWithInputSequences = columns.byName(columnName);
|
|
2102
2104
|
return columns.addNewString(nameOfNewColumn).init((i) => {
|
|
2103
|
-
return
|
|
2105
|
+
return columnWithInputSequences.getString(i) == '' ?
|
|
2106
|
+
'' :
|
|
2107
|
+
translateSequence(columnWithInputSequences.getString(i), bases, ptoLinkages, startModification, endModification, firstPtoExist);
|
|
2104
2108
|
});
|
|
2105
2109
|
}
|
|
2106
2110
|
function defineAxolabsPattern() {
|
|
@@ -2290,7 +2294,7 @@ function defineAxolabsPattern() {
|
|
|
2290
2294
|
const col = tables.value.columns.byName(colName);
|
|
2291
2295
|
let allLengthsAreTheSame = true;
|
|
2292
2296
|
for (let i = 1; i < col.length; i++) {
|
|
2293
|
-
if (col.get(i - 1).length != col.get(i).length) {
|
|
2297
|
+
if (col.get(i - 1).length != col.get(i).length && col.get(i).length != 0) {
|
|
2294
2298
|
allLengthsAreTheSame = false;
|
|
2295
2299
|
break;
|
|
2296
2300
|
}
|
|
@@ -2320,10 +2324,11 @@ function defineAxolabsPattern() {
|
|
|
2320
2324
|
}
|
|
2321
2325
|
function postPatternToUserStorage() {
|
|
2322
2326
|
return __awaiter(this, void 0, void 0, function* () {
|
|
2323
|
-
const
|
|
2324
|
-
|
|
2325
|
-
saveAs.value
|
|
2326
|
-
|
|
2327
|
+
const currUserName = yield getCurrentUserName();
|
|
2328
|
+
saveAs.value = (saveAs.stringValue.includes('(created by ')) ?
|
|
2329
|
+
getShortName(saveAs.value) + currUserName :
|
|
2330
|
+
saveAs.stringValue + currUserName;
|
|
2331
|
+
return datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.dapi.userDataStorage.postValue(userStorageKey, saveAs.value, JSON.stringify({
|
|
2327
2332
|
'ssBases': ssBases.slice(0, ssLength.value).map((e) => e.value),
|
|
2328
2333
|
'asBases': asBases.slice(0, asLength.value).map((e) => e.value),
|
|
2329
2334
|
'ssPtoLinkages': [firstSsPto.value].concat(ssPtoLinkages.slice(0, ssLength.value).map((e) => e.value)),
|
|
@@ -2341,11 +2346,12 @@ function defineAxolabsPattern() {
|
|
|
2341
2346
|
datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.dapi.userDataStorage.get(userStorageKey, false).then((entities) => __awaiter(this, void 0, void 0, function* () {
|
|
2342
2347
|
const lstMy = [];
|
|
2343
2348
|
const lstOthers = [];
|
|
2349
|
+
// TODO: display short name, but use long for querying userdataStorage
|
|
2344
2350
|
for (const ent of Object.keys(entities)) {
|
|
2345
2351
|
if (yield isCurrentUserCreatedThisPattern(ent))
|
|
2346
2352
|
lstOthers.push(ent);
|
|
2347
2353
|
else
|
|
2348
|
-
lstMy.push(getShortName(ent));
|
|
2354
|
+
lstMy.push(ent); //getShortName(ent));
|
|
2349
2355
|
}
|
|
2350
2356
|
let loadPattern = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('Load Pattern', '', lstMy, (v) => parsePatternAndUpdateUi(v));
|
|
2351
2357
|
const myOrOthersPatternList = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('', 'Mine', ['Mine', 'Others'], (v) => {
|
|
@@ -2469,7 +2475,7 @@ function defineAxolabsPattern() {
|
|
|
2469
2475
|
const col = tables.value.columns.byName(colName);
|
|
2470
2476
|
if (col.type != datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TYPE.INT)
|
|
2471
2477
|
datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.error('Column should contain integers only');
|
|
2472
|
-
else if (col.categories.length < col.length) {
|
|
2478
|
+
else if (col.categories.filter((e) => e != '').length < col.toList().filter((e) => e != '').length) {
|
|
2473
2479
|
const duplicates = findDuplicates(col.getRawData());
|
|
2474
2480
|
datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.dialog('Non-unique IDs')
|
|
2475
2481
|
.add(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText('Press \'OK\' to select rows with non-unique values'))
|
|
@@ -2483,21 +2489,42 @@ function defineAxolabsPattern() {
|
|
|
2483
2489
|
}
|
|
2484
2490
|
}
|
|
2485
2491
|
const tables = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.tableInput('Tables', datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.tables[0], datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.tables, (t) => {
|
|
2486
|
-
const inputSsColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('SS Column', '', t.columns.names(), (colName) =>
|
|
2492
|
+
const inputSsColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('SS Column', '', t.columns.names(), (colName) => {
|
|
2493
|
+
validateSsColumn(colName);
|
|
2494
|
+
ssVar = colName;
|
|
2495
|
+
});
|
|
2487
2496
|
inputSsColumnDiv.innerHTML = '';
|
|
2488
2497
|
inputSsColumnDiv.append(inputSsColumn.root);
|
|
2489
|
-
const inputAsColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('AS Column', '', t.columns.names(), (colName) =>
|
|
2498
|
+
const inputAsColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('AS Column', '', t.columns.names(), (colName) => {
|
|
2499
|
+
validateAsColumn(colName);
|
|
2500
|
+
asVar = colName;
|
|
2501
|
+
});
|
|
2490
2502
|
inputAsColumnDiv.innerHTML = '';
|
|
2491
2503
|
inputAsColumnDiv.append(inputAsColumn.root);
|
|
2492
|
-
const inputIdColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('ID Column', '', t.columns.names(), (colName) =>
|
|
2504
|
+
const inputIdColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('ID Column', '', t.columns.names(), (colName) => {
|
|
2505
|
+
validateIdsColumn(colName);
|
|
2506
|
+
idVar = colName;
|
|
2507
|
+
});
|
|
2493
2508
|
inputIdColumnDiv.innerHTML = '';
|
|
2494
2509
|
inputIdColumnDiv.append(inputIdColumn.root);
|
|
2495
2510
|
});
|
|
2496
|
-
|
|
2511
|
+
let ssVar = '';
|
|
2512
|
+
const inputSsColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('SS Column', '', [], (colName) => {
|
|
2513
|
+
validateSsColumn(colName);
|
|
2514
|
+
ssVar = colName;
|
|
2515
|
+
});
|
|
2497
2516
|
inputSsColumnDiv.append(inputSsColumn.root);
|
|
2498
|
-
|
|
2517
|
+
let asVar = '';
|
|
2518
|
+
const inputAsColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('AS Column', '', [], (colName) => {
|
|
2519
|
+
validateAsColumn(colName);
|
|
2520
|
+
asVar = colName;
|
|
2521
|
+
});
|
|
2499
2522
|
inputAsColumnDiv.append(inputAsColumn.root);
|
|
2500
|
-
|
|
2523
|
+
let idVar = '';
|
|
2524
|
+
const inputIdColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('ID Column', '', [], (colName) => {
|
|
2525
|
+
validateIdsColumn(colName);
|
|
2526
|
+
idVar = colName;
|
|
2527
|
+
});
|
|
2501
2528
|
inputIdColumnDiv.append(inputIdColumn.root);
|
|
2502
2529
|
updatePatternsList();
|
|
2503
2530
|
const sequenceBase = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('Sequence Basis', defaultBase, baseChoices, (v) => {
|
|
@@ -2562,7 +2589,7 @@ function defineAxolabsPattern() {
|
|
|
2562
2589
|
}
|
|
2563
2590
|
});
|
|
2564
2591
|
const convertSequenceButton = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.button('Convert Sequences', () => {
|
|
2565
|
-
if (
|
|
2592
|
+
if (ssVar == '' || (createAsStrand.value && asVar == ''))
|
|
2566
2593
|
datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.info('Please select table and columns on which to apply pattern');
|
|
2567
2594
|
else if (ssLength.value != ssInputExample.value.length || asLength.value != asInputExample.value.length) {
|
|
2568
2595
|
const dialog = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.dialog('Length Mismatch');
|
|
@@ -2577,11 +2604,11 @@ function defineAxolabsPattern() {
|
|
|
2577
2604
|
.show();
|
|
2578
2605
|
}
|
|
2579
2606
|
else {
|
|
2580
|
-
if (
|
|
2581
|
-
addColumnWithIds(tables.value.name,
|
|
2582
|
-
addColumnWithTranslatedSequences(tables.value.name,
|
|
2607
|
+
if (idVar != '')
|
|
2608
|
+
addColumnWithIds(tables.value.name, idVar, getShortName(saveAs.value));
|
|
2609
|
+
addColumnWithTranslatedSequences(tables.value.name, ssVar, ssBases, ssPtoLinkages, ssFiveModification, ssThreeModification, firstSsPto.value);
|
|
2583
2610
|
if (createAsStrand.value) {
|
|
2584
|
-
addColumnWithTranslatedSequences(tables.value.name,
|
|
2611
|
+
addColumnWithTranslatedSequences(tables.value.name, asVar, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstAsPto.value);
|
|
2585
2612
|
}
|
|
2586
2613
|
datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.v = datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.getTableView(tables.value.name);
|
|
2587
2614
|
datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.info(((createAsStrand.value) ? 'Columns were' : 'Column was') +
|
|
@@ -2971,6 +2998,7 @@ NO DATA
|
|
|
2971
2998
|
"use strict";
|
|
2972
2999
|
__webpack_require__.r(__webpack_exports__);
|
|
2973
3000
|
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
3001
|
+
/* harmony export */ "gcrsToLcms": () => (/* binding */ gcrsToLcms),
|
|
2974
3002
|
/* harmony export */ "asoGapmersNucleotidesToBioSpring": () => (/* binding */ asoGapmersNucleotidesToBioSpring),
|
|
2975
3003
|
/* harmony export */ "asoGapmersNucleotidesToGcrs": () => (/* binding */ asoGapmersNucleotidesToGcrs),
|
|
2976
3004
|
/* harmony export */ "asoGapmersBioSpringToNucleotides": () => (/* binding */ asoGapmersBioSpringToNucleotides),
|
|
@@ -2993,6 +3021,27 @@ __webpack_require__.r(__webpack_exports__);
|
|
|
2993
3021
|
/* harmony export */ "gcrsToNucleotides": () => (/* binding */ gcrsToNucleotides),
|
|
2994
3022
|
/* harmony export */ "gcrsToMermade12": () => (/* binding */ gcrsToMermade12)
|
|
2995
3023
|
/* harmony export */ });
|
|
3024
|
+
/* harmony import */ var _map__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./map */ "./src/structures-works/map.ts");
|
|
3025
|
+
/* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! datagrok-api/dg */ "datagrok-api/dg");
|
|
3026
|
+
/* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__);
|
|
3027
|
+
|
|
3028
|
+
|
|
3029
|
+
//name: gcrsToLcms
|
|
3030
|
+
//input: string nucleotides {semType: GCRS}
|
|
3031
|
+
//output: string result {semType: LCMS}
|
|
3032
|
+
function gcrsToLcms(sequence) {
|
|
3033
|
+
const df = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__.DataFrame.fromCsv(_map__WEBPACK_IMPORTED_MODULE_0__.lcmsToGcrs);
|
|
3034
|
+
const arr1 = df.getCol('GCRS').toList();
|
|
3035
|
+
const arr2 = df.getCol('LCMS').toList();
|
|
3036
|
+
const obj = {};
|
|
3037
|
+
arr1.forEach((element, index) => obj[element] = arr2[index]);
|
|
3038
|
+
for (let i = 0; i < arr1.length; i++) {
|
|
3039
|
+
arr1[i] = arr1[i].replace('(', '\\(');
|
|
3040
|
+
arr1[i] = arr1[i].replace(')', '\\)');
|
|
3041
|
+
}
|
|
3042
|
+
const regExp = new RegExp('(' + arr1.join('|') + ')', 'g');
|
|
3043
|
+
return sequence.replace(regExp, function (code) { return obj[code]; });
|
|
3044
|
+
}
|
|
2996
3045
|
//name: asoGapmersNucleotidesToBioSpring
|
|
2997
3046
|
//input: string nucleotides {semType: DNA nucleotides}
|
|
2998
3047
|
//output: string result {semType: BioSpring / Gapmers}
|
|
@@ -3398,14 +3447,22 @@ __webpack_require__.r(__webpack_exports__);
|
|
|
3398
3447
|
/* harmony export */ "COL_NAMES": () => (/* binding */ COL_NAMES),
|
|
3399
3448
|
/* harmony export */ "MODIFICATIONS": () => (/* binding */ MODIFICATIONS),
|
|
3400
3449
|
/* harmony export */ "stadardPhosphateLinkSmiles": () => (/* binding */ stadardPhosphateLinkSmiles),
|
|
3401
|
-
/* harmony export */ "map": () => (/* binding */ map)
|
|
3450
|
+
/* harmony export */ "map": () => (/* binding */ map),
|
|
3451
|
+
/* harmony export */ "lcmsToGcrs": () => (/* binding */ lcmsToGcrs),
|
|
3452
|
+
/* harmony export */ "gcrsCodesWithoutSmiles": () => (/* binding */ gcrsCodesWithoutSmiles)
|
|
3402
3453
|
/* harmony export */ });
|
|
3454
|
+
/* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! datagrok-api/dg */ "datagrok-api/dg");
|
|
3455
|
+
/* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__);
|
|
3456
|
+
/* harmony import */ var _sequence_codes_tools__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./sequence-codes-tools */ "./src/structures-works/sequence-codes-tools.ts");
|
|
3457
|
+
|
|
3458
|
+
|
|
3403
3459
|
const SYNTHESIZERS = {
|
|
3404
3460
|
RAW_NUCLEOTIDES: 'Raw Nucleotides',
|
|
3405
3461
|
BIOSPRING: 'BioSpring Codes',
|
|
3406
3462
|
GCRS: 'Janssen GCRS Codes',
|
|
3407
3463
|
AXOLABS: 'Axolabs Codes',
|
|
3408
3464
|
MERMADE_12: 'Mermade 12',
|
|
3465
|
+
LCMS: 'LCMS',
|
|
3409
3466
|
};
|
|
3410
3467
|
const TECHNOLOGIES = {
|
|
3411
3468
|
DNA: 'DNA',
|
|
@@ -3858,6 +3915,7 @@ const map = {
|
|
|
3858
3915
|
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',
|
|
3859
3916
|
},
|
|
3860
3917
|
},
|
|
3918
|
+
'Others': {},
|
|
3861
3919
|
},
|
|
3862
3920
|
'Mermade 12': {
|
|
3863
3921
|
'For 2\'-OMe and 2\'-F modified siRNA': {
|
|
@@ -3959,7 +4017,164 @@ const map = {
|
|
|
3959
4017
|
},
|
|
3960
4018
|
},
|
|
3961
4019
|
},
|
|
4020
|
+
// 'LCMS': {
|
|
4021
|
+
// 'For 2\'-OMe and 2\'-F modified siRNA': {
|
|
3962
4022
|
};
|
|
4023
|
+
const lcmsToGcrs = `LCMS, GCRS
|
|
4024
|
+
A, A
|
|
4025
|
+
C, C
|
|
4026
|
+
/5mC/, (5m)C
|
|
4027
|
+
G, G
|
|
4028
|
+
T, T
|
|
4029
|
+
rA, rA
|
|
4030
|
+
rC, rC
|
|
4031
|
+
rG, rG
|
|
4032
|
+
rU, rU
|
|
4033
|
+
mA, mA
|
|
4034
|
+
mC, mC
|
|
4035
|
+
/5mmC/, (5m)mC
|
|
4036
|
+
mG, mG
|
|
4037
|
+
mU, mU
|
|
4038
|
+
fA, fA
|
|
4039
|
+
fC, fC
|
|
4040
|
+
/5mfC/, (5m)fC
|
|
4041
|
+
fG, fG
|
|
4042
|
+
fU, fU
|
|
4043
|
+
/afA/, afA
|
|
4044
|
+
/afC/, afC
|
|
4045
|
+
/afG/, afG
|
|
4046
|
+
/afU/, afU
|
|
4047
|
+
+A, lna A
|
|
4048
|
+
+C, lna C
|
|
4049
|
+
+G, lna G
|
|
4050
|
+
+T, lna T
|
|
4051
|
+
/moeA/, moeA
|
|
4052
|
+
/moeC/, moeC
|
|
4053
|
+
/5mmoeC/, (5m)moeC
|
|
4054
|
+
/moeG/, moeG
|
|
4055
|
+
/moeT/, moeT
|
|
4056
|
+
/moeU/, moeU
|
|
4057
|
+
/xA/, Anp
|
|
4058
|
+
/xC/, Cnp
|
|
4059
|
+
/x5mC/, (5m)Cnp
|
|
4060
|
+
/xG/, Gnp
|
|
4061
|
+
/xT/, Tnp
|
|
4062
|
+
/xrA/, rAnp
|
|
4063
|
+
/xrC/, rCnp
|
|
4064
|
+
/xrG/, rGnp
|
|
4065
|
+
/xrU/, rUnp
|
|
4066
|
+
/xmA/, mAnp
|
|
4067
|
+
/xmC/, mCnp
|
|
4068
|
+
/x5mmC/, (5m)mCnp
|
|
4069
|
+
/xmG/, mGnp
|
|
4070
|
+
/xmU/, mUnp
|
|
4071
|
+
/xfA/, fAnp
|
|
4072
|
+
/xfC/, fCnp
|
|
4073
|
+
/xfG/, fGnp
|
|
4074
|
+
/xfT/, fTnp
|
|
4075
|
+
/xfU/, fUnp
|
|
4076
|
+
/xafA/, afAnp
|
|
4077
|
+
/xafC/, afCnp
|
|
4078
|
+
/xafG/, afGnp
|
|
4079
|
+
/xafU/, afUnp
|
|
4080
|
+
/xeA/, eAnp
|
|
4081
|
+
/xeC/, eCnp
|
|
4082
|
+
/xeG/, eGnp
|
|
4083
|
+
/xeU/, eUnp
|
|
4084
|
+
/xmoeA/, moeAnp
|
|
4085
|
+
/xmoeC/, moeCnp
|
|
4086
|
+
/x5mmoeC/, (5m)moeCnp
|
|
4087
|
+
/xmoeG/, moeGnp
|
|
4088
|
+
/xmoeU/, moeUnp
|
|
4089
|
+
/UNA-A/, (UNA-A)
|
|
4090
|
+
/UNA-C/, (UNA-C)
|
|
4091
|
+
/UNA-G/, (UNA-G)
|
|
4092
|
+
/UNA-T/, (UNA-T)
|
|
4093
|
+
/UNA-U/, (UNA-U)
|
|
4094
|
+
/GNA-A/, (GNA-A)
|
|
4095
|
+
/GNA-C/, (GNA-C)
|
|
4096
|
+
/GNA-G/, (GNA-G)
|
|
4097
|
+
/GNA-T/, (GNA-T)
|
|
4098
|
+
/GNA-U/, (GNA-U)
|
|
4099
|
+
/5CholTEG/, (5-CholTEG)
|
|
4100
|
+
/3CholTEG/, (TEGChol-3)
|
|
4101
|
+
/Toco/, Toco
|
|
4102
|
+
/Palm/, Palm
|
|
4103
|
+
/GalNAc/, GalNAc
|
|
4104
|
+
/GalNAc2/, GalNAc2
|
|
4105
|
+
/GalNAc3/, GalNAc3
|
|
4106
|
+
/GalNAc6/, GalNAc6
|
|
4107
|
+
/GalNAc7/, GalNAc7
|
|
4108
|
+
/GalNAc9/, GalNAc9
|
|
4109
|
+
/GalNAc14/, GalNAc14
|
|
4110
|
+
/NAG37/, NAG37
|
|
4111
|
+
/HEG/, (HEG)
|
|
4112
|
+
/TEG/, (TEG)
|
|
4113
|
+
/AmmC6/, (NHC6)
|
|
4114
|
+
/AmmC7/, (NHC7)
|
|
4115
|
+
/AmmC12/, (NHC12)
|
|
4116
|
+
/invAb/, (invabasic)
|
|
4117
|
+
/invdT/, (invdT)
|
|
4118
|
+
/VPmU/, (vinu)
|
|
4119
|
+
*, ps
|
|
4120
|
+
/2-C16U/, 2-C16U
|
|
4121
|
+
/2-C18w9U/, 2-C18w9U
|
|
4122
|
+
/JDi-Palm/, JDi-Palm
|
|
4123
|
+
/J2-CONC16U/, J2-CONC16U
|
|
4124
|
+
/J2-C3NC16U/, J2-C3NC16U
|
|
4125
|
+
/J-C15Ada/, J-C15Ada
|
|
4126
|
+
/J-2C15AdaU/, J-2C15AdaU
|
|
4127
|
+
/J-C16NC6/, J-C16NC6
|
|
4128
|
+
/R2-C6NH-U/, R2-C6NH-U
|
|
4129
|
+
/J-M1/, J-M1
|
|
4130
|
+
/J-B1/, J-B1
|
|
4131
|
+
/J-B2/, J-B2
|
|
4132
|
+
/J-M2/, J-M2
|
|
4133
|
+
/2-C16C/, 2-C16C
|
|
4134
|
+
/2-C16A/, 2-C16A
|
|
4135
|
+
/2-C16G/, 2-C16G
|
|
4136
|
+
/R2-C6NH-G/, R2-C6NH-G
|
|
4137
|
+
/R2-C6NH-C/, R2-C6NH-C
|
|
4138
|
+
/J2-CONC16A/, J2-CONC16A
|
|
4139
|
+
/J2-CONC16C/, J2-CONC16C
|
|
4140
|
+
/J2-CONC16G/, J2-CONC16G
|
|
4141
|
+
/J2-C15AdaC/, J2-C15AdaC
|
|
4142
|
+
/J2-M2U/, J2-M2U
|
|
4143
|
+
/J2-B2U/, J2-B2U
|
|
4144
|
+
/J2-C3NC16C/, J2-C3NC16C
|
|
4145
|
+
/J2-C3NC16G/, J2-C3NC16G
|
|
4146
|
+
/R2-C6NH-A/, R2-C6NH-A
|
|
4147
|
+
/J2-C15AdaA/, J2-C15AdaA
|
|
4148
|
+
/J2-C3NC16A/, J2-C3NC16A
|
|
4149
|
+
/J-C5-SER-1/, J-C5-SER-1
|
|
4150
|
+
/J-C16-SER-1/, J-C16-SER-1
|
|
4151
|
+
/J-A2/, J-A2
|
|
4152
|
+
/J-A1/, J-A1
|
|
4153
|
+
/J2-C15AdaG/, J2-C15AdaG
|
|
4154
|
+
/J-C16NAsp/, J-C16NAsp
|
|
4155
|
+
/J2-C16NC6U/, J2-C16NC6U
|
|
4156
|
+
/J-C5-REBO-1/, J-C5-REBO-1
|
|
4157
|
+
/J-C16-REBO-1/, J-C16-REBO-1
|
|
4158
|
+
/J-C16-IND-1/, J-C16-IND-1
|
|
4159
|
+
/J-C5-IND-1/, J-C5-IND-1
|
|
4160
|
+
/J-1C15Ada-2Man/, J-1C15Ada-2Man
|
|
4161
|
+
/JG-1C15Ada-23DiMan/, JG-1C15Ada-2,3DiMan
|
|
4162
|
+
/J-TriManPC/, J-TriManPC
|
|
4163
|
+
/J-triManPO/, J-triManPO
|
|
4164
|
+
/J-A4/, J-A4
|
|
4165
|
+
/J-Ara-1/, J-Ara-1
|
|
4166
|
+
/J-Ara-2/, J-Ara-2
|
|
4167
|
+
/J-AcCS/, J-AcCS
|
|
4168
|
+
/J-CbCS/, J-CbCS
|
|
4169
|
+
/J-MtCD/, J-MtCD`;
|
|
4170
|
+
function differenceOfTwoArrays(a, b) {
|
|
4171
|
+
return a.filter((x) => !b.includes(x));
|
|
4172
|
+
}
|
|
4173
|
+
const codesWithSmiles = (0,_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_1__.getAllCodesOfSynthesizer)(SYNTHESIZERS.GCRS);
|
|
4174
|
+
const allGcrsCodes = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__.DataFrame.fromCsv(lcmsToGcrs).getCol('GCRS').toList();
|
|
4175
|
+
const gcrsCodesWithoutSmiles = differenceOfTwoArrays(allGcrsCodes, codesWithSmiles);
|
|
4176
|
+
for (const e of gcrsCodesWithoutSmiles)
|
|
4177
|
+
map[SYNTHESIZERS.GCRS]['Others'][e] = { 'SMILES': '' };
|
|
3963
4178
|
|
|
3964
4179
|
|
|
3965
4180
|
/***/ }),
|
|
@@ -3976,9 +4191,6 @@ __webpack_require__.r(__webpack_exports__);
|
|
|
3976
4191
|
/* harmony export */ "getNucleotidesMol": () => (/* binding */ getNucleotidesMol),
|
|
3977
4192
|
/* harmony export */ "linkV3000": () => (/* binding */ linkV3000)
|
|
3978
4193
|
/* harmony export */ });
|
|
3979
|
-
/* harmony import */ var openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! openchemlib/full.js */ "openchemlib/full.js");
|
|
3980
|
-
/* harmony import */ var openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__);
|
|
3981
|
-
|
|
3982
4194
|
const PHOSHATE = `
|
|
3983
4195
|
Datagrok monomer library Nucleotides
|
|
3984
4196
|
|
|
@@ -4204,7 +4416,8 @@ function linkV3000(molBlocks, twoChains = false, oclRender = false) {
|
|
|
4204
4416
|
return macroMolBlock;
|
|
4205
4417
|
}
|
|
4206
4418
|
function rotateNucleotidesV3000(molecule) {
|
|
4207
|
-
|
|
4419
|
+
// @ts-ignore
|
|
4420
|
+
let molBlock = molecule.includes('M END') ? molecule : OCL.Molecule.fromSmiles(molecule).toMolfileV3();
|
|
4208
4421
|
const coordinates = extractAtomDataV3000(molBlock);
|
|
4209
4422
|
const natom = coordinates.atomIndex.length;
|
|
4210
4423
|
const indexFivePrime = coordinates.atomIndex.indexOf(1);
|
|
@@ -4257,7 +4470,8 @@ function rotateNucleotidesV3000(molecule) {
|
|
|
4257
4470
|
return molBlock;
|
|
4258
4471
|
}
|
|
4259
4472
|
function invertNucleotidesV3000(molecule) {
|
|
4260
|
-
|
|
4473
|
+
// @ts-ignore
|
|
4474
|
+
let molBlock = molecule.includes('M END') ? molecule : OCL.Molecule.fromSmiles(molecule).toMolfileV3();
|
|
4261
4475
|
const coordinates = extractAtomDataV3000(molBlock);
|
|
4262
4476
|
const natom = coordinates.atomIndex.length;
|
|
4263
4477
|
const xCenter = (Math.max(...coordinates.x) + Math.min(...coordinates.x)) / 2;
|
|
@@ -4438,13 +4652,11 @@ __webpack_require__.r(__webpack_exports__);
|
|
|
4438
4652
|
/* harmony export */ "undefinedInputSequence": () => (/* binding */ undefinedInputSequence),
|
|
4439
4653
|
/* harmony export */ "getFormat": () => (/* binding */ getFormat),
|
|
4440
4654
|
/* harmony export */ "isValidSequence": () => (/* binding */ isValidSequence),
|
|
4655
|
+
/* harmony export */ "getAllCodesOfSynthesizer": () => (/* binding */ getAllCodesOfSynthesizer),
|
|
4441
4656
|
/* harmony export */ "convertSequence": () => (/* binding */ convertSequence)
|
|
4442
4657
|
/* harmony export */ });
|
|
4443
4658
|
/* harmony import */ var _map__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./map */ "./src/structures-works/map.ts");
|
|
4444
4659
|
/* harmony import */ var _converters__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./converters */ "./src/structures-works/converters.ts");
|
|
4445
|
-
// import * as grok from 'datagrok-api/grok';
|
|
4446
|
-
// import * as ui from 'datagrok-api/ui';
|
|
4447
|
-
// import * as DG from 'datagrok-api/dg';
|
|
4448
4660
|
|
|
4449
4661
|
|
|
4450
4662
|
const noTranslationTableAvailable = 'No translation table available';
|
|
@@ -4600,7 +4812,7 @@ function getAllCodesOfSynthesizer(synthesizer) {
|
|
|
4600
4812
|
let codes = [];
|
|
4601
4813
|
for (const technology of Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer]))
|
|
4602
4814
|
codes = codes.concat(Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer][technology]));
|
|
4603
|
-
return codes.concat(Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS));
|
|
4815
|
+
return codes.concat(Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS)).concat(',');
|
|
4604
4816
|
}
|
|
4605
4817
|
function getListOfPossibleSynthesizersByFirstMatchedCode(sequence) {
|
|
4606
4818
|
const synthesizers = [];
|
|
@@ -4659,6 +4871,7 @@ function convertSequence(sequence, output) {
|
|
|
4659
4871
|
BioSpring: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.asoGapmersGcrsToBioSpring)(sequence),
|
|
4660
4872
|
Mermade12: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.gcrsToMermade12)(sequence),
|
|
4661
4873
|
GCRS: sequence,
|
|
4874
|
+
LCMS: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.gcrsToLcms)(sequence),
|
|
4662
4875
|
};
|
|
4663
4876
|
}
|
|
4664
4877
|
if (output.synthesizer.includes(_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.RAW_NUCLEOTIDES) && output.technology.includes(_map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.RNA)) {
|
|
@@ -4696,6 +4909,7 @@ function convertSequence(sequence, output) {
|
|
|
4696
4909
|
Axolabs: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.siRnaGcrsToAxolabs)(sequence),
|
|
4697
4910
|
MM12: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.gcrsToMermade12)(sequence),
|
|
4698
4911
|
GCRS: sequence,
|
|
4912
|
+
LCMS: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.gcrsToLcms)(sequence),
|
|
4699
4913
|
};
|
|
4700
4914
|
}
|
|
4701
4915
|
if (output.synthesizer.includes(_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.GCRS)) {
|
|
@@ -4704,6 +4918,7 @@ function convertSequence(sequence, output) {
|
|
|
4704
4918
|
Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.gcrsToNucleotides)(sequence),
|
|
4705
4919
|
GCRS: sequence,
|
|
4706
4920
|
Mermade12: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.gcrsToMermade12)(sequence),
|
|
4921
|
+
LCMS: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.gcrsToLcms)(sequence),
|
|
4707
4922
|
};
|
|
4708
4923
|
}
|
|
4709
4924
|
if (output.synthesizer.includes(_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.MERMADE_12)) {
|
|
@@ -4752,17 +4967,6 @@ module.exports = DG;
|
|
|
4752
4967
|
|
|
4753
4968
|
/***/ }),
|
|
4754
4969
|
|
|
4755
|
-
/***/ "openchemlib/full.js":
|
|
4756
|
-
/*!**********************!*\
|
|
4757
|
-
!*** external "OCL" ***!
|
|
4758
|
-
\**********************/
|
|
4759
|
-
/***/ ((module) => {
|
|
4760
|
-
|
|
4761
|
-
"use strict";
|
|
4762
|
-
module.exports = OCL;
|
|
4763
|
-
|
|
4764
|
-
/***/ }),
|
|
4765
|
-
|
|
4766
4970
|
/***/ "datagrok-api/grok":
|
|
4767
4971
|
/*!***********************!*\
|
|
4768
4972
|
!*** external "grok" ***!
|
|
@@ -4873,15 +5077,14 @@ __webpack_require__.r(__webpack_exports__);
|
|
|
4873
5077
|
/* harmony import */ var datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__);
|
|
4874
5078
|
/* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! datagrok-api/dg */ "datagrok-api/dg");
|
|
4875
5079
|
/* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__);
|
|
4876
|
-
/* harmony import */ var
|
|
4877
|
-
/* harmony import */ var
|
|
4878
|
-
/* harmony import */ var
|
|
4879
|
-
/* harmony import */ var
|
|
4880
|
-
/* harmony import */ var
|
|
4881
|
-
/* harmony import */ var
|
|
4882
|
-
/* harmony import */ var
|
|
4883
|
-
/* harmony import */ var
|
|
4884
|
-
/* harmony import */ var _structures_works_map__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./structures-works/map */ "./src/structures-works/map.ts");
|
|
5080
|
+
/* harmony import */ var cash_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! cash-dom */ "./node_modules/cash-dom/dist/cash.js");
|
|
5081
|
+
/* harmony import */ var cash_dom__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(cash_dom__WEBPACK_IMPORTED_MODULE_3__);
|
|
5082
|
+
/* harmony import */ var _defineAxolabsPattern__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./defineAxolabsPattern */ "./src/defineAxolabsPattern.ts");
|
|
5083
|
+
/* harmony import */ var _structures_works_save_sense_antisense__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./structures-works/save-sense-antisense */ "./src/structures-works/save-sense-antisense.ts");
|
|
5084
|
+
/* harmony import */ var _structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./structures-works/from-monomers */ "./src/structures-works/from-monomers.ts");
|
|
5085
|
+
/* harmony import */ var _structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./structures-works/sequence-codes-tools */ "./src/structures-works/sequence-codes-tools.ts");
|
|
5086
|
+
/* harmony import */ var _structures_works_map__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./structures-works/map */ "./src/structures-works/map.ts");
|
|
5087
|
+
/* harmony import */ var _structures_works_converters__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./structures-works/converters */ "./src/structures-works/converters.ts");
|
|
4885
5088
|
/* harmony import */ var _salts__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./salts */ "./src/salts.ts");
|
|
4886
5089
|
/* harmony import */ var _users__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./users */ "./src/users.ts");
|
|
4887
5090
|
/* harmony import */ var _ICDs__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./ICDs */ "./src/ICDs.ts");
|
|
@@ -4896,6 +5099,7 @@ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _argume
|
|
|
4896
5099
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
4897
5100
|
});
|
|
4898
5101
|
};
|
|
5102
|
+
var _a;
|
|
4899
5103
|
/* Do not change these import lines. Datagrok will import API library in exactly the same manner */
|
|
4900
5104
|
|
|
4901
5105
|
|
|
@@ -4930,11 +5134,11 @@ function sequenceTranslator() {
|
|
|
4930
5134
|
let errorsExist = false;
|
|
4931
5135
|
try {
|
|
4932
5136
|
sequence = sequence.replace(/\s/g, '');
|
|
4933
|
-
const output = (0,
|
|
5137
|
+
const output = (0,_structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_7__.isValidSequence)(sequence, null);
|
|
4934
5138
|
if (isSet)
|
|
4935
5139
|
output.synthesizer = [inputFormat];
|
|
4936
5140
|
inputFormatChoiceInput.value = output.synthesizer[0];
|
|
4937
|
-
const outputSequenceObj = (0,
|
|
5141
|
+
const outputSequenceObj = (0,_structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_7__.convertSequence)(sequence, output);
|
|
4938
5142
|
const tableRows = [];
|
|
4939
5143
|
for (const key of Object.keys(outputSequenceObj).slice(1)) {
|
|
4940
5144
|
const indexOfFirstNotValidChar = ('indexOfFirstNotValidChar' in outputSequenceObj) ?
|
|
@@ -4976,22 +5180,22 @@ function sequenceTranslator() {
|
|
|
4976
5180
|
outputTableDiv.append(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([
|
|
4977
5181
|
datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.HtmlTable.create(tableRows, (item) => [item.key, item.value], ['Code', 'Sequence']).root,
|
|
4978
5182
|
]));
|
|
4979
|
-
if (outputSequenceObj.type !=
|
|
5183
|
+
if (outputSequenceObj.type != _structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_7__.undefinedInputSequence && outputSequenceObj.Error != _structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_7__.undefinedInputSequence) {
|
|
4980
5184
|
const canvas = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.canvas(300, 170);
|
|
4981
5185
|
canvas.addEventListener('click', () => {
|
|
4982
|
-
const canv = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.canvas(
|
|
4983
|
-
const mol = (0,
|
|
5186
|
+
const canv = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.canvas(cash_dom__WEBPACK_IMPORTED_MODULE_3___default()(window).width(), cash_dom__WEBPACK_IMPORTED_MODULE_3___default()(window).height());
|
|
5187
|
+
const mol = (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_6__.sequenceToMolV3000)(inputSequenceField.value.replace(/\s/g, ''), false, true, output.synthesizer[0]);
|
|
4984
5188
|
// @ts-ignore
|
|
4985
|
-
|
|
5189
|
+
OCL.StructureView.drawMolecule(canv, OCL.Molecule.fromMolfile(mol), { suppressChiralText: true });
|
|
4986
5190
|
datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.dialog('Molecule: ' + inputSequenceField.value)
|
|
4987
5191
|
.add(canv)
|
|
4988
5192
|
.showModal(true);
|
|
4989
5193
|
});
|
|
4990
|
-
|
|
4991
|
-
|
|
4992
|
-
const mol = (0,
|
|
5194
|
+
cash_dom__WEBPACK_IMPORTED_MODULE_3___default()(canvas).on('mouseover', () => cash_dom__WEBPACK_IMPORTED_MODULE_3___default()(canvas).css('cursor', 'zoom-in'));
|
|
5195
|
+
cash_dom__WEBPACK_IMPORTED_MODULE_3___default()(canvas).on('mouseout', () => cash_dom__WEBPACK_IMPORTED_MODULE_3___default()(canvas).css('cursor', 'default'));
|
|
5196
|
+
const mol = (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_6__.sequenceToMolV3000)(inputSequenceField.value.replace(/\s/g, ''), false, true, output.synthesizer[0]);
|
|
4993
5197
|
// @ts-ignore
|
|
4994
|
-
|
|
5198
|
+
OCL.StructureView.drawMolecule(canvas, OCL.Molecule.fromMolfile(mol), { suppressChiralText: true });
|
|
4995
5199
|
moleculeSvgDiv.append(canvas);
|
|
4996
5200
|
}
|
|
4997
5201
|
else
|
|
@@ -5001,7 +5205,7 @@ function sequenceTranslator() {
|
|
|
5001
5205
|
pi.close();
|
|
5002
5206
|
}
|
|
5003
5207
|
}
|
|
5004
|
-
const inputFormatChoiceInput = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('Input format: ', 'Janssen GCRS Codes', Object.keys(
|
|
5208
|
+
const inputFormatChoiceInput = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('Input format: ', 'Janssen GCRS Codes', Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.map), (format) => {
|
|
5005
5209
|
updateTableAndMolecule(inputSequenceField.value.replace(/\s/g, ''), format, true);
|
|
5006
5210
|
});
|
|
5007
5211
|
const moleculeSvgDiv = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.block([]);
|
|
@@ -5039,7 +5243,7 @@ function sequenceTranslator() {
|
|
|
5039
5243
|
{ 'Name': 'ps linkage', 'BioSpring': '*', 'Axolabs': 's', 'Janssen GCRS': 'ps' },
|
|
5040
5244
|
]), { showRowHeader: false, showCellTooltip: false });
|
|
5041
5245
|
const overhangModificationsGrid = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Viewer.grid(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromColumns([
|
|
5042
|
-
datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Column.fromStrings('Name', Object.keys(
|
|
5246
|
+
datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Column.fromStrings('Name', Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.MODIFICATIONS)),
|
|
5043
5247
|
]), { showRowHeader: false, showCellTooltip: false });
|
|
5044
5248
|
updateTableAndMolecule(defaultInput, inputFormatChoiceInput.value, true);
|
|
5045
5249
|
const appMainDescription = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.info([
|
|
@@ -5079,24 +5283,25 @@ function sequenceTranslator() {
|
|
|
5079
5283
|
]),
|
|
5080
5284
|
codesTablesDiv,
|
|
5081
5285
|
], { style: { height: '100%', width: '100%' } })),
|
|
5082
|
-
'AXOLABS': (0,
|
|
5083
|
-
'SDF': (0,
|
|
5286
|
+
'AXOLABS': (0,_defineAxolabsPattern__WEBPACK_IMPORTED_MODULE_4__.defineAxolabsPattern)(),
|
|
5287
|
+
'SDF': (0,_structures_works_save_sense_antisense__WEBPACK_IMPORTED_MODULE_5__.saveSenseAntiSense)(),
|
|
5084
5288
|
});
|
|
5289
|
+
cash_dom__WEBPACK_IMPORTED_MODULE_3___default()(codesTablesDiv).hide();
|
|
5085
5290
|
const v = datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.newView('Sequence Translator', [tabControl]);
|
|
5086
5291
|
v.box = true;
|
|
5087
|
-
const switchInput = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.switchInput('Codes',
|
|
5088
|
-
|
|
5089
|
-
|
|
5292
|
+
const switchInput = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.switchInput('Codes', false, (v) => (v) ?
|
|
5293
|
+
cash_dom__WEBPACK_IMPORTED_MODULE_3___default()(codesTablesDiv).show() :
|
|
5294
|
+
cash_dom__WEBPACK_IMPORTED_MODULE_3___default()(codesTablesDiv).hide());
|
|
5090
5295
|
const topPanel = [
|
|
5091
5296
|
datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.iconFA('download', () => {
|
|
5092
|
-
const result = (0,
|
|
5297
|
+
const result = (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_6__.sequenceToMolV3000)(inputSequenceField.value.replace(/\s/g, ''), false, false, inputFormatChoiceInput.value);
|
|
5093
5298
|
const element = document.createElement('a');
|
|
5094
5299
|
element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(result));
|
|
5095
5300
|
element.setAttribute('download', inputSequenceField.value.replace(/\s/g, '') + '.mol');
|
|
5096
5301
|
element.click();
|
|
5097
5302
|
}, 'Save .mol file'),
|
|
5098
5303
|
datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.iconFA('copy', () => {
|
|
5099
|
-
navigator.clipboard.writeText((0,
|
|
5304
|
+
navigator.clipboard.writeText((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_6__.sequenceToSmiles)(inputSequenceField.value.replace(/\s/g, ''), false, inputFormatChoiceInput.value))
|
|
5100
5305
|
.then(() => datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.info(sequenceWasCopied));
|
|
5101
5306
|
}, 'Copy SMILES'),
|
|
5102
5307
|
switchInput.root,
|
|
@@ -5108,19 +5313,19 @@ function saveTableAsSdFile(table) {
|
|
|
5108
5313
|
return __awaiter(this, void 0, void 0, function* () {
|
|
5109
5314
|
if (!table.columns.contains('Compound Name')) {
|
|
5110
5315
|
datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.warning('File saved without columns \'' +
|
|
5111
|
-
[
|
|
5112
|
-
|
|
5316
|
+
[_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.COMPOUND_NAME, _structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.COMPOUND_COMMENTS, _structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.CPD_MW,
|
|
5317
|
+
_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.SALT_MASS, _structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.BATCH_MW].join('\', \''));
|
|
5113
5318
|
}
|
|
5114
|
-
const structureColumn = table.col(
|
|
5115
|
-
const typeColumn = table.col(
|
|
5319
|
+
const structureColumn = table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.SEQUENCE);
|
|
5320
|
+
const typeColumn = table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.TYPE);
|
|
5116
5321
|
let result = '';
|
|
5117
5322
|
for (let i = 0; i < table.rowCount; i++) {
|
|
5118
|
-
const format = (0,
|
|
5323
|
+
const format = (0,_structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_7__.getFormat)(structureColumn.get(i));
|
|
5119
5324
|
result += (typeColumn.get(i) == 'SS') ?
|
|
5120
|
-
(0,
|
|
5121
|
-
(0,
|
|
5325
|
+
(0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_6__.sequenceToMolV3000)(structureColumn.get(i), false, true, format) + '\n' + `> <Sequence>\nSense Strand\n\n` :
|
|
5326
|
+
(0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_6__.sequenceToMolV3000)(structureColumn.get(i), true, true, format) + '\n' + `> <Sequence>\nAnti Sense\n\n`;
|
|
5122
5327
|
for (const col of table.columns) {
|
|
5123
|
-
if (col.name !=
|
|
5328
|
+
if (col.name != _structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.SEQUENCE)
|
|
5124
5329
|
result += `> <${col.name}>\n${col.get(i)}\n\n`;
|
|
5125
5330
|
}
|
|
5126
5331
|
result += '$$$$\n\n';
|
|
@@ -5132,13 +5337,13 @@ function saveTableAsSdFile(table) {
|
|
|
5132
5337
|
});
|
|
5133
5338
|
}
|
|
5134
5339
|
const weightsObj = {};
|
|
5135
|
-
for (const synthesizer of Object.keys(
|
|
5136
|
-
for (const technology of Object.keys(
|
|
5137
|
-
for (const code of Object.keys(
|
|
5138
|
-
weightsObj[code]
|
|
5340
|
+
for (const synthesizer of Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.map)) {
|
|
5341
|
+
for (const technology of Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.map[synthesizer])) {
|
|
5342
|
+
for (const code of Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.map[synthesizer][technology]))
|
|
5343
|
+
(_a = weightsObj[code]) !== null && _a !== void 0 ? _a : _structures_works_map__WEBPACK_IMPORTED_MODULE_8__.map[synthesizer][technology][code].weight;
|
|
5139
5344
|
}
|
|
5140
5345
|
}
|
|
5141
|
-
for (const [key, value] of Object.entries(
|
|
5346
|
+
for (const [key, value] of Object.entries(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.MODIFICATIONS))
|
|
5142
5347
|
weightsObj[key] = value.molecularWeight;
|
|
5143
5348
|
function sortByStringLengthInDescendingOrder(array) {
|
|
5144
5349
|
return array.sort(function (a, b) { return b.length - a.length; });
|
|
@@ -5147,7 +5352,7 @@ function stringifyItems(items) {
|
|
|
5147
5352
|
return '["' + items.join('", "') + '"]';
|
|
5148
5353
|
}
|
|
5149
5354
|
function molecularWeight(sequence, weightsObj) {
|
|
5150
|
-
const codes = sortByStringLengthInDescendingOrder(Object.keys(weightsObj)).concat(Object.keys(
|
|
5355
|
+
const codes = sortByStringLengthInDescendingOrder(Object.keys(weightsObj)).concat(Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.MODIFICATIONS));
|
|
5151
5356
|
let weight = 0;
|
|
5152
5357
|
let i = 0;
|
|
5153
5358
|
while (i < sequence.length) {
|
|
@@ -5160,8 +5365,48 @@ function molecularWeight(sequence, weightsObj) {
|
|
|
5160
5365
|
//tags: autostart
|
|
5161
5366
|
function autostartOligoSdFileSubscription() {
|
|
5162
5367
|
datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.events.onViewAdded.subscribe((v) => {
|
|
5163
|
-
if (v.type == 'TableView'
|
|
5164
|
-
|
|
5368
|
+
if (v.type == 'TableView') {
|
|
5369
|
+
if (v.dataFrame.columns.contains(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.TYPE))
|
|
5370
|
+
oligoSdFile(v.dataFrame);
|
|
5371
|
+
datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.events.onContextMenu.subscribe((args) => {
|
|
5372
|
+
const seqCol = args.args.context.table.currentCol;
|
|
5373
|
+
if (datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) => /^[fsACGUacgu]{6,}$/.test(s))) {
|
|
5374
|
+
args.args.menu.item('Convert Axolabs to GCRS', () => {
|
|
5375
|
+
args.args.context.table.columns.addNewString(seqCol.name + ' to GCRS').init((i) => {
|
|
5376
|
+
return (0,_structures_works_converters__WEBPACK_IMPORTED_MODULE_9__.siRnaAxolabsToGcrs)(seqCol.get(i));
|
|
5377
|
+
});
|
|
5378
|
+
});
|
|
5379
|
+
}
|
|
5380
|
+
else if (datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) => /^[fmpsACGU]{6,}$/.test(s)) ||
|
|
5381
|
+
datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) => /^(?=.*moe)(?=.*5mC)(?=.*ps){6,}/.test(s))) {
|
|
5382
|
+
args.args.menu.item('Convert GCRS to raw', () => {
|
|
5383
|
+
args.args.context.table.columns.addNewString(seqCol.name + ' to raw').init((i) => {
|
|
5384
|
+
return (0,_structures_works_converters__WEBPACK_IMPORTED_MODULE_9__.gcrsToNucleotides)(seqCol.get(i));
|
|
5385
|
+
});
|
|
5386
|
+
});
|
|
5387
|
+
args.args.menu.item('Convert GCRS to MM12', () => {
|
|
5388
|
+
args.args.context.table.columns.addNewString(seqCol.name + ' to MM12').init((i) => {
|
|
5389
|
+
return (0,_structures_works_converters__WEBPACK_IMPORTED_MODULE_9__.gcrsToMermade12)(seqCol.get(i));
|
|
5390
|
+
});
|
|
5391
|
+
});
|
|
5392
|
+
}
|
|
5393
|
+
else if (datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) => /^[*56789ATGC]{6,}$/.test(s))) {
|
|
5394
|
+
args.args.menu.item('Convert Biospring to GCRS', () => {
|
|
5395
|
+
const seqCol = args.args.context.table.currentCol;
|
|
5396
|
+
args.args.context.table.columns.addNewString(seqCol.name + ' to GCRS').init((i) => {
|
|
5397
|
+
return (0,_structures_works_converters__WEBPACK_IMPORTED_MODULE_9__.asoGapmersBioSpringToGcrs)(seqCol.get(i));
|
|
5398
|
+
});
|
|
5399
|
+
});
|
|
5400
|
+
}
|
|
5401
|
+
else if (datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) => /^[*1-8]{6,}$/.test(s))) {
|
|
5402
|
+
args.args.menu.item('Convert Biospring to GCRS', () => {
|
|
5403
|
+
args.args.context.table.columns.addNewString(seqCol.name + ' to GCRS').init((i) => {
|
|
5404
|
+
return (0,_structures_works_converters__WEBPACK_IMPORTED_MODULE_9__.siRnaAxolabsToGcrs)(seqCol.get(i));
|
|
5405
|
+
});
|
|
5406
|
+
});
|
|
5407
|
+
}
|
|
5408
|
+
});
|
|
5409
|
+
}
|
|
5165
5410
|
});
|
|
5166
5411
|
}
|
|
5167
5412
|
function oligoSdFile(table) {
|
|
@@ -5171,25 +5416,25 @@ function oligoSdFile(table) {
|
|
|
5171
5416
|
const icdsDf = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromCsv(_ICDs__WEBPACK_IMPORTED_MODULE_12__.ICDS);
|
|
5172
5417
|
const idpsDf = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromCsv(_IDPs__WEBPACK_IMPORTED_MODULE_14__.IDPS);
|
|
5173
5418
|
function addColumns(t, saltsDf) {
|
|
5174
|
-
if (t.columns.contains(
|
|
5419
|
+
if (t.columns.contains(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.COMPOUND_NAME))
|
|
5175
5420
|
return datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.error('Columns already exist!');
|
|
5176
|
-
const sequence = t.col(
|
|
5177
|
-
const salt = t.col(
|
|
5178
|
-
const equivalents = t.col(
|
|
5179
|
-
t.columns.addNewString(
|
|
5180
|
-
t.columns.addNewString(
|
|
5421
|
+
const sequence = t.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.SEQUENCE);
|
|
5422
|
+
const salt = t.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.SALT);
|
|
5423
|
+
const equivalents = t.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.EQUIVALENTS);
|
|
5424
|
+
t.columns.addNewString(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.COMPOUND_NAME).init((i) => sequence.get(i));
|
|
5425
|
+
t.columns.addNewString(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.COMPOUND_COMMENTS).init((i) => (i > 0 && i % 2 == 0) ?
|
|
5181
5426
|
sequence.getString(i) + '; duplex of SS: ' + sequence.getString(i - 2) + ' and AS: ' + sequence.getString(i - 1) :
|
|
5182
5427
|
sequence.getString(i));
|
|
5183
5428
|
const molWeightCol = saltsDf.col('MOLWEIGHT');
|
|
5184
5429
|
const saltNamesList = saltsDf.col('DISPLAY').toList();
|
|
5185
|
-
t.columns.addNewFloat(
|
|
5430
|
+
t.columns.addNewFloat(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.CPD_MW)
|
|
5186
5431
|
.init((i) => molecularWeight(sequence.get(i), weightsObj));
|
|
5187
|
-
t.columns.addNewFloat(
|
|
5432
|
+
t.columns.addNewFloat(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.SALT_MASS).init((i) => {
|
|
5188
5433
|
const saltRowIndex = saltNamesList.indexOf(salt.get(i));
|
|
5189
5434
|
const mw = molWeightCol.get(saltRowIndex);
|
|
5190
5435
|
return mw * equivalents.get(i);
|
|
5191
5436
|
});
|
|
5192
|
-
t.columns.addNewCalculated(
|
|
5437
|
+
t.columns.addNewCalculated(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.BATCH_MW, '${' + _structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.CPD_MW + '} + ${' + _structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.SALT_MASS + '}', datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.COLUMN_TYPE.FLOAT, false);
|
|
5193
5438
|
addColumnsPressed = true;
|
|
5194
5439
|
return newDf = t;
|
|
5195
5440
|
}
|
|
@@ -5198,22 +5443,22 @@ function oligoSdFile(table) {
|
|
|
5198
5443
|
const d = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([
|
|
5199
5444
|
datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.icons.edit(() => {
|
|
5200
5445
|
d.innerHTML = '';
|
|
5201
|
-
if (table.col(
|
|
5202
|
-
table.changeColumnType(
|
|
5446
|
+
if (table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.IDP).type != datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.COLUMN_TYPE.STRING)
|
|
5447
|
+
table.changeColumnType(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.IDP, datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.COLUMN_TYPE.STRING);
|
|
5203
5448
|
d.append(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.link('Add Columns', () => {
|
|
5204
5449
|
addColumns(table, saltsDf);
|
|
5205
|
-
datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.tableView(table.name).grid.columns.setOrder(Object.values(
|
|
5206
|
-
}, 'Add columns: \'' + [
|
|
5207
|
-
|
|
5450
|
+
datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.tableView(table.name).grid.columns.setOrder(Object.values(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES));
|
|
5451
|
+
}, 'Add columns: \'' + [_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.COMPOUND_NAME, _structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.COMPOUND_COMMENTS, _structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.CPD_MW,
|
|
5452
|
+
_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.SALT_MASS, _structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.BATCH_MW].join('\', \''), ''), datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.button('Save SD file', () => saveTableAsSdFile(addColumnsPressed ? newDf : table)));
|
|
5208
5453
|
const view = datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.getTableView(table.name);
|
|
5209
|
-
view.table.col(
|
|
5210
|
-
view.table.col(
|
|
5211
|
-
view.table.col(
|
|
5212
|
-
view.table.col(
|
|
5213
|
-
view.table.col(
|
|
5214
|
-
view.table.col(
|
|
5454
|
+
view.table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.TYPE).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, '["AS", "SS", "Duplex"]');
|
|
5455
|
+
view.table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.OWNER).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, stringifyItems(usersDf.columns.byIndex(0).toList()));
|
|
5456
|
+
view.table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.SALT).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, stringifyItems(saltsDf.columns.byIndex(0).toList()));
|
|
5457
|
+
view.table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.SOURCE).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, stringifyItems(sourcesDf.columns.byIndex(0).toList()));
|
|
5458
|
+
view.table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.ICD).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, stringifyItems(icdsDf.columns.byIndex(0).toList()));
|
|
5459
|
+
view.table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.IDP).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, stringifyItems(idpsDf.columns.byIndex(0).toList()));
|
|
5215
5460
|
datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.events.onContextMenu.subscribe((args) => {
|
|
5216
|
-
if ([
|
|
5461
|
+
if ([_structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.TYPE, _structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.OWNER, _structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.SALT, _structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.SOURCE, _structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.ICD, _structures_works_map__WEBPACK_IMPORTED_MODULE_8__.COL_NAMES.IDP]
|
|
5217
5462
|
.includes(args.args.context.table.currentCol.name)) {
|
|
5218
5463
|
args.args.menu.item('Fill Column With Value', () => {
|
|
5219
5464
|
const v = args.args.context.table.currentCell.value;
|
|
@@ -5231,4 +5476,4 @@ function oligoSdFile(table) {
|
|
|
5231
5476
|
sequencetranslator = __webpack_exports__;
|
|
5232
5477
|
/******/ })()
|
|
5233
5478
|
;
|
|
5234
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"package.js","mappings":";;;;;;;;;;AAAA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;;AAErB;AACA;AACA,EAAE;AACF;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN,mCAAmC;AACnC;;AAEA;AACA;;AAEA,qCAAqC,OAAO;AAC5C;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA,+BAA+B;;AAE/B;AACA,oBAAoB;;AAEpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA,GAAG;;;AAGH;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA,eAAe;;AAEf;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;;AAEA,qCAAqC,OAAO;AAC5C;AACA;AACA;AACA,IAAI;AACJ,oCAAoC,OAAO;AAC3C;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;;AAEA,mBAAmB,uBAAuB;AAC1C;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,kBAAkB,YAAY;AAC9B;;AAEA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA,GAAG;AACH;;;AAGA;AACA;AACA;AACA,IAAI;AACJ;AACA,IAAI;AACJ;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH,GAAG;;;AAGH;AACA;AACA,EAAE;;;AAGF;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,kCAAkC,OAAO;AACzC;AACA;AACA;AACA,MAAM;AACN;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;AAEA;AACA;AACA,GAAG;AACH;;;AAGA;AACA;AACA;AACA;AACA,EAAE;;;AAGF;AACA;AACA;;AAEA,2BAA2B;;AAE3B;AACA;AACA,EAAE;AACF;AACA;AACA;AACA;;;AAGA,sBAAsB;AACtB;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;AAEA,EAAE;AACF;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,QAAQ;AACR;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,cAAc;AACd;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,EAAE;AACF;;;AAGA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,gBAAgB;;AAEhB;AACA;AACA;AACA,EAAE;;;AAGF;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH,CAAC;AACD;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,CAAC,GAAG;AACJ;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAE;;;AAGF;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;;AAGA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD;AACA;AACA;AACA,CAAC;AACD,8EAA8E;;AAE9E;AACA;AACA,EAAE;;;AAGF;AACA;AACA,EAAE;AACF;;;AAGA;AACA;AACA;AACA;AACA;AACA,EAAE;;;AAGF;AACA;AACA,4CAA4C;AAC5C,EAAE;AACF;AACA;;;AAGA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL,IAAI;AACJ;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA,wFAAwF;;AAExF;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,8BAA8B;AAC9B;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,uCAAuC;;AAEvC;;AAEA,wCAAwC;AACxC;;AAEA;AACA,GAAG;AACH,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT,QAAQ;AACR;AACA;AACA,MAAM;AACN;AACA;AACA,GAAG;AACH;;AAEA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA,GAAG;AACH,GAAG;AACH;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,GAAG;AACH,EAAE;;;AAGF;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA,EAAE;;;AAGF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL,GAAG;AACH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA,IAAI,IAA8B;AAClC;AACA;AACA,EAAE,KAAK,EAGN;AACD,CAAC;;;;;;;;;;;AC71CD,gEAAa;;AAEb;AACA,aAAa,KAA6B,eAAe,KAA4B,OAAO;AAC5F,MAAM,IAA6B,EAAE,iCAA0B,EAAE,mCAAE;AACnE;AACA,GAAG;AAAA,kGAAC;AACJ;;AAEA;AACA;AACA;AACA,8KAA8K;AAC9K;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,mFAAmF;AACnF;AACA;AACA;AACA,qCAAqC,iEAAiE;AACtG,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,2EAA2E,EAAE;AAC7E;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA,6DAA6D;AAC7D;AACA;AACA,oBAAoB,uBAAuB;AAC3C;AACA;AACA,gCAAgC,kBAAkB;AAClD;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;;AAEA;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,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mFAAmF;AACnF;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB,QAAQ;AACR;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA,4BAA4B;AAC5B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,qBAAqB,cAAc;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,yGAAyG;AACzG;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA,OAAO;AACP,KAAK;;AAEL;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA,eAAe;AACf;AACA;;AAEA;AACA;;AAEA,6BAA6B;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,kDAAkD;;AAElD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;;AAEA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA,iEAAiE,cAAc;AAC/E,QAAQ;AACR;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,mEAAmE,cAAc;AACjF,SAAS;AACT;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,uCAAuC;AACvC;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;AAEA,6BAA6B;AAC7B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,oCAAoC;;AAEpC;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA,sEAAsE;AACtE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA,qFAAqF;AACrF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;;AAEA;AACA,0CAA0C;AAC1C;AACA,gDAAgD;AAChD,KAAK;AACL;AACA,KAAK;AACL;;AAEA;AACA,0CAA0C;AAC1C;AACA,+CAA+C;AAC/C,KAAK;AACL;AACA,KAAK;AACL;AACA,CAAC;;;;;;;;;;;;;;;AC5bM;AACP;AACA;;;;;;;;;;;;;;;;ACFO;AACP;AACA;;;;;;;;;;;;;;;;ACFA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;;;;;;;;;;;;;;;;;;;;;;;;;;;;AClGA,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;AACA;AAC0C;AACJ;AACA;AACtC;AACuC;AACd;AACiC;AAChB;AAC1C,gCAAgC,mDAAU;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,mDAAU;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,iEAAuB;AAC5C;AACA;AACA,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA,oBAAoB,wBAAwB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,wBAAwB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,uEAAoC;AAClE,uBAAuB,mDAAU;AACjC;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,0DAAgB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,0DAAgB;AACpC;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,oBAAoB;AAC5C,+BAA+B,sDAAY;AAC3C;AACA;AACA,aAAa;AACb,yBAAyB,wDAAc;AACvC;AACA;AACA,uDAAuD,sDAAY;AACnE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,uCAAuC,iDAAO;AAC9C,gBAAgB,gDAAM,EAAE,kDAAQ,2EAA2E,SAAS,iBAAiB;AACrI,gBAAgB,oDAAU;AAC1B,gBAAgB,gDAAM;AACtB,iBAAiB,SAAS,wBAAwB;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,oBAAoB;AAC5C,+BAA+B,sDAAY;AAC3C;AACA;AACA,aAAa;AACb,yBAAyB,wDAAc;AACvC;AACA;AACA,uDAAuD,sDAAY;AACnE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,uCAAuC,iDAAO;AAC9C,gBAAgB,gDAAM,EAAE,kDAAQ,2EAA2E,SAAS,iBAAiB;AACrI,gBAAgB,oDAAU;AAC1B,gBAAgB,gDAAM;AACtB,iBAAiB,SAAS,wBAAwB;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,mDAAS;AACrB,qBAAqB,oDAAU;AAC/B;AACA,qBAAqB,oDAAU;AAC/B;AACA;AACA;AACA;AACA,wBAAwB,0BAA0B;AAClD;AACA,wBAAwB,0BAA0B;AAClD;AACA;AACA;AACA;AACA,wBAAwB,oBAAoB;AAC5C;AACA,wBAAwB,oBAAoB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,iDAAO;AAC7B,YAAY,uEAAkB;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,kBAAkB;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,4EAAkC;AACzD,kBAAkB,uEAA6B;AAC/C;AACA;AACA;AACA;AACA;AACA,gCAAgC,2BAA2B;AAC3D,iCAAiC,wDAAc;AAC/C;AACA,gCAAgC,2BAA2B;AAC3D,iCAAiC,wDAAc;AAC/C;AACA;AACA,gCAAgC,iCAAiC;AACjE,uCAAuC,sDAAY;AACnD;AACA;AACA,gCAAgC,iCAAiC;AACjE,uCAAuC,sDAAY;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,mDAAS;AACpC,YAAY,+CAAC;AACb;AACA,qBAAqB,oDAAU;AAC/B,qBAAqB,oDAAU;AAC/B;AACA;AACA,gBAAgB,yDAAe;AAC/B;AACA,gBAAgB,sDAAY,GAAG,iEAAuB;AACtD,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB,iEAAuB;AAChD;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,6EAAmC;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,qBAAqB,yDAAe;AACjD,SAAS;AACT;AACA;AACA;AACA,YAAY,uEAA6B;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,wDAAc;AAChD,8CAA8C,wDAAc;AAC5D;AACA,kCAAkC,wDAAc;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,gDAAM;AAClD,wBAAwB,mDAAS,CAAC,mDAAS,uBAAuB;AAClE;AACA,gCAAgC,4DAAkB;AAClD;AACA,gCAAgC,4DAAkB;AAClD;AACA,sCAAsC,0EAAgC;AACtE,gDAAgD,yDAAe;AAC/D;AACA;AACA,yBAAyB;AACzB;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,gDAAM;AAC9C,oBAAoB,mDAAS,CAAC,mDAAS,uBAAuB;AAC9D;AACA,4BAA4B,4DAAkB;AAC9C;AACA,4BAA4B,4DAAkB;AAC9C;AACA,kCAAkC,0EAAgC;AAClE,4CAA4C,yDAAe;AAC3D;AACA;AACA,qBAAqB;AACrB;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA,kBAAkB,uEAA6B;AAC/C;AACA;AACA,mCAAmC,mDAAS;AAC5C,oBAAoB,+CAAC;AACrB;AACA,6BAA6B,oDAAU;AACvC,6BAA6B,oDAAU;AACvC;AACA,8BAA8B,0EAAgC;AAC9D;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,SAAS;AACT;AACA,6BAA6B,gDAAM;AACnC,6BAA6B,gDAAM;AACnC,6BAA6B,gDAAM;AACnC,gCAAgC,gDAAM;AACtC,gCAAgC,gDAAM;AACtC,mBAAmB,gDAAM;AACzB,yBAAyB,gDAAM;AAC/B,kCAAkC,gDAAM;AACxC,2BAA2B,gDAAM;AACjC,8BAA8B,gDAAM;AACpC,0BAA0B,gDAAM;AAChC,wCAAwC,iDAAO,EAAE,sDAAY;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,oDAAoD,wDAAc;AAClE,oDAAoD,wDAAc;AAClE,0DAA0D,sDAAY;AACtE,0DAA0D,sDAAY;AACtE,qBAAqB,qDAAW;AAChC,qBAAqB,qDAAW;AAChC,wBAAwB,gDAAM;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,qDAAW;AACnC,YAAY,0DAAgB;AAC5B;AACA;AACA,YAAY,mDAAS;AACrB,qBAAqB,oDAAU;AAC/B;AACA;AACA;AACA,gBAAgB,sDAAY,GAAG,iEAAuB;AACtD,gBAAgB,yDAAe;AAC/B,aAAa;AACb;AACA;AACA;AACA,mBAAmB,uDAAa,WAAW,8DAAoB,EAAE,2DAAiB;AAClF,8BAA8B,wDAAc;AAC5C;AACA;AACA,8BAA8B,wDAAc;AAC5C;AACA;AACA,8BAA8B,wDAAc;AAC5C;AACA;AACA,KAAK;AACL,0BAA0B,wDAAc;AACxC;AACA,0BAA0B,wDAAc;AACxC;AACA,0BAA0B,wDAAc;AACxC;AACA;AACA,yBAAyB,wDAAc;AACvC;AACA;AACA,KAAK;AACL,qBAAqB,sDAAY;AACjC;AACA;AACA;AACA;AACA,KAAK;AACL,uBAAuB,sDAAY;AACnC,uBAAuB,sDAAY;AACnC;AACA,2BAA2B,sDAAY;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,mBAAmB,sDAAY;AAC/B;AACA,gCAAgC,wDAAc;AAC9C;AACA;AACA,KAAK;AACL;AACA,+BAA+B,wDAAc;AAC7C;AACA;AACA,KAAK;AACL;AACA,gCAAgC,wDAAc;AAC9C;AACA;AACA,KAAK;AACL;AACA,+BAA+B,wDAAc;AAC7C;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,oBAAoB,sDAAY;AAChC,8BAA8B,mDAAS;AACvC;AACA,sCAAsC,yDAAe;AACrD;AACA,yBAAyB,wDAAc;AACvC,YAAY,mDAAS;AACrB;AACA;AACA;AACA,0CAA0C,yDAAe;AACzD,aAAa;AACb;AACA;AACA,KAAK;AACL,kCAAkC,mDAAS;AAC3C;AACA,YAAY,yDAAe;AAC3B;AACA,2BAA2B,mDAAS;AACpC,YAAY,+CAAC;AACb;AACA,qBAAqB,oDAAU;AAC/B;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,sDAAY,GAAG,iEAAuB;AAClD,YAAY,yDAAe;AAC3B;AACA;AACA,KAAK;AACL,2BAA2B,sDAAY;AACvC;AACA,KAAK;AACL,4BAA4B,sDAAY;AACxC;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,gDAAM;AACtC,QAAQ,mDAAS,CAAC,mDAAS,kBAAkB;AAC7C,4EAA4E,yDAAe;AAC3F,SAAS;AACT;AACA,2BAA2B,sDAAY;AACvC;AACA,KAAK;AACL,4BAA4B,sDAAY;AACxC;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,gDAAM;AACtC,QAAQ,mDAAS,CAAC,mDAAS,kBAAkB;AAC7C,4EAA4E,yDAAe;AAC3F,SAAS;AACT;AACA;AACA;AACA;AACA,2BAA2B,gDAAM;AACjC,QAAQ,+CAAK;AACb;AACA;AACA;AACA;AACA,0BAA0B,gDAAM;AAChC,QAAQ,+CAAK;AACb,QAAQ,iDAAO;AACf;AACA;AACA;AACA,QAAQ,iDAAO;AACf;AACA;AACA;AACA,QAAQ,yDAAe;AACvB;AACA;AACA;AACA,wBAAwB,kDAAQ;AAChC,QAAQ,kDAAQ;AAChB;AACA,aAAa,SAAS,uBAAuB;AAC7C,QAAQ,mDAAS,mBAAmB,yDAAgB;AACpD;AACA,QAAQ,gDAAM;AACd,YAAY,gDAAM;AAClB,gBAAgB,iDAAO;AACvB,oBAAoB,+CAAK;AACzB,oBAAoB,gDAAM;AAC1B,wBAAwB,mDAAS;AACjC;AACA;AACA,yBAAyB;AACzB,yBAAyB,SAAS,kBAAkB;AACpD;AACA,gBAAgB,iDAAO;AACvB,oBAAoB,gDAAM;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,yDAAe;AACvC;AACA;AACA;AACA,oBAAoB,gDAAM;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,SAAS,oBAAoB;AAC1C;AACA,kCAAkC,kDAAQ;AAC1C,QAAQ,+CAAK;AACb,QAAQ,iDAAO;AACf,YAAY,gDAAM,EAAE,oDAAU,UAAU,SAAS,iBAAiB;AAClE,YAAY,oDAAU,EAAE,oDAAU;AAClC,YAAY,gDAAM,EAAE,oDAAU,YAAY,SAAS,uBAAuB;AAC1E;AACA;AACA;AACA,kCAAkC,kDAAQ;AAC1C,QAAQ,+CAAK;AACb,QAAQ,iDAAO;AACf,YAAY,gDAAM,EAAE,oDAAU,UAAU,SAAS,iBAAiB;AAClE,YAAY,oDAAU,EAAE,oDAAU;AAClC,YAAY,gDAAM,EAAE,oDAAU,YAAY,SAAS,uBAAuB;AAC1E;AACA;AACA;AACA,iBAAiB,iDAAO;AACxB,QAAQ,oDAAU,oCAAoC,SAAS,2BAA2B;AAC1F,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB;AACA,WAAW,mDAAS;AACpB,QAAQ,gDAAM;AACd;AACA;AACA;AACA,QAAQ,gDAAM,CAAC,iDAAO;AACtB;AACA;AACA,cAAc,SAAS,qBAAqB;AAC5C;AACA;;;;;;;;;;;;;;;;;ACvsB0C;AAC1C;AACA;AACA,iCAAiC;AACjC;AACA,qCAAqC;AACrC;AACA;AACA;AACA,uDAAuD;AACvD;AACA,oBAAoB,yBAAyB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,mDAAU;AACrB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,oBAAoB;AACxC;AACA;AACA;AACA;AACA,qCAAqC,QAAQ;AAC7C;AACA;AACA;AACA,iLAAiL,mDAAU;AAC3L;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,oBAAoB;AACxC;AACA;AACA;AACA;AACA;AACA,yCAAyC,QAAQ;AACjD;AACA;AACA;AACA,gJAAgJ,mDAAU;AAC1J;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,wBAAwB;AAC5C;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;ACvLO;AACP;;;;;;;;;;;;;;;;ACDO;AACP;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACFA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA;AACA;AACA;AACA;AACA,2BAA2B;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,gGAAgG,gBAAgB;AAChH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,2HAA2H,gBAAgB;AAC3I;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,iGAAiG,gBAAgB;AACjH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,8BAA8B;AAC9B;AACA,+BAA+B;AAC/B;AACA,gCAAgC;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,8BAA8B;AAC9B;AACA,gCAAgC;AAChC;AACA,+BAA+B;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,gCAAgC;AAChC;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,kCAAkC;AAClC;AACA,gCAAgC;AAChC;AACA,gCAAgC;AAChC;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA;AACA,mJAAmJ,gBAAgB;AACnK;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA;AACA,mJAAmJ,gBAAgB;AACnK;;;;;;;;;;;;;;;;;;;;ACxQmG;AAC1C;AACC;AACnD;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,+CAAa;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA,gBAAgB,+CAAa,uBAAuB,+CAAa;AACjE,6BAA6B,4DAA0B;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,4DAA0B;AAC3D;AACA;AACA;AACA,WAAW,uEAAiB;AAC5B;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,+CAAa;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA,gBAAgB,+CAAa,uBAAuB,4DAA0B;AAC9E,gBAAgB,+CAAa,sBAAsB,4DAA0B;AAC7E;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,4DAA0B;AACxE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,mEAAiC;AACzE;AACA;AACA;AACA;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;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;;;;;;;;;;;;;;;;;;;;;ACtGO;AACP;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACO;AACA;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;;;;;;;;;;;;;;;;;;;AC/iB2C;AAC3C;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,oBAAoB,4BAA4B;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,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,wBAAwB,uBAAuB;AAC/C;AACA;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA,4BAA4B,oBAAoB;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D,oEAAuB;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA,uDAAuD;AACvD;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D,oEAAuB;AACnF;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA,uDAAuD;AACvD;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C;AAC9C,gDAAgD;AAChD;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,uDAAuD;AACvD;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;;;;;;;;;;;;;;;;;;;;;;ACtXsC;AACiC;AACH;AACC;AAC9D;AACP,qBAAqB,iFAAS;AAC9B,qBAAqB,iFAAS;AAC9B,kBAAkB,mFAAkB;AACpC,kBAAkB,mFAAkB;AACpC;AACA;AACA,iBAAiB,gFAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kDAAkD;AAClD;AACA;AACA;AACO;AACP,2BAA2B,kDAAQ;AACnC,oBAAoB,sDAAY;AAChC,oBAAoB,sDAAY;AAChC,uBAAuB,wDAAc;AACrC,oBAAoB,wDAAc;AAClC,oBAAoB,mDAAS;AAC7B,wBAAwB,kDAAQ;AAChC,QAAQ,gDAAM;AACd,YAAY,gDAAM;AAClB,gBAAgB,iDAAO,EAAE,+CAAK;AAC9B,gBAAgB,iDAAO;AACvB,oBAAoB,gDAAM;AAC1B,oBAAoB,gDAAM;AAC1B;AACA;AACA,oBAAoB,yDAAe;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;AC/CA;AACA;AACA;AACuE;AACye;AAChjB;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;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,kCAAkC,qCAAG;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC,qCAAG;AAC5C,yCAAyC,qCAAG;AAC5C,oCAAoC,+CAAa;AACjD;AACA;AACA;AACA,gBAAgB,qCAAG;AACnB;AACA;AACA;AACA,wBAAwB,qBAAqB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,gBAAgB,qCAAG;AACnB,kCAAkC,qCAAG,8CAA8C,+CAAa;AAChG;AACA;AACA,KAAK;AACL;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,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;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;AACA;AACA,oCAAoC,mDAAiB;AACrD;AACA,kBAAkB,mDAAiB;AACnC,yBAAyB,8DAAiB;AAC1C;AACA,uBAAuB,4DAAe;AACtC;AACA;AACA,oCAAoC,yDAAuB;AAC3D;AACA,kBAAkB,yDAAuB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;ACpRO;AACP;AACA;;;;;;;;;;;;ACFA;;;;;;;;;;;ACAA;;;;;;;;;;;ACAA;;;;;;;;;;;ACAA;;;;;;UCAA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;WACA;WACA;WACA;WACA;WACA,iCAAiC,WAAW;WAC5C;WACA;;;;;WCPA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA;;;;;WCPA;;;;;WCAA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACNA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACA;AAC0C;AACJ;AACA;AACK;AAClB;AACqC;AACe;AACW;AACsC;AACvD;AACnC;AACA;AACN;AACM;AACN;AACvB,qBAAqB,oDAAU;AACtC;AACA;AACA;AACA;AACA;AACO;AACP,oBAAoB,4DAAkB;AACtC;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,4EAAkC;AACrD;AACA;AACA;AACA,2BAA2B,uFAAe;AAC1C;AACA;AACA;AACA,sCAAsC,uFAAe;AACrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,iDAAO;AAC/B,4BAA4B,oDAAU,gDAAgD,SAAS,iBAAiB;AAChH,4BAA4B,yDAAe,CAAC,oDAAU,6CAA6C,SAAS,gBAAgB;AAC5H;AACA;AACA,wBAAwB,iDAAO;AAC/B,wCAAwC,yDAAe;AACvD,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA,6DAA6D,kCAAkC;AAC/F,+DAA+D,kCAAkC;AACjG;AACA,kCAAkC,gDAAM;AACxC,gBAAgB,6DAAmB;AACnC;AACA,0CAA0C,0FAAsB,+BAA+B,0FAAsB;AACrH,+BAA+B,mDAAS;AACxC;AACA,iCAAiC,mDAAS,CAAC,+CAAC,kBAAkB,+CAAC;AAC/D,gCAAgC,mFAAkB;AAClD;AACA,oBAAoB,2EAA8B,OAAO,qEAAwB,SAAS,0BAA0B;AACpH,oBAAoB,mDAAS;AAC7B;AACA;AACA,iBAAiB;AACjB,gBAAgB,+CAAC,+BAA+B,+CAAC;AACjD,gBAAgB,+CAAC,8BAA8B,+CAAC;AAChD,4BAA4B,mFAAkB;AAC9C;AACA,gBAAgB,2EAA8B,SAAS,qEAAwB,SAAS,0BAA0B;AAClH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,wDAAc,qDAAqD,sDAAG;AACzG;AACA,KAAK;AACL,2BAA2B,kDAAQ;AACnC,2BAA2B,gDAAM;AACjC,+BAA+B,sDAAY;AAC3C,kBAAkB,kEAAwB;AAC1C,UAAU,mEAAmE;AAC7E,UAAU,+DAA+D;AACzE,UAAU,qEAAqE;AAC/E,UAAU,+DAA+D;AACzE,UAAU,gEAAgE;AAC1E,UAAU,8DAA8D;AACxE,UAAU,yDAAyD;AACnE,UAAU,yDAAyD;AACnE,UAAU,yDAAyD;AACnE,UAAU,yDAAyD;AACnE,UAAU,qDAAqD;AAC/D,UAAU,qDAAqD;AAC/D,UAAU,qDAAqD;AAC/D,UAAU,qDAAqD;AAC/D;AACA,2BAA2B,wDAAc,UAAU,8CAA8C;AACjG;AACA,0EAA0E,yDAAe;AACzF,KAAK;AACL,6BAA6B,wDAAc,CAAC,kEAAwB;AACpE,UAAU,iFAAiF;AAC3F,UAAU,iFAAiF;AAC3F,UAAU,iFAAiF;AAC3F,UAAU,iFAAiF;AAC3F,UAAU,6EAA6E;AACvF,UAAU,6EAA6E;AACvF,UAAU,6EAA6E;AACvF,UAAU,6EAA6E;AACvF,UAAU,8EAA8E;AACxF,UAAU,8CAA8C;AACxD,sCAAsC,wDAAc,CAAC,kEAAwB;AAC7E,QAAQ,+DAAqB,qBAAqB,gEAAa;AAC/D,UAAU,8CAA8C;AACxD;AACA,+BAA+B,iDAAO;AACtC,QAAQ,oDAAU,mCAAmC,SAAS,2BAA2B;AACzF,QAAQ,oDAAU;AAClB,QAAQ,oDAAU,wCAAwC,SAAS,2BAA2B;AAC9F,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB;AACA,2BAA2B,mDAAS;AACpC,QAAQ,gDAAM,CAAC,+CAAK,mBAAmB,SAAS,qBAAqB;AACrE;AACA,QAAQ,gDAAM,CAAC,+CAAK,+BAA+B,SAAS,qBAAqB;AACjF;AACA,QAAQ,gDAAM,CAAC,+CAAK,8BAA8B,SAAS,qBAAqB;AAChF;AACA,SAAS,SAAS,qBAAqB;AACvC,uBAAuB,uDAAa;AACpC,gBAAgB,gDAAM,CAAC,mDAAS;AAChC,YAAY,mDAAS;AACrB,gBAAgB,kDAAQ;AACxB;AACA,oBAAoB,gDAAM;AAC1B,wBAAwB,+CAAK;AAC7B,wBAAwB,gDAAM;AAC9B;AACA;AACA;AACA,oBAAoB,gDAAM,6BAA6B,SAAS,oBAAoB;AACpF,oBAAoB,kDAAQ;AAC5B,wBAAwB,+CAAK;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,SAAS,iCAAiC;AACvD,mBAAmB,2EAAoB;AACvC,eAAe,0FAAkB;AACjC,KAAK;AACL,cAAc,4DAAkB;AAChC;AACA,wBAAwB,wDAAc;AACtC,QAAQ,+CAAC;AACT,QAAQ,+CAAC;AACT;AACA,QAAQ,mDAAS;AACjB,2BAA2B,mFAAkB;AAC7C;AACA,0DAA0D;AAC1D;AACA;AACA,SAAS;AACT,QAAQ,mDAAS;AACjB,0CAA0C,iFAAgB;AAC1D,4BAA4B,yDAAe;AAC3C,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,4DAAkB;AAC9B,iBAAiB,0EAAuB,EAAE,8EAA2B,EAAE,mEAAgB;AACvF,oBAAoB,sEAAmB,EAAE,qEAAkB;AAC3D;AACA,0CAA0C,qEAAkB;AAC5D,qCAAqC,iEAAc;AACnD;AACA,wBAAwB,oBAAoB;AAC5C,2BAA2B,iFAAS;AACpC;AACA,gBAAgB,mFAAkB;AAClC,gBAAgB,mFAAkB;AAClC;AACA,gCAAgC,qEAAkB;AAClD,qCAAqC,SAAS,KAAK,WAAW;AAC9D;AACA;AACA;AACA;AACA,sDAAsD;AACtD;AACA;AACA,KAAK;AACL;AACA;AACA,sCAAsC,sDAAG;AACzC,yCAAyC,sDAAG;AAC5C,uCAAuC,sDAAG;AAC1C,+BAA+B,sDAAG;AAClC;AACA;AACA,0CAA0C,gEAAa;AACvD;AACA;AACA,wCAAwC,6BAA6B;AACrE;AACA;AACA;AACA;AACA;AACA,kGAAkG,gEAAa;AAC/G;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP,IAAI,2EAAiC;AACrC,kEAAkE,iEAAc;AAChF;AACA,KAAK;AACL;AACO;AACP,oBAAoB,8DAAoB,CAAC,8CAAS;AAClD,oBAAoB,8DAAoB,CAAC,8CAAS;AAClD,sBAAsB,8DAAoB,CAAC,8CAAO;AAClD,mBAAmB,8DAAoB,CAAC,wCAAI;AAC5C,mBAAmB,8DAAoB,CAAC,wCAAI;AAC5C;AACA,+BAA+B,0EAAuB;AACtD,mBAAmB,0DAAgB;AACnC,+BAA+B,qEAAkB;AACjD,2BAA2B,iEAAc;AACzC,kCAAkC,wEAAqB;AACvD,+BAA+B,0EAAuB;AACtD,+BAA+B,8EAA2B;AAC1D,uCAAuC;AACvC;AACA;AACA;AACA,8BAA8B,mEAAgB;AAC9C;AACA,8BAA8B,sEAAmB;AACjD;AACA;AACA;AACA,SAAS;AACT,mCAAmC,qEAAkB,KAAK,IAAI,mEAAgB,MAAM,IAAI,IAAI,sEAAmB,KAAK,GAAG,8DAAoB;AAC3I;AACA;AACA;AACA;AACA;AACA,cAAc,gDAAM;AACpB,QAAQ,uDAAa;AACrB;AACA,0BAA0B,gEAAa,UAAU,+DAAqB;AACtE,uCAAuC,gEAAa,EAAE,+DAAqB;AAC3E,qBAAqB,iDAAO;AAC5B;AACA,gBAAgB,8DAAoB,iDAAiD,4DAAS;AAC9F,aAAa,uBAAuB,0EAAuB,EAAE,8EAA2B,EAAE,mEAAgB;AAC1G,gBAAgB,sEAAmB,EAAE,qEAAkB,uBAAuB,mDAAS;AACvF,yBAAyB,iEAAuB;AAChD,2BAA2B,iEAAc,SAAS,yDAAe;AACjE,2BAA2B,kEAAe,SAAS,yDAAe;AAClE,2BAA2B,iEAAc,SAAS,yDAAe;AACjE,2BAA2B,mEAAgB,SAAS,yDAAe;AACnE,2BAA2B,gEAAa,SAAS,yDAAe;AAChE,2BAA2B,gEAAa,SAAS,yDAAe;AAChE,YAAY,6EAAmC;AAC/C,qBAAqB,iEAAc,EAAE,kEAAe,EAAE,iEAAc,EAAE,mEAAgB,EAAE,gEAAa,EAAE,gEAAa;AACpH;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA,aAAa;AACb,SAAS;AACT;AACA,IAAI,sEAA4B;AAChC","sources":["webpack://sequencetranslator/./node_modules/cash-dom/dist/cash.js","webpack://sequencetranslator/./node_modules/save-svg-as-png/lib/saveSvgAsPng.js","webpack://sequencetranslator/./src/ICDs.ts","webpack://sequencetranslator/./src/IDPs.ts","webpack://sequencetranslator/./src/axolabsMap.ts","webpack://sequencetranslator/./src/defineAxolabsPattern.ts","webpack://sequencetranslator/./src/drawAxolabsPattern.ts","webpack://sequencetranslator/./src/salts.ts","webpack://sequencetranslator/./src/sources.ts","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/save-sense-antisense.ts","webpack://sequencetranslator/./src/structures-works/sequence-codes-tools.ts","webpack://sequencetranslator/./src/users.ts","webpack://sequencetranslator/external var \"DG\"","webpack://sequencetranslator/external var \"OCL\"","webpack://sequencetranslator/external var \"grok\"","webpack://sequencetranslator/external var \"ui\"","webpack://sequencetranslator/webpack/bootstrap","webpack://sequencetranslator/webpack/runtime/compat get default export","webpack://sequencetranslator/webpack/runtime/define property getters","webpack://sequencetranslator/webpack/runtime/hasOwnProperty shorthand","webpack://sequencetranslator/webpack/runtime/make namespace object","webpack://sequencetranslator/./src/package.ts"],"sourcesContent":["/* MIT https://github.com/fabiospampinato/cash */\n(function(){\n\"use strict\";\n\nvar propMap = {\n  /* GENERAL */\n  \"class\": 'className',\n  contenteditable: 'contentEditable',\n\n  /* LABEL */\n  \"for\": 'htmlFor',\n\n  /* INPUT */\n  readonly: 'readOnly',\n  maxlength: 'maxLength',\n  tabindex: 'tabIndex',\n\n  /* TABLE */\n  colspan: 'colSpan',\n  rowspan: 'rowSpan',\n\n  /* IMAGE */\n  usemap: 'useMap'\n};\n\nfunction attempt(fn, arg) {\n  try {\n    return fn(arg);\n  } catch (_a) {\n    return arg;\n  }\n}\n\nvar doc = document,\n    win = window,\n    docEle = doc.documentElement,\n    createElement = doc.createElement.bind(doc),\n    div = createElement('div'),\n    table = createElement('table'),\n    tbody = createElement('tbody'),\n    tr = createElement('tr'),\n    isArray = Array.isArray,\n    ArrayPrototype = Array.prototype,\n    concat = ArrayPrototype.concat,\n    filter = ArrayPrototype.filter,\n    indexOf = ArrayPrototype.indexOf,\n    map = ArrayPrototype.map,\n    push = ArrayPrototype.push,\n    slice = ArrayPrototype.slice,\n    some = ArrayPrototype.some,\n    splice = ArrayPrototype.splice;\nvar idRe = /^#(?:[\\w-]|\\\\.|[^\\x00-\\xa0])*$/,\n    classRe = /^\\.(?:[\\w-]|\\\\.|[^\\x00-\\xa0])*$/,\n    htmlRe = /<.+>/,\n    tagRe = /^\\w+$/; // @require ./variables.ts\n\nfunction find(selector, context) {\n  return !selector || !isDocument(context) && !isElement(context) ? [] : classRe.test(selector) ? context.getElementsByClassName(selector.slice(1)) : tagRe.test(selector) ? context.getElementsByTagName(selector) : context.querySelectorAll(selector);\n} // @require ./find.ts\n// @require ./variables.ts\n\n\nvar Cash =\n/** @class */\nfunction () {\n  function Cash(selector, context) {\n    if (!selector) return;\n    if (isCash(selector)) return selector;\n    var eles = selector;\n\n    if (isString(selector)) {\n      var ctx = (isCash(context) ? context[0] : context) || doc;\n      eles = idRe.test(selector) ? ctx.getElementById(selector.slice(1)) : htmlRe.test(selector) ? parseHTML(selector) : find(selector, ctx);\n      if (!eles) return;\n    } else if (isFunction(selector)) {\n      return this.ready(selector); //FIXME: `fn.ready` is not included in `core`, but it's actually a core functionality\n    }\n\n    if (eles.nodeType || eles === win) eles = [eles];\n    this.length = eles.length;\n\n    for (var i = 0, l = this.length; i < l; i++) {\n      this[i] = eles[i];\n    }\n  }\n\n  Cash.prototype.init = function (selector, context) {\n    return new Cash(selector, context);\n  };\n\n  return Cash;\n}();\n\nvar fn = Cash.prototype,\n    cash = fn.init;\ncash.fn = cash.prototype = fn; // Ensuring that `cash () instanceof cash`\n\nfn.length = 0;\nfn.splice = splice; // Ensuring a cash collection gets printed as array-like in Chrome's devtools\n\nif (typeof Symbol === 'function') {\n  // Ensuring a cash collection is iterable\n  fn[Symbol['iterator']] = ArrayPrototype[Symbol['iterator']];\n}\n\nfn.map = function (callback) {\n  return cash(concat.apply([], map.call(this, function (ele, i) {\n    return callback.call(ele, i, ele);\n  })));\n};\n\nfn.slice = function (start, end) {\n  return cash(slice.call(this, start, end));\n}; // @require ./cash.ts\n\n\nvar dashAlphaRe = /-([a-z])/g;\n\nfunction camelCase(str) {\n  return str.replace(dashAlphaRe, function (match, letter) {\n    return letter.toUpperCase();\n  });\n}\n\ncash.guid = 1; // @require ./cash.ts\n\nfunction matches(ele, selector) {\n  var matches = ele && (ele['matches'] || ele['webkitMatchesSelector'] || ele['msMatchesSelector']);\n  return !!matches && !!selector && matches.call(ele, selector);\n}\n\nfunction isCash(x) {\n  return x instanceof Cash;\n}\n\nfunction isWindow(x) {\n  return !!x && x === x.window;\n}\n\nfunction isDocument(x) {\n  return !!x && x.nodeType === 9;\n}\n\nfunction isElement(x) {\n  return !!x && x.nodeType === 1;\n}\n\nfunction isBoolean(x) {\n  return typeof x === 'boolean';\n}\n\nfunction isFunction(x) {\n  return typeof x === 'function';\n}\n\nfunction isString(x) {\n  return typeof x === 'string';\n}\n\nfunction isUndefined(x) {\n  return x === undefined;\n}\n\nfunction isNull(x) {\n  return x === null;\n}\n\nfunction isNumeric(x) {\n  return !isNaN(parseFloat(x)) && isFinite(x);\n}\n\nfunction isPlainObject(x) {\n  if (typeof x !== 'object' || x === null) return false;\n  var proto = Object.getPrototypeOf(x);\n  return proto === null || proto === Object.prototype;\n}\n\ncash.isWindow = isWindow;\ncash.isFunction = isFunction;\ncash.isArray = isArray;\ncash.isNumeric = isNumeric;\ncash.isPlainObject = isPlainObject;\n\nfn.get = function (index) {\n  if (isUndefined(index)) return slice.call(this);\n  index = Number(index);\n  return this[index < 0 ? index + this.length : index];\n};\n\nfn.eq = function (index) {\n  return cash(this.get(index));\n};\n\nfn.first = function () {\n  return this.eq(0);\n};\n\nfn.last = function () {\n  return this.eq(-1);\n};\n\nfunction each(arr, callback, _reverse) {\n  if (_reverse) {\n    var i = arr.length;\n\n    while (i--) {\n      if (callback.call(arr[i], i, arr[i]) === false) return arr;\n    }\n  } else if (isPlainObject(arr)) {\n    var keys = Object.keys(arr);\n\n    for (var i = 0, l = keys.length; i < l; i++) {\n      var key = keys[i];\n      if (callback.call(arr[key], key, arr[key]) === false) return arr;\n    }\n  } else {\n    for (var i = 0, l = arr.length; i < l; i++) {\n      if (callback.call(arr[i], i, arr[i]) === false) return arr;\n    }\n  }\n\n  return arr;\n}\n\ncash.each = each;\n\nfn.each = function (callback) {\n  return each(this, callback);\n};\n\nfn.prop = function (prop, value) {\n  if (!prop) return;\n\n  if (isString(prop)) {\n    prop = propMap[prop] || prop;\n    if (arguments.length < 2) return this[0] && this[0][prop];\n    return this.each(function (i, ele) {\n      ele[prop] = value;\n    });\n  }\n\n  for (var key in prop) {\n    this.prop(key, prop[key]);\n  }\n\n  return this;\n};\n\nfn.removeProp = function (prop) {\n  return this.each(function (i, ele) {\n    delete ele[propMap[prop] || prop];\n  });\n};\n\nfunction extend() {\n  var sources = [];\n\n  for (var _i = 0; _i < arguments.length; _i++) {\n    sources[_i] = arguments[_i];\n  }\n\n  var deep = isBoolean(sources[0]) ? sources.shift() : false,\n      target = sources.shift(),\n      length = sources.length;\n  if (!target) return {};\n  if (!length) return extend(deep, cash, target);\n\n  for (var i = 0; i < length; i++) {\n    var source = sources[i];\n\n    for (var key in source) {\n      if (deep && (isArray(source[key]) || isPlainObject(source[key]))) {\n        if (!target[key] || target[key].constructor !== source[key].constructor) target[key] = new source[key].constructor();\n        extend(deep, target[key], source[key]);\n      } else {\n        target[key] = source[key];\n      }\n    }\n  }\n\n  return target;\n}\n\ncash.extend = extend;\n\nfn.extend = function (plugins) {\n  return extend(fn, plugins);\n}; // @require ./matches.ts\n// @require ./type_checking.ts\n\n\nfunction getCompareFunction(comparator) {\n  return isString(comparator) ? function (i, ele) {\n    return matches(ele, comparator);\n  } : isFunction(comparator) ? comparator : isCash(comparator) ? function (i, ele) {\n    return comparator.is(ele);\n  } : !comparator ? function () {\n    return false;\n  } : function (i, ele) {\n    return ele === comparator;\n  };\n}\n\nfn.filter = function (comparator) {\n  var compare = getCompareFunction(comparator);\n  return cash(filter.call(this, function (ele, i) {\n    return compare.call(ele, i, ele);\n  }));\n}; // @require collection/filter.ts\n\n\nfunction filtered(collection, comparator) {\n  return !comparator ? collection : collection.filter(comparator);\n} // @require ./type_checking.ts\n\n\nvar splitValuesRe = /\\S+/g;\n\nfunction getSplitValues(str) {\n  return isString(str) ? str.match(splitValuesRe) || [] : [];\n}\n\nfn.hasClass = function (cls) {\n  return !!cls && some.call(this, function (ele) {\n    return isElement(ele) && ele.classList.contains(cls);\n  });\n};\n\nfn.removeAttr = function (attr) {\n  var attrs = getSplitValues(attr);\n  return this.each(function (i, ele) {\n    if (!isElement(ele)) return;\n    each(attrs, function (i, a) {\n      ele.removeAttribute(a);\n    });\n  });\n};\n\nfunction attr(attr, value) {\n  if (!attr) return;\n\n  if (isString(attr)) {\n    if (arguments.length < 2) {\n      if (!this[0] || !isElement(this[0])) return;\n      var value_1 = this[0].getAttribute(attr);\n      return isNull(value_1) ? undefined : value_1;\n    }\n\n    if (isUndefined(value)) return this;\n    if (isNull(value)) return this.removeAttr(attr);\n    return this.each(function (i, ele) {\n      if (!isElement(ele)) return;\n      ele.setAttribute(attr, value);\n    });\n  }\n\n  for (var key in attr) {\n    this.attr(key, attr[key]);\n  }\n\n  return this;\n}\n\nfn.attr = attr;\n\nfn.toggleClass = function (cls, force) {\n  var classes = getSplitValues(cls),\n      isForce = !isUndefined(force);\n  return this.each(function (i, ele) {\n    if (!isElement(ele)) return;\n    each(classes, function (i, c) {\n      if (isForce) {\n        force ? ele.classList.add(c) : ele.classList.remove(c);\n      } else {\n        ele.classList.toggle(c);\n      }\n    });\n  });\n};\n\nfn.addClass = function (cls) {\n  return this.toggleClass(cls, true);\n};\n\nfn.removeClass = function (cls) {\n  if (arguments.length) return this.toggleClass(cls, false);\n  return this.attr('class', '');\n};\n\nfunction pluck(arr, prop, deep, until) {\n  var plucked = [],\n      isCallback = isFunction(prop),\n      compare = until && getCompareFunction(until);\n\n  for (var i = 0, l = arr.length; i < l; i++) {\n    if (isCallback) {\n      var val_1 = prop(arr[i]);\n      if (val_1.length) push.apply(plucked, val_1);\n    } else {\n      var val_2 = arr[i][prop];\n\n      while (val_2 != null) {\n        if (until && compare(-1, val_2)) break;\n        plucked.push(val_2);\n        val_2 = deep ? val_2[prop] : null;\n      }\n    }\n  }\n\n  return plucked;\n}\n\nfunction unique(arr) {\n  return arr.length > 1 ? filter.call(arr, function (item, index, self) {\n    return indexOf.call(self, item) === index;\n  }) : arr;\n}\n\ncash.unique = unique;\n\nfn.add = function (selector, context) {\n  return cash(unique(this.get().concat(cash(selector, context).get())));\n}; // @require core/type_checking.ts\n// @require core/variables.ts\n\n\nfunction computeStyle(ele, prop, isVariable) {\n  if (!isElement(ele)) return;\n  var style = win.getComputedStyle(ele, null);\n  return isVariable ? style.getPropertyValue(prop) || undefined : style[prop] || ele.style[prop];\n} // @require ./compute_style.ts\n\n\nfunction computeStyleInt(ele, prop) {\n  return parseInt(computeStyle(ele, prop), 10) || 0;\n}\n\nvar cssVariableRe = /^--/; // @require ./variables.ts\n\nfunction isCSSVariable(prop) {\n  return cssVariableRe.test(prop);\n} // @require core/camel_case.ts\n// @require core/cash.ts\n// @require core/each.ts\n// @require core/variables.ts\n// @require ./is_css_variable.ts\n\n\nvar prefixedProps = {},\n    style = div.style,\n    vendorsPrefixes = ['webkit', 'moz', 'ms'];\n\nfunction getPrefixedProp(prop, isVariable) {\n  if (isVariable === void 0) {\n    isVariable = isCSSVariable(prop);\n  }\n\n  if (isVariable) return prop;\n\n  if (!prefixedProps[prop]) {\n    var propCC = camelCase(prop),\n        propUC = \"\" + propCC[0].toUpperCase() + propCC.slice(1),\n        props = (propCC + \" \" + vendorsPrefixes.join(propUC + \" \") + propUC).split(' ');\n    each(props, function (i, p) {\n      if (p in style) {\n        prefixedProps[prop] = p;\n        return false;\n      }\n    });\n  }\n\n  return prefixedProps[prop];\n}\n\n; // @require core/type_checking.ts\n// @require ./is_css_variable.ts\n\nvar numericProps = {\n  animationIterationCount: true,\n  columnCount: true,\n  flexGrow: true,\n  flexShrink: true,\n  fontWeight: true,\n  gridArea: true,\n  gridColumn: true,\n  gridColumnEnd: true,\n  gridColumnStart: true,\n  gridRow: true,\n  gridRowEnd: true,\n  gridRowStart: true,\n  lineHeight: true,\n  opacity: true,\n  order: true,\n  orphans: true,\n  widows: true,\n  zIndex: true\n};\n\nfunction getSuffixedValue(prop, value, isVariable) {\n  if (isVariable === void 0) {\n    isVariable = isCSSVariable(prop);\n  }\n\n  return !isVariable && !numericProps[prop] && isNumeric(value) ? value + \"px\" : value;\n}\n\nfunction css(prop, value) {\n  if (isString(prop)) {\n    var isVariable_1 = isCSSVariable(prop);\n    prop = getPrefixedProp(prop, isVariable_1);\n    if (arguments.length < 2) return this[0] && computeStyle(this[0], prop, isVariable_1);\n    if (!prop) return this;\n    value = getSuffixedValue(prop, value, isVariable_1);\n    return this.each(function (i, ele) {\n      if (!isElement(ele)) return;\n\n      if (isVariable_1) {\n        ele.style.setProperty(prop, value);\n      } else {\n        ele.style[prop] = value;\n      }\n    });\n  }\n\n  for (var key in prop) {\n    this.css(key, prop[key]);\n  }\n\n  return this;\n}\n\n;\nfn.css = css; // @optional ./css.ts\n// @require core/attempt.ts\n// @require core/camel_case.ts\n\nvar JSONStringRe = /^\\s+|\\s+$/;\n\nfunction getData(ele, key) {\n  var value = ele.dataset[key] || ele.dataset[camelCase(key)];\n  if (JSONStringRe.test(value)) return value;\n  return attempt(JSON.parse, value);\n} // @require core/attempt.ts\n// @require core/camel_case.ts\n\n\nfunction setData(ele, key, value) {\n  value = attempt(JSON.stringify, value);\n  ele.dataset[camelCase(key)] = value;\n}\n\nfunction data(name, value) {\n  if (!name) {\n    if (!this[0]) return;\n    var datas = {};\n\n    for (var key in this[0].dataset) {\n      datas[key] = getData(this[0], key);\n    }\n\n    return datas;\n  }\n\n  if (isString(name)) {\n    if (arguments.length < 2) return this[0] && getData(this[0], name);\n    if (isUndefined(value)) return this;\n    return this.each(function (i, ele) {\n      setData(ele, name, value);\n    });\n  }\n\n  for (var key in name) {\n    this.data(key, name[key]);\n  }\n\n  return this;\n}\n\nfn.data = data; // @optional ./data.ts\n\nfunction getDocumentDimension(doc, dimension) {\n  var docEle = doc.documentElement;\n  return Math.max(doc.body[\"scroll\" + dimension], docEle[\"scroll\" + dimension], doc.body[\"offset\" + dimension], docEle[\"offset\" + dimension], docEle[\"client\" + dimension]);\n} // @require css/helpers/compute_style_int.ts\n\n\nfunction getExtraSpace(ele, xAxis) {\n  return computeStyleInt(ele, \"border\" + (xAxis ? 'Left' : 'Top') + \"Width\") + computeStyleInt(ele, \"padding\" + (xAxis ? 'Left' : 'Top')) + computeStyleInt(ele, \"padding\" + (xAxis ? 'Right' : 'Bottom')) + computeStyleInt(ele, \"border\" + (xAxis ? 'Right' : 'Bottom') + \"Width\");\n}\n\neach([true, false], function (i, outer) {\n  each(['Width', 'Height'], function (i, prop) {\n    var name = \"\" + (outer ? 'outer' : 'inner') + prop;\n\n    fn[name] = function (includeMargins) {\n      if (!this[0]) return;\n      if (isWindow(this[0])) return outer ? this[0][\"inner\" + prop] : this[0].document.documentElement[\"client\" + prop];\n      if (isDocument(this[0])) return getDocumentDimension(this[0], prop);\n      return this[0][\"\" + (outer ? 'offset' : 'client') + prop] + (includeMargins && outer ? computeStyleInt(this[0], \"margin\" + (i ? 'Top' : 'Left')) + computeStyleInt(this[0], \"margin\" + (i ? 'Bottom' : 'Right')) : 0);\n    };\n  });\n});\neach(['Width', 'Height'], function (index, prop) {\n  var propLC = prop.toLowerCase();\n\n  fn[propLC] = function (value) {\n    if (!this[0]) return isUndefined(value) ? undefined : this;\n\n    if (!arguments.length) {\n      if (isWindow(this[0])) return this[0].document.documentElement[\"client\" + prop];\n      if (isDocument(this[0])) return getDocumentDimension(this[0], prop);\n      return this[0].getBoundingClientRect()[propLC] - getExtraSpace(this[0], !index);\n    }\n\n    var valueNumber = parseInt(value, 10);\n    return this.each(function (i, ele) {\n      if (!isElement(ele)) return;\n      var boxSizing = computeStyle(ele, 'boxSizing');\n      ele.style[propLC] = getSuffixedValue(propLC, valueNumber + (boxSizing === 'border-box' ? getExtraSpace(ele, !index) : 0));\n    });\n  };\n}); // @optional ./inner_outer.ts\n// @optional ./normal.ts\n// @require css/helpers/compute_style.ts\n\nvar defaultDisplay = {};\n\nfunction getDefaultDisplay(tagName) {\n  if (defaultDisplay[tagName]) return defaultDisplay[tagName];\n  var ele = createElement(tagName);\n  doc.body.insertBefore(ele, null);\n  var display = computeStyle(ele, 'display');\n  doc.body.removeChild(ele);\n  return defaultDisplay[tagName] = display !== 'none' ? display : 'block';\n} // @require css/helpers/compute_style.ts\n\n\nfunction isHidden(ele) {\n  return computeStyle(ele, 'display') === 'none';\n}\n\nvar displayProperty = '___cd';\n\nfn.toggle = function (force) {\n  return this.each(function (i, ele) {\n    if (!isElement(ele)) return;\n    var show = isUndefined(force) ? isHidden(ele) : force;\n\n    if (show) {\n      ele.style.display = ele[displayProperty] || '';\n\n      if (isHidden(ele)) {\n        ele.style.display = getDefaultDisplay(ele.tagName);\n      }\n    } else {\n      ele[displayProperty] = computeStyle(ele, 'display');\n      ele.style.display = 'none';\n    }\n  });\n};\n\nfn.hide = function () {\n  return this.toggle(false);\n};\n\nfn.show = function () {\n  return this.toggle(true);\n}; // @optional ./hide.ts\n// @optional ./show.ts\n// @optional ./toggle.ts\n\n\nfunction hasNamespaces(ns1, ns2) {\n  return !ns2 || !some.call(ns2, function (ns) {\n    return ns1.indexOf(ns) < 0;\n  });\n}\n\nvar eventsNamespace = '___ce',\n    eventsNamespacesSeparator = '.',\n    eventsFocus = {\n  focus: 'focusin',\n  blur: 'focusout'\n},\n    eventsHover = {\n  mouseenter: 'mouseover',\n  mouseleave: 'mouseout'\n},\n    eventsMouseRe = /^(mouse|pointer|contextmenu|drag|drop|click|dblclick)/i; // @require ./variables.ts\n\nfunction getEventNameBubbling(name) {\n  return eventsHover[name] || eventsFocus[name] || name;\n} // @require ./variables.ts\n\n\nfunction getEventsCache(ele) {\n  return ele[eventsNamespace] = ele[eventsNamespace] || {};\n} // @require core/guid.ts\n// @require events/helpers/get_events_cache.ts\n\n\nfunction addEvent(ele, name, namespaces, selector, callback) {\n  var eventCache = getEventsCache(ele);\n  eventCache[name] = eventCache[name] || [];\n  eventCache[name].push([namespaces, selector, callback]);\n  ele.addEventListener(name, callback);\n} // @require ./variables.ts\n\n\nfunction parseEventName(eventName) {\n  var parts = eventName.split(eventsNamespacesSeparator);\n  return [parts[0], parts.slice(1).sort()]; // [name, namespace[]]\n} // @require ./get_events_cache.ts\n// @require ./has_namespaces.ts\n// @require ./parse_event_name.ts\n\n\nfunction removeEvent(ele, name, namespaces, selector, callback) {\n  var cache = getEventsCache(ele);\n\n  if (!name) {\n    for (name in cache) {\n      removeEvent(ele, name, namespaces, selector, callback);\n    }\n  } else if (cache[name]) {\n    cache[name] = cache[name].filter(function (_a) {\n      var ns = _a[0],\n          sel = _a[1],\n          cb = _a[2];\n      if (callback && cb.guid !== callback.guid || !hasNamespaces(ns, namespaces) || selector && selector !== sel) return true;\n      ele.removeEventListener(name, cb);\n    });\n  }\n}\n\nfn.off = function (eventFullName, selector, callback) {\n  var _this = this;\n\n  if (isUndefined(eventFullName)) {\n    this.each(function (i, ele) {\n      if (!isElement(ele) && !isDocument(ele) && !isWindow(ele)) return;\n      removeEvent(ele);\n    });\n  } else if (!isString(eventFullName)) {\n    for (var key in eventFullName) {\n      this.off(key, eventFullName[key]);\n    }\n  } else {\n    if (isFunction(selector)) {\n      callback = selector;\n      selector = '';\n    }\n\n    each(getSplitValues(eventFullName), function (i, eventFullName) {\n      var _a = parseEventName(eventFullName),\n          nameOriginal = _a[0],\n          namespaces = _a[1],\n          name = getEventNameBubbling(nameOriginal);\n\n      _this.each(function (i, ele) {\n        if (!isElement(ele) && !isDocument(ele) && !isWindow(ele)) return;\n        removeEvent(ele, name, namespaces, selector, callback);\n      });\n    });\n  }\n\n  return this;\n};\n\nfunction on(eventFullName, selector, data, callback, _one) {\n  var _this = this;\n\n  if (!isString(eventFullName)) {\n    for (var key in eventFullName) {\n      this.on(key, selector, data, eventFullName[key], _one);\n    }\n\n    return this;\n  }\n\n  if (!isString(selector)) {\n    if (isUndefined(selector) || isNull(selector)) {\n      selector = '';\n    } else if (isUndefined(data)) {\n      data = selector;\n      selector = '';\n    } else {\n      callback = data;\n      data = selector;\n      selector = '';\n    }\n  }\n\n  if (!isFunction(callback)) {\n    callback = data;\n    data = undefined;\n  }\n\n  if (!callback) return this;\n  each(getSplitValues(eventFullName), function (i, eventFullName) {\n    var _a = parseEventName(eventFullName),\n        nameOriginal = _a[0],\n        namespaces = _a[1],\n        name = getEventNameBubbling(nameOriginal),\n        isEventHover = nameOriginal in eventsHover,\n        isEventFocus = nameOriginal in eventsFocus;\n\n    if (!name) return;\n\n    _this.each(function (i, ele) {\n      if (!isElement(ele) && !isDocument(ele) && !isWindow(ele)) return;\n\n      var finalCallback = function finalCallback(event) {\n        if (event.target[\"___i\" + event.type]) return event.stopImmediatePropagation(); // Ignoring native event in favor of the upcoming custom one\n\n        if (event.namespace && !hasNamespaces(namespaces, event.namespace.split(eventsNamespacesSeparator))) return;\n        if (!selector && (isEventFocus && (event.target !== ele || event.___ot === name) || isEventHover && event.relatedTarget && ele.contains(event.relatedTarget))) return;\n        var thisArg = ele;\n\n        if (selector) {\n          var target = event.target;\n\n          while (!matches(target, selector)) {\n            if (target === ele) return;\n            target = target.parentNode;\n            if (!target) return;\n          }\n\n          thisArg = target;\n          event.___cd = true; // Delegate\n        }\n\n        if (event.___cd) {\n          Object.defineProperty(event, 'currentTarget', {\n            configurable: true,\n            get: function get() {\n              return thisArg;\n            }\n          });\n        }\n\n        Object.defineProperty(event, 'data', {\n          configurable: true,\n          get: function get() {\n            return data;\n          }\n        });\n        var returnValue = callback.call(thisArg, event, event.___td);\n\n        if (_one) {\n          removeEvent(ele, name, namespaces, selector, finalCallback);\n        }\n\n        if (returnValue === false) {\n          event.preventDefault();\n          event.stopPropagation();\n        }\n      };\n\n      finalCallback.guid = callback.guid = callback.guid || cash.guid++;\n      addEvent(ele, name, namespaces, selector, finalCallback);\n    });\n  });\n  return this;\n}\n\nfn.on = on;\n\nfunction one(eventFullName, selector, data, callback) {\n  return this.on(eventFullName, selector, data, callback, true);\n}\n\n;\nfn.one = one;\n\nfn.ready = function (callback) {\n  var cb = function cb() {\n    return setTimeout(callback, 0, cash);\n  };\n\n  if (doc.readyState !== 'loading') {\n    cb();\n  } else {\n    doc.addEventListener('DOMContentLoaded', cb);\n  }\n\n  return this;\n};\n\nfn.trigger = function (event, data) {\n  if (isString(event)) {\n    var _a = parseEventName(event),\n        nameOriginal = _a[0],\n        namespaces = _a[1],\n        name_1 = getEventNameBubbling(nameOriginal);\n\n    if (!name_1) return this;\n    var type = eventsMouseRe.test(name_1) ? 'MouseEvents' : 'HTMLEvents';\n    event = doc.createEvent(type);\n    event.initEvent(name_1, true, true);\n    event.namespace = namespaces.join(eventsNamespacesSeparator);\n    event.___ot = nameOriginal;\n  }\n\n  event.___td = data;\n  var isEventFocus = event.___ot in eventsFocus;\n  return this.each(function (i, ele) {\n    if (isEventFocus && isFunction(ele[event.___ot])) {\n      ele[\"___i\" + event.type] = true; // Ensuring the native event is ignored\n\n      ele[event.___ot]();\n\n      ele[\"___i\" + event.type] = false; // Ensuring the custom event is not ignored\n    }\n\n    ele.dispatchEvent(event);\n  });\n}; // @optional ./off.ts\n// @optional ./on.ts\n// @optional ./one.ts\n// @optional ./ready.ts\n// @optional ./trigger.ts\n// @require core/pluck.ts\n// @require core/variables.ts\n\n\nfunction getValue(ele) {\n  if (ele.multiple && ele.options) return pluck(filter.call(ele.options, function (option) {\n    return option.selected && !option.disabled && !option.parentNode.disabled;\n  }), 'value');\n  return ele.value || '';\n}\n\nvar queryEncodeSpaceRe = /%20/g,\n    queryEncodeCRLFRe = /\\r?\\n/g;\n\nfunction queryEncode(prop, value) {\n  return \"&\" + encodeURIComponent(prop) + \"=\" + encodeURIComponent(value.replace(queryEncodeCRLFRe, '\\r\\n')).replace(queryEncodeSpaceRe, '+');\n}\n\nvar skippableRe = /file|reset|submit|button|image/i,\n    checkableRe = /radio|checkbox/i;\n\nfn.serialize = function () {\n  var query = '';\n  this.each(function (i, ele) {\n    each(ele.elements || [ele], function (i, ele) {\n      if (ele.disabled || !ele.name || ele.tagName === 'FIELDSET' || skippableRe.test(ele.type) || checkableRe.test(ele.type) && !ele.checked) return;\n      var value = getValue(ele);\n\n      if (!isUndefined(value)) {\n        var values = isArray(value) ? value : [value];\n        each(values, function (i, value) {\n          query += queryEncode(ele.name, value);\n        });\n      }\n    });\n  });\n  return query.slice(1);\n};\n\nfunction val(value) {\n  if (!arguments.length) return this[0] && getValue(this[0]);\n  return this.each(function (i, ele) {\n    var isSelect = ele.multiple && ele.options;\n\n    if (isSelect || checkableRe.test(ele.type)) {\n      var eleValue_1 = isArray(value) ? map.call(value, String) : isNull(value) ? [] : [String(value)];\n\n      if (isSelect) {\n        each(ele.options, function (i, option) {\n          option.selected = eleValue_1.indexOf(option.value) >= 0;\n        }, true);\n      } else {\n        ele.checked = eleValue_1.indexOf(ele.value) >= 0;\n      }\n    } else {\n      ele.value = isUndefined(value) || isNull(value) ? '' : value;\n    }\n  });\n}\n\nfn.val = val;\n\nfn.clone = function () {\n  return this.map(function (i, ele) {\n    return ele.cloneNode(true);\n  });\n};\n\nfn.detach = function (comparator) {\n  filtered(this, comparator).each(function (i, ele) {\n    if (ele.parentNode) {\n      ele.parentNode.removeChild(ele);\n    }\n  });\n  return this;\n};\n\nvar fragmentRe = /^\\s*<(\\w+)[^>]*>/,\n    singleTagRe = /^<(\\w+)\\s*\\/?>(?:<\\/\\1>)?$/;\nvar containers = {\n  '*': div,\n  tr: tbody,\n  td: tr,\n  th: tr,\n  thead: table,\n  tbody: table,\n  tfoot: table\n}; //TODO: Create elements inside a document fragment, in order to prevent inline event handlers from firing\n//TODO: Ensure the created elements have the fragment as their parent instead of null, this also ensures we can deal with detatched nodes more reliably\n\nfunction parseHTML(html) {\n  if (!isString(html)) return [];\n  if (singleTagRe.test(html)) return [createElement(RegExp.$1)];\n  var fragment = fragmentRe.test(html) && RegExp.$1,\n      container = containers[fragment] || containers['*'];\n  container.innerHTML = html;\n  return cash(container.childNodes).detach().get();\n}\n\ncash.parseHTML = parseHTML;\n\nfn.empty = function () {\n  return this.each(function (i, ele) {\n    while (ele.firstChild) {\n      ele.removeChild(ele.firstChild);\n    }\n  });\n};\n\nfunction html(html) {\n  if (!arguments.length) return this[0] && this[0].innerHTML;\n  if (isUndefined(html)) return this;\n  return this.each(function (i, ele) {\n    if (!isElement(ele)) return;\n    ele.innerHTML = html;\n  });\n}\n\nfn.html = html;\n\nfn.remove = function (comparator) {\n  filtered(this, comparator).detach().off();\n  return this;\n};\n\nfunction text(text) {\n  if (isUndefined(text)) return this[0] ? this[0].textContent : '';\n  return this.each(function (i, ele) {\n    if (!isElement(ele)) return;\n    ele.textContent = text;\n  });\n}\n\n;\nfn.text = text;\n\nfn.unwrap = function () {\n  this.parent().each(function (i, ele) {\n    if (ele.tagName === 'BODY') return;\n    var $ele = cash(ele);\n    $ele.replaceWith($ele.children());\n  });\n  return this;\n};\n\nfn.offset = function () {\n  var ele = this[0];\n  if (!ele) return;\n  var rect = ele.getBoundingClientRect();\n  return {\n    top: rect.top + win.pageYOffset,\n    left: rect.left + win.pageXOffset\n  };\n};\n\nfn.offsetParent = function () {\n  return this.map(function (i, ele) {\n    var offsetParent = ele.offsetParent;\n\n    while (offsetParent && computeStyle(offsetParent, 'position') === 'static') {\n      offsetParent = offsetParent.offsetParent;\n    }\n\n    return offsetParent || docEle;\n  });\n};\n\nfn.position = function () {\n  var ele = this[0];\n  if (!ele) return;\n  var isFixed = computeStyle(ele, 'position') === 'fixed',\n      offset = isFixed ? ele.getBoundingClientRect() : this.offset();\n\n  if (!isFixed) {\n    var doc_1 = ele.ownerDocument;\n    var offsetParent = ele.offsetParent || doc_1.documentElement;\n\n    while ((offsetParent === doc_1.body || offsetParent === doc_1.documentElement) && computeStyle(offsetParent, 'position') === 'static') {\n      offsetParent = offsetParent.parentNode;\n    }\n\n    if (offsetParent !== ele && isElement(offsetParent)) {\n      var parentOffset = cash(offsetParent).offset();\n      offset.top -= parentOffset.top + computeStyleInt(offsetParent, 'borderTopWidth');\n      offset.left -= parentOffset.left + computeStyleInt(offsetParent, 'borderLeftWidth');\n    }\n  }\n\n  return {\n    top: offset.top - computeStyleInt(ele, 'marginTop'),\n    left: offset.left - computeStyleInt(ele, 'marginLeft')\n  };\n};\n\nfn.children = function (comparator) {\n  return filtered(cash(unique(pluck(this, function (ele) {\n    return ele.children;\n  }))), comparator);\n};\n\nfn.contents = function () {\n  return cash(unique(pluck(this, function (ele) {\n    return ele.tagName === 'IFRAME' ? [ele.contentDocument] : ele.tagName === 'TEMPLATE' ? ele.content.childNodes : ele.childNodes;\n  })));\n};\n\nfn.find = function (selector) {\n  return cash(unique(pluck(this, function (ele) {\n    return find(selector, ele);\n  })));\n}; // @require core/variables.ts\n// @require collection/filter.ts\n// @require traversal/find.ts\n\n\nvar HTMLCDATARe = /^\\s*<!(?:\\[CDATA\\[|--)|(?:\\]\\]|--)>\\s*$/g,\n    scriptTypeRe = /^$|^module$|\\/(java|ecma)script/i,\n    scriptAttributes = ['type', 'src', 'nonce', 'noModule'];\n\nfunction evalScripts(node, doc) {\n  var collection = cash(node);\n  collection.filter('script').add(collection.find('script')).each(function (i, ele) {\n    if (scriptTypeRe.test(ele.type) && docEle.contains(ele)) {\n      // The script type is supported // The element is attached to the DOM // Using `documentElement` for broader browser support\n      var script_1 = createElement('script');\n      script_1.text = ele.textContent.replace(HTMLCDATARe, '');\n      each(scriptAttributes, function (i, attr) {\n        if (ele[attr]) script_1[attr] = ele[attr];\n      });\n      doc.head.insertBefore(script_1, null);\n      doc.head.removeChild(script_1);\n    }\n  });\n} // @require ./eval_scripts.ts\n\n\nfunction insertElement(anchor, target, left, inside, evaluate) {\n  if (inside) {\n    // prepend/append\n    anchor.insertBefore(target, left ? anchor.firstChild : null);\n  } else {\n    // before/after\n    anchor.parentNode.insertBefore(target, left ? anchor : anchor.nextSibling);\n  }\n\n  if (evaluate) {\n    evalScripts(target, anchor.ownerDocument);\n  }\n} // @require ./insert_element.ts\n\n\nfunction insertSelectors(selectors, anchors, inverse, left, inside, reverseLoop1, reverseLoop2, reverseLoop3) {\n  each(selectors, function (si, selector) {\n    each(cash(selector), function (ti, target) {\n      each(cash(anchors), function (ai, anchor) {\n        var anchorFinal = inverse ? target : anchor,\n            targetFinal = inverse ? anchor : target,\n            indexFinal = inverse ? ti : ai;\n        insertElement(anchorFinal, !indexFinal ? targetFinal : targetFinal.cloneNode(true), left, inside, !indexFinal);\n      }, reverseLoop3);\n    }, reverseLoop2);\n  }, reverseLoop1);\n  return anchors;\n}\n\nfn.after = function () {\n  return insertSelectors(arguments, this, false, false, false, true, true);\n};\n\nfn.append = function () {\n  return insertSelectors(arguments, this, false, false, true);\n};\n\nfn.appendTo = function (selector) {\n  return insertSelectors(arguments, this, true, false, true);\n};\n\nfn.before = function () {\n  return insertSelectors(arguments, this, false, true);\n};\n\nfn.insertAfter = function (selector) {\n  return insertSelectors(arguments, this, true, false, false, false, false, true);\n};\n\nfn.insertBefore = function (selector) {\n  return insertSelectors(arguments, this, true, true);\n};\n\nfn.prepend = function () {\n  return insertSelectors(arguments, this, false, true, true, true, true);\n};\n\nfn.prependTo = function (selector) {\n  return insertSelectors(arguments, this, true, true, true, false, false, true);\n};\n\nfn.replaceWith = function (selector) {\n  return this.before(selector).remove();\n};\n\nfn.replaceAll = function (selector) {\n  cash(selector).replaceWith(this);\n  return this;\n};\n\nfn.wrapAll = function (selector) {\n  var structure = cash(selector),\n      wrapper = structure[0];\n\n  while (wrapper.children.length) {\n    wrapper = wrapper.firstElementChild;\n  }\n\n  this.first().before(structure);\n  return this.appendTo(wrapper);\n};\n\nfn.wrap = function (selector) {\n  return this.each(function (i, ele) {\n    var wrapper = cash(selector)[0];\n    cash(ele).wrapAll(!i ? wrapper : wrapper.cloneNode(true));\n  });\n};\n\nfn.wrapInner = function (selector) {\n  return this.each(function (i, ele) {\n    var $ele = cash(ele),\n        contents = $ele.contents();\n    contents.length ? contents.wrapAll(selector) : $ele.append(selector);\n  });\n};\n\nfn.has = function (selector) {\n  var comparator = isString(selector) ? function (i, ele) {\n    return find(selector, ele).length;\n  } : function (i, ele) {\n    return ele.contains(selector);\n  };\n  return this.filter(comparator);\n};\n\nfn.is = function (comparator) {\n  var compare = getCompareFunction(comparator);\n  return some.call(this, function (ele, i) {\n    return compare.call(ele, i, ele);\n  });\n};\n\nfn.next = function (comparator, _all, _until) {\n  return filtered(cash(unique(pluck(this, 'nextElementSibling', _all, _until))), comparator);\n};\n\nfn.nextAll = function (comparator) {\n  return this.next(comparator, true);\n};\n\nfn.nextUntil = function (until, comparator) {\n  return this.next(comparator, true, until);\n};\n\nfn.not = function (comparator) {\n  var compare = getCompareFunction(comparator);\n  return this.filter(function (i, ele) {\n    return (!isString(comparator) || isElement(ele)) && !compare.call(ele, i, ele);\n  });\n};\n\nfn.parent = function (comparator) {\n  return filtered(cash(unique(pluck(this, 'parentNode'))), comparator);\n};\n\nfn.index = function (selector) {\n  var child = selector ? cash(selector)[0] : this[0],\n      collection = selector ? this : cash(child).parent().children();\n  return indexOf.call(collection, child);\n};\n\nfn.closest = function (comparator) {\n  var filtered = this.filter(comparator);\n  if (filtered.length) return filtered;\n  var $parent = this.parent();\n  if (!$parent.length) return filtered;\n  return $parent.closest(comparator);\n};\n\nfn.parents = function (comparator, _until) {\n  return filtered(cash(unique(pluck(this, 'parentElement', true, _until))), comparator);\n};\n\nfn.parentsUntil = function (until, comparator) {\n  return this.parents(comparator, until);\n};\n\nfn.prev = function (comparator, _all, _until) {\n  return filtered(cash(unique(pluck(this, 'previousElementSibling', _all, _until))), comparator);\n};\n\nfn.prevAll = function (comparator) {\n  return this.prev(comparator, true);\n};\n\nfn.prevUntil = function (until, comparator) {\n  return this.prev(comparator, true, until);\n};\n\nfn.siblings = function (comparator) {\n  return filtered(cash(unique(pluck(this, function (ele) {\n    return cash(ele).parent().children().not(ele);\n  }))), comparator);\n}; // @optional ./children.ts\n// @optional ./closest.ts\n// @optional ./contents.ts\n// @optional ./find.ts\n// @optional ./has.ts\n// @optional ./is.ts\n// @optional ./next.ts\n// @optional ./next_all.ts\n// @optional ./next_until.ts\n// @optional ./not.ts\n// @optional ./parent.ts\n// @optional ./parents.ts\n// @optional ./parents_until.ts\n// @optional ./prev.ts\n// @optional ./prev_all.ts\n// @optional ./prev_until.ts\n// @optional ./siblings.ts\n// @optional attributes/index.ts\n// @optional collection/index.ts\n// @optional css/index.ts\n// @optional data/index.ts\n// @optional dimensions/index.ts\n// @optional effects/index.ts\n// @optional events/index.ts\n// @optional forms/index.ts\n// @optional manipulation/index.ts\n// @optional offset/index.ts\n// @optional traversal/index.ts\n// @require core/index.ts\n// @priority -100\n// @require ./cash.ts\n// @require ./variables.ts\n\n\nif (typeof exports !== 'undefined') {\n  // Node.js\n  module.exports = cash;\n} else {\n  // Browser\n  win['cash'] = win['$'] = cash;\n}\n})();","'use strict';\n\n(function () {\n  var out$ = typeof exports != 'undefined' && exports || typeof define != 'undefined' && {} || this || window;\n  if (typeof define !== 'undefined') define('save-svg-as-png', [], function () {\n    return out$;\n  });\n  out$.default = out$;\n\n  var xmlNs = 'http://www.w3.org/2000/xmlns/';\n  var xhtmlNs = 'http://www.w3.org/1999/xhtml';\n  var svgNs = 'http://www.w3.org/2000/svg';\n  var doctype = '<?xml version=\"1.0\" standalone=\"no\"?><!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\" \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\" [<!ENTITY nbsp \"&#160;\">]>';\n  var urlRegex = /url\\([\"']?(.+?)[\"']?\\)/;\n  var fontFormats = {\n    woff2: 'font/woff2',\n    woff: 'font/woff',\n    otf: 'application/x-font-opentype',\n    ttf: 'application/x-font-ttf',\n    eot: 'application/vnd.ms-fontobject',\n    sfnt: 'application/font-sfnt',\n    svg: 'image/svg+xml'\n  };\n\n  var isElement = function isElement(obj) {\n    return obj instanceof HTMLElement || obj instanceof SVGElement;\n  };\n  var requireDomNode = function requireDomNode(el) {\n    if (!isElement(el)) throw new Error('an HTMLElement or SVGElement is required; got ' + el);\n  };\n  var requireDomNodePromise = function requireDomNodePromise(el) {\n    return new Promise(function (resolve, reject) {\n      if (isElement(el)) resolve(el);else reject(new Error('an HTMLElement or SVGElement is required; got ' + el));\n    });\n  };\n  var isExternal = function isExternal(url) {\n    return url && url.lastIndexOf('http', 0) === 0 && url.lastIndexOf(window.location.host) === -1;\n  };\n\n  var getFontMimeTypeFromUrl = function getFontMimeTypeFromUrl(fontUrl) {\n    var formats = Object.keys(fontFormats).filter(function (extension) {\n      return fontUrl.indexOf('.' + extension) > 0;\n    }).map(function (extension) {\n      return fontFormats[extension];\n    });\n    if (formats) return formats[0];\n    console.error('Unknown font format for ' + fontUrl + '. Fonts may not be working correctly.');\n    return 'application/octet-stream';\n  };\n\n  var arrayBufferToBase64 = function arrayBufferToBase64(buffer) {\n    var binary = '';\n    var bytes = new Uint8Array(buffer);\n    for (var i = 0; i < bytes.byteLength; i++) {\n      binary += String.fromCharCode(bytes[i]);\n    }return window.btoa(binary);\n  };\n\n  var getDimension = function getDimension(el, clone, dim) {\n    var v = el.viewBox && el.viewBox.baseVal && el.viewBox.baseVal[dim] || clone.getAttribute(dim) !== null && !clone.getAttribute(dim).match(/%$/) && parseInt(clone.getAttribute(dim)) || el.getBoundingClientRect()[dim] || parseInt(clone.style[dim]) || parseInt(window.getComputedStyle(el).getPropertyValue(dim));\n    return typeof v === 'undefined' || v === null || isNaN(parseFloat(v)) ? 0 : v;\n  };\n\n  var getDimensions = function getDimensions(el, clone, width, height) {\n    if (el.tagName === 'svg') return {\n      width: width || getDimension(el, clone, 'width'),\n      height: height || getDimension(el, clone, 'height')\n    };else if (el.getBBox) {\n      var _el$getBBox = el.getBBox(),\n          x = _el$getBBox.x,\n          y = _el$getBBox.y,\n          _width = _el$getBBox.width,\n          _height = _el$getBBox.height;\n\n      return {\n        width: x + _width,\n        height: y + _height\n      };\n    }\n  };\n\n  var reEncode = function reEncode(data) {\n    return decodeURIComponent(encodeURIComponent(data).replace(/%([0-9A-F]{2})/g, function (match, p1) {\n      var c = String.fromCharCode('0x' + p1);\n      return c === '%' ? '%25' : c;\n    }));\n  };\n\n  var uriToBlob = function uriToBlob(uri) {\n    var byteString = window.atob(uri.split(',')[1]);\n    var mimeString = uri.split(',')[0].split(':')[1].split(';')[0];\n    var buffer = new ArrayBuffer(byteString.length);\n    var intArray = new Uint8Array(buffer);\n    for (var i = 0; i < byteString.length; i++) {\n      intArray[i] = byteString.charCodeAt(i);\n    }\n    return new Blob([buffer], { type: mimeString });\n  };\n\n  var query = function query(el, selector) {\n    if (!selector) return;\n    try {\n      return el.querySelector(selector) || el.parentNode && el.parentNode.querySelector(selector);\n    } catch (err) {\n      console.warn('Invalid CSS selector \"' + selector + '\"', err);\n    }\n  };\n\n  var detectCssFont = function detectCssFont(rule, href) {\n    // Match CSS font-face rules to external links.\n    // @font-face {\n    //   src: local('Abel'), url(https://fonts.gstatic.com/s/abel/v6/UzN-iejR1VoXU2Oc-7LsbvesZW2xOQ-xsNqO47m55DA.woff2);\n    // }\n    var match = rule.cssText.match(urlRegex);\n    var url = match && match[1] || '';\n    if (!url || url.match(/^data:/) || url === 'about:blank') return;\n    var fullUrl = url.startsWith('../') ? href + '/../' + url : url.startsWith('./') ? href + '/.' + url : url;\n    return {\n      text: rule.cssText,\n      format: getFontMimeTypeFromUrl(fullUrl),\n      url: fullUrl\n    };\n  };\n\n  var inlineImages = function inlineImages(el) {\n    return Promise.all(Array.from(el.querySelectorAll('image')).map(function (image) {\n      var href = image.getAttributeNS('http://www.w3.org/1999/xlink', 'href') || image.getAttribute('href');\n      if (!href) return Promise.resolve(null);\n      if (isExternal(href)) {\n        href += (href.indexOf('?') === -1 ? '?' : '&') + 't=' + new Date().valueOf();\n      }\n      return new Promise(function (resolve, reject) {\n        var canvas = document.createElement('canvas');\n        var img = new Image();\n        img.crossOrigin = 'anonymous';\n        img.src = href;\n        img.onerror = function () {\n          return reject(new Error('Could not load ' + href));\n        };\n        img.onload = function () {\n          canvas.width = img.width;\n          canvas.height = img.height;\n          canvas.getContext('2d').drawImage(img, 0, 0);\n          image.setAttributeNS('http://www.w3.org/1999/xlink', 'href', canvas.toDataURL('image/png'));\n          resolve(true);\n        };\n      });\n    }));\n  };\n\n  var cachedFonts = {};\n  var inlineFonts = function inlineFonts(fonts) {\n    return Promise.all(fonts.map(function (font) {\n      return new Promise(function (resolve, reject) {\n        if (cachedFonts[font.url]) return resolve(cachedFonts[font.url]);\n\n        var req = new XMLHttpRequest();\n        req.addEventListener('load', function () {\n          // TODO: it may also be worth it to wait until fonts are fully loaded before\n          // attempting to rasterize them. (e.g. use https://developer.mozilla.org/en-US/docs/Web/API/FontFaceSet)\n          var fontInBase64 = arrayBufferToBase64(req.response);\n          var fontUri = font.text.replace(urlRegex, 'url(\"data:' + font.format + ';base64,' + fontInBase64 + '\")') + '\\n';\n          cachedFonts[font.url] = fontUri;\n          resolve(fontUri);\n        });\n        req.addEventListener('error', function (e) {\n          console.warn('Failed to load font from: ' + font.url, e);\n          cachedFonts[font.url] = null;\n          resolve(null);\n        });\n        req.addEventListener('abort', function (e) {\n          console.warn('Aborted loading font from: ' + font.url, e);\n          resolve(null);\n        });\n        req.open('GET', font.url);\n        req.responseType = 'arraybuffer';\n        req.send();\n      });\n    })).then(function (fontCss) {\n      return fontCss.filter(function (x) {\n        return x;\n      }).join('');\n    });\n  };\n\n  var cachedRules = null;\n  var styleSheetRules = function styleSheetRules() {\n    if (cachedRules) return cachedRules;\n    return cachedRules = Array.from(document.styleSheets).map(function (sheet) {\n      try {\n        return { rules: sheet.cssRules, href: sheet.href };\n      } catch (e) {\n        console.warn('Stylesheet could not be loaded: ' + sheet.href, e);\n        return {};\n      }\n    });\n  };\n\n  var inlineCss = function inlineCss(el, options) {\n    var _ref = options || {},\n        selectorRemap = _ref.selectorRemap,\n        modifyStyle = _ref.modifyStyle,\n        modifyCss = _ref.modifyCss,\n        fonts = _ref.fonts,\n        excludeUnusedCss = _ref.excludeUnusedCss;\n\n    var generateCss = modifyCss || function (selector, properties) {\n      var sel = selectorRemap ? selectorRemap(selector) : selector;\n      var props = modifyStyle ? modifyStyle(properties) : properties;\n      return sel + '{' + props + '}\\n';\n    };\n    var css = [];\n    var detectFonts = typeof fonts === 'undefined';\n    var fontList = fonts || [];\n    styleSheetRules().forEach(function (_ref2) {\n      var rules = _ref2.rules,\n          href = _ref2.href;\n\n      if (!rules) return;\n      Array.from(rules).forEach(function (rule) {\n        if (typeof rule.style != 'undefined') {\n          if (query(el, rule.selectorText)) css.push(generateCss(rule.selectorText, rule.style.cssText));else if (detectFonts && rule.cssText.match(/^@font-face/)) {\n            var font = detectCssFont(rule, href);\n            if (font) fontList.push(font);\n          } else if (!excludeUnusedCss) {\n            css.push(rule.cssText);\n          }\n        }\n      });\n    });\n\n    return inlineFonts(fontList).then(function (fontCss) {\n      return css.join('\\n') + fontCss;\n    });\n  };\n\n  var downloadOptions = function downloadOptions() {\n    if (!navigator.msSaveOrOpenBlob && !('download' in document.createElement('a'))) {\n      return { popup: window.open() };\n    }\n  };\n\n  out$.prepareSvg = function (el, options, done) {\n    requireDomNode(el);\n\n    var _ref3 = options || {},\n        _ref3$left = _ref3.left,\n        left = _ref3$left === undefined ? 0 : _ref3$left,\n        _ref3$top = _ref3.top,\n        top = _ref3$top === undefined ? 0 : _ref3$top,\n        w = _ref3.width,\n        h = _ref3.height,\n        _ref3$scale = _ref3.scale,\n        scale = _ref3$scale === undefined ? 1 : _ref3$scale,\n        _ref3$responsive = _ref3.responsive,\n        responsive = _ref3$responsive === undefined ? false : _ref3$responsive,\n        _ref3$excludeCss = _ref3.excludeCss,\n        excludeCss = _ref3$excludeCss === undefined ? false : _ref3$excludeCss;\n\n    return inlineImages(el).then(function () {\n      var clone = el.cloneNode(true);\n      clone.style.backgroundColor = (options || {}).backgroundColor || el.style.backgroundColor;\n\n      var _getDimensions = getDimensions(el, clone, w, h),\n          width = _getDimensions.width,\n          height = _getDimensions.height;\n\n      if (el.tagName !== 'svg') {\n        if (el.getBBox) {\n          if (clone.getAttribute('transform') != null) {\n            clone.setAttribute('transform', clone.getAttribute('transform').replace(/translate\\(.*?\\)/, ''));\n          }\n          var svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg');\n          svg.appendChild(clone);\n          clone = svg;\n        } else {\n          console.error('Attempted to render non-SVG element', el);\n          return;\n        }\n      }\n\n      clone.setAttribute('version', '1.1');\n      clone.setAttribute('viewBox', [left, top, width, height].join(' '));\n      if (!clone.getAttribute('xmlns')) clone.setAttributeNS(xmlNs, 'xmlns', svgNs);\n      if (!clone.getAttribute('xmlns:xlink')) clone.setAttributeNS(xmlNs, 'xmlns:xlink', 'http://www.w3.org/1999/xlink');\n\n      if (responsive) {\n        clone.removeAttribute('width');\n        clone.removeAttribute('height');\n        clone.setAttribute('preserveAspectRatio', 'xMinYMin meet');\n      } else {\n        clone.setAttribute('width', width * scale);\n        clone.setAttribute('height', height * scale);\n      }\n\n      Array.from(clone.querySelectorAll('foreignObject > *')).forEach(function (foreignObject) {\n        foreignObject.setAttributeNS(xmlNs, 'xmlns', foreignObject.tagName === 'svg' ? svgNs : xhtmlNs);\n      });\n\n      if (excludeCss) {\n        var outer = document.createElement('div');\n        outer.appendChild(clone);\n        var src = outer.innerHTML;\n        if (typeof done === 'function') done(src, width, height);else return { src: src, width: width, height: height };\n      } else {\n        return inlineCss(el, options).then(function (css) {\n          var style = document.createElement('style');\n          style.setAttribute('type', 'text/css');\n          style.innerHTML = '<![CDATA[\\n' + css + '\\n]]>';\n\n          var defs = document.createElement('defs');\n          defs.appendChild(style);\n          clone.insertBefore(defs, clone.firstChild);\n\n          var outer = document.createElement('div');\n          outer.appendChild(clone);\n          var src = outer.innerHTML.replace(/NS\\d+:href/gi, 'xmlns:xlink=\"http://www.w3.org/1999/xlink\" xlink:href');\n\n          if (typeof done === 'function') done(src, width, height);else return { src: src, width: width, height: height };\n        });\n      }\n    });\n  };\n\n  out$.svgAsDataUri = function (el, options, done) {\n    requireDomNode(el);\n    return out$.prepareSvg(el, options).then(function (_ref4) {\n      var src = _ref4.src,\n          width = _ref4.width,\n          height = _ref4.height;\n\n      var svgXml = 'data:image/svg+xml;base64,' + window.btoa(reEncode(doctype + src));\n      if (typeof done === 'function') {\n        done(svgXml, width, height);\n      }\n      return svgXml;\n    });\n  };\n\n  out$.svgAsPngUri = function (el, options, done) {\n    requireDomNode(el);\n\n    var _ref5 = options || {},\n        _ref5$encoderType = _ref5.encoderType,\n        encoderType = _ref5$encoderType === undefined ? 'image/png' : _ref5$encoderType,\n        _ref5$encoderOptions = _ref5.encoderOptions,\n        encoderOptions = _ref5$encoderOptions === undefined ? 0.8 : _ref5$encoderOptions,\n        canvg = _ref5.canvg;\n\n    var convertToPng = function convertToPng(_ref6) {\n      var src = _ref6.src,\n          width = _ref6.width,\n          height = _ref6.height;\n\n      var canvas = document.createElement('canvas');\n      var context = canvas.getContext('2d');\n      var pixelRatio = window.devicePixelRatio || 1;\n\n      canvas.width = width * pixelRatio;\n      canvas.height = height * pixelRatio;\n      canvas.style.width = canvas.width + 'px';\n      canvas.style.height = canvas.height + 'px';\n      context.setTransform(pixelRatio, 0, 0, pixelRatio, 0, 0);\n\n      if (canvg) canvg(canvas, src);else context.drawImage(src, 0, 0);\n\n      var png = void 0;\n      try {\n        png = canvas.toDataURL(encoderType, encoderOptions);\n      } catch (e) {\n        if (typeof SecurityError !== 'undefined' && e instanceof SecurityError || e.name === 'SecurityError') {\n          console.error('Rendered SVG images cannot be downloaded in this browser.');\n          return;\n        } else throw e;\n      }\n      if (typeof done === 'function') done(png, canvas.width, canvas.height);\n      return Promise.resolve(png);\n    };\n\n    if (canvg) return out$.prepareSvg(el, options).then(convertToPng);else return out$.svgAsDataUri(el, options).then(function (uri) {\n      return new Promise(function (resolve, reject) {\n        var image = new Image();\n        image.onload = function () {\n          return resolve(convertToPng({\n            src: image,\n            width: image.width,\n            height: image.height\n          }));\n        };\n        image.onerror = function () {\n          reject('There was an error loading the data URI as an image on the following SVG\\n' + window.atob(uri.slice(26)) + 'Open the following link to see browser\\'s diagnosis\\n' + uri);\n        };\n        image.src = uri;\n      });\n    });\n  };\n\n  out$.download = function (name, uri, options) {\n    if (navigator.msSaveOrOpenBlob) navigator.msSaveOrOpenBlob(uriToBlob(uri), name);else {\n      var saveLink = document.createElement('a');\n      if ('download' in saveLink) {\n        saveLink.download = name;\n        saveLink.style.display = 'none';\n        document.body.appendChild(saveLink);\n        try {\n          var blob = uriToBlob(uri);\n          var url = URL.createObjectURL(blob);\n          saveLink.href = url;\n          saveLink.onclick = function () {\n            return requestAnimationFrame(function () {\n              return URL.revokeObjectURL(url);\n            });\n          };\n        } catch (e) {\n          console.error(e);\n          console.warn('Error while getting object URL. Falling back to string URL.');\n          saveLink.href = uri;\n        }\n        saveLink.click();\n        document.body.removeChild(saveLink);\n      } else if (options && options.popup) {\n        options.popup.document.title = name;\n        options.popup.location.replace(uri);\n      }\n    }\n  };\n\n  out$.saveSvg = function (el, name, options) {\n    var downloadOpts = downloadOptions(); // don't inline, can't be async\n    return requireDomNodePromise(el).then(function (el) {\n      return out$.svgAsDataUri(el, options || {});\n    }).then(function (uri) {\n      return out$.download(name, uri, downloadOpts);\n    });\n  };\n\n  out$.saveSvgAsPng = function (el, name, options) {\n    var downloadOpts = downloadOptions(); // don't inline, can't be async\n    return requireDomNodePromise(el).then(function (el) {\n      return out$.svgAsPngUri(el, options || {});\n    }).then(function (uri) {\n      return out$.download(name, uri, downloadOpts);\n    });\n  };\n})();","export const ICDS = `DISPLAY\nNO DATA\n`;\n","export const IDPS = `DISPLAY\nNO DATA\n`;\n","const rnaColor = 'rgb(255,230,153)';\nconst invAbasicColor = 'rgb(255,230,153)';\nexport const axolabsMap = {\n    'RNA': {\n        fullName: 'RNA nucleotides',\n        symbols: ['A', 'C', 'G', 'U'],\n        color: rnaColor,\n    },\n    'DNA': {\n        fullName: 'DNA nucleotides',\n        symbols: ['dA', 'dC', 'dG', 'dT'],\n        color: 'rgb(197,224,180)',\n    },\n    '2\\'-Fluoro': {\n        fullName: '2\\'-Fluoro nucleotides',\n        symbols: ['Af', 'Cf', 'Gf', 'Uf'],\n        color: 'rgb(68,114,196)',\n    },\n    '2\\'-O-Methyl': {\n        fullName: '2\\'-O-Methyl nucleotides',\n        symbols: ['a', 'c', 'g', 'u'],\n        color: 'rgb(166,166,166)',\n    },\n    '2\\'-O-MOE': {\n        fullName: '2\\'-O-MOE nucleotides (including 5-Methyl C)',\n        symbols: ['Am', 'Cm', 'Gm', 'Tm'],\n        color: 'rgb(112,48,160)',\n    },\n    'GNA': {\n        fullName: 'Glycol nucleic acid',\n        symbols: ['(GNA-A)', '(GNA-C)', '(GNA-G)', '(GNA-T)'],\n        color: 'rgb(255,192,0)',\n    },\n    'LNA': {\n        fullName: 'Locked nucleic acid (including 5-Methyl C)',\n        symbols: ['Ab', 'Cb', 'Gb', 'Tb'],\n        color: 'rgb(54,229,238)',\n    },\n    'UNA': {\n        fullName: 'Unlocked nucleotides',\n        symbols: ['Ao', 'Co', 'Go', 'Uo'],\n        color: 'rgb(255,192,0)',\n    },\n    'A': {\n        fullName: 'Adenine',\n        symbols: ['a', 'a', 'a', 'a'],\n        color: rnaColor,\n    },\n    'C': {\n        fullName: 'Cytosine',\n        symbols: ['c', 'c', 'c', 'c'],\n        color: rnaColor,\n    },\n    'G': {\n        fullName: 'Guanine',\n        symbols: ['g', 'g', 'g', 'g'],\n        color: rnaColor,\n    },\n    'U': {\n        fullName: 'Uracil',\n        symbols: ['u', 'u', 'u', 'u'],\n        color: rnaColor,\n    },\n    'X-New': {\n        fullName: '',\n        symbols: ['X', 'X', 'X', 'X'],\n        color: 'rgb(108,0,0)',\n    },\n    'Y-New': {\n        fullName: '',\n        symbols: ['Y', 'Y', 'Y', 'Y'],\n        color: 'rgb(210,146,146)',\n    },\n    'Z-New': {\n        fullName: '',\n        symbols: ['Z', 'Z', 'Z', 'Z'],\n        color: 'rgb(155,108,132)',\n    },\n    'InvAbasic': {\n        fullName: 'Inverted abasic capped',\n        symbols: ['(invabasic)', '(invabasic)', '(invabasic)', '(invabasic)'],\n        color: invAbasicColor,\n    },\n    '5\\'-vinylps': {\n        fullName: '5\\'-vinylphosphonate-2\\'-OMe-uridine',\n        symbols: ['(vinu)', '(vinu)', '(vinu)', '(vinu)'],\n        color: 'rgb(0,0,139)',\n    },\n    'InvAbasic(o)': {\n        fullName: 'Inverted abasic capped (overhang)',\n        symbols: ['(invabasic)', '(invabasic)', '(invabasic)', '(invabasic)'],\n        color: invAbasicColor,\n    },\n    '2\\'-OMe-U(o)': {\n        fullName: 'Nucleotide Uridine with 2’O-Methyl protection (overhang)',\n        symbols: ['mU', 'mU', 'mU', 'mU'],\n        color: 'rgb(65,233,80)',\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};\n/* Do not change these import lines. Datagrok will import API library in exactly the same manner */\nimport * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\n// @ts-ignore\nimport * as svg from 'save-svg-as-png';\nimport $ from 'cash-dom';\nimport { drawAxolabsPattern } from './drawAxolabsPattern';\nimport { axolabsMap } from './axolabsMap';\nconst baseChoices = Object.keys(axolabsMap);\nconst defaultBase = baseChoices[0];\nconst defaultPto = true;\nconst defaultSequenceLength = 23;\nconst maximalValidSequenceLength = 35;\nconst userStorageKey = 'SequenceTranslator';\nconst exampleMinWidth = '400px';\nfunction generateExample(sequenceLength, sequenceBasis) {\n    const uniqueSymbols = axolabsMap[sequenceBasis].symbols.join('');\n    return uniqueSymbols.repeat(Math.floor(sequenceLength / 4)) + uniqueSymbols.slice(0, sequenceLength % 4);\n}\nfunction findDuplicates(data) {\n    return Array.from(new Set(data)).filter((value) => data.indexOf(value) !== data.lastIndexOf(value));\n}\nfunction isCurrentUserCreatedThisPattern(patternName) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return yield grok.dapi.users.current().then((user) => {\n            const [firstName, lastName] = getUserName(patternName);\n            return (user.firstName != firstName || user.lastName != lastName);\n        });\n    });\n}\nfunction getShortName(patternName) {\n    let first = patternName.length + 1;\n    for (let i = 0; i < patternName.length; i++) {\n        if (patternName[i] == '(') {\n            first = i;\n            break;\n        }\n    }\n    return patternName.slice(0, first - 1);\n}\nfunction getUserName(patternName) {\n    let first = -1;\n    for (let i = 0; i < patternName.length; i++) {\n        if (patternName[i] == '(') {\n            first = i;\n            break;\n        }\n    }\n    return (first == -1) ? ['', ''] : patternName.slice(first + 9, patternName.length - 1).split(' ').slice(1);\n}\nfunction translateSequence(sequence, bases, ptoLinkages, startModification, endModification, firstPtoExist) {\n    let counter = -1;\n    let mainSequence = sequence.replace(/[AUGC]/g, function (x) {\n        counter++;\n        const indexOfSymbol = axolabsMap['RNA']['symbols'].indexOf(x);\n        const symbol = axolabsMap[bases[counter].value]['symbols'][indexOfSymbol];\n        return (ptoLinkages[counter].value) ? symbol + 's' : symbol;\n    });\n    if (mainSequence.slice(0, 5).split('mU').length == 3)\n        mainSequence = '(uu)' + mainSequence.slice(4);\n    if (mainSequence.slice(mainSequence.length - 7).split('mU').length == 3)\n        mainSequence = mainSequence.slice(0, mainSequence.length - 4) + '(uu)';\n    return startModification.value + (firstPtoExist ? 's' : '') + mainSequence + endModification.value;\n}\nfunction addColumnWithIds(tableName, columnName, patternName) {\n    const nameOfNewColumn = 'ID ' + patternName;\n    const columns = grok.shell.table(tableName).columns;\n    if (columns.contains(nameOfNewColumn))\n        columns.remove(nameOfNewColumn);\n    const columnWithIds = columns.byName(columnName);\n    return columns.addNewString(nameOfNewColumn).init((i) => columnWithIds.get(i) + '_' + patternName);\n}\nfunction addColumnWithTranslatedSequences(tableName, columnName, bases, ptoLinkages, startModification, endModification, firstPtoExist) {\n    const nameOfNewColumn = 'Axolabs ' + columnName;\n    const columns = grok.shell.table(tableName).columns;\n    if (columns.contains(nameOfNewColumn))\n        columns.remove(nameOfNewColumn);\n    const columnWithInputSequences = columns.byName(columnName);\n    return columns.addNewString(nameOfNewColumn).init((i) => {\n        return translateSequence(columnWithInputSequences.getString(i), bases, ptoLinkages, startModification, endModification, firstPtoExist);\n    });\n}\nexport function defineAxolabsPattern() {\n    const enumerateModifications = [defaultBase];\n    let maximalSsLength = defaultSequenceLength;\n    let maximalAsLength = defaultSequenceLength;\n    function updateAsModification() {\n        asModificationItems.innerHTML = '';\n        asPtoLinkages = asPtoLinkages.concat(Array(maximalAsLength - asBases.length).fill(fullyPto));\n        asBases = asBases.concat(Array(maximalAsLength - asBases.length).fill(sequenceBase));\n        let nucleotideCounter = 0;\n        for (let i = 0; i < asLength.value; i++) {\n            asPtoLinkages[i] = ui.boolInput('', asPtoLinkages[i].value, () => {\n                updateSvgScheme();\n                updateOutputExamples();\n            });\n            asBases[i] = ui.choiceInput('', asBases[i].value, baseChoices, (v) => {\n                if (!enumerateModifications.includes(v)) {\n                    enumerateModifications.push(v);\n                    isEnumerateModificationsDiv.append(ui.boolInput(v, true, (boolV) => {\n                        if (boolV) {\n                            if (!enumerateModifications.includes(v))\n                                enumerateModifications.push(v);\n                        }\n                        else {\n                            const index = enumerateModifications.indexOf(v, 0);\n                            if (index > -1)\n                                enumerateModifications.splice(index, 1);\n                        }\n                        updateSvgScheme();\n                    }).root);\n                }\n                updateAsModification();\n                updateSvgScheme();\n                updateOutputExamples();\n            });\n            if (asBases[i].value.slice(-3) != '(o)')\n                nucleotideCounter++;\n            asModificationItems.append(ui.divH([\n                ui.div([ui.label(asBases[i].value.slice(-3) == '(o)' ? '' : String(nucleotideCounter))], { style: { width: '20px' } }),\n                ui.block75([asBases[i]]),\n                ui.div([asPtoLinkages[i]]),\n            ], { style: { alignItems: 'center' } }));\n        }\n    }\n    function updateSsModification() {\n        ssModificationItems.innerHTML = '';\n        ssPtoLinkages = ssPtoLinkages.concat(Array(maximalSsLength - ssBases.length).fill(fullyPto));\n        ssBases = ssBases.concat(Array(maximalSsLength - ssBases.length).fill(sequenceBase));\n        let nucleotideCounter = 0;\n        for (let i = 0; i < ssLength.value; i++) {\n            ssPtoLinkages[i] = ui.boolInput('', ssPtoLinkages[i].value, () => {\n                updateSvgScheme();\n                updateOutputExamples();\n            });\n            ssBases[i] = ui.choiceInput('', ssBases[i].value, baseChoices, (v) => {\n                if (!enumerateModifications.includes(v)) {\n                    enumerateModifications.push(v);\n                    isEnumerateModificationsDiv.append(ui.boolInput(v, true, (boolV) => {\n                        if (boolV) {\n                            if (!enumerateModifications.includes(v))\n                                enumerateModifications.push(v);\n                        }\n                        else {\n                            const index = enumerateModifications.indexOf(v, 0);\n                            if (index > -1)\n                                enumerateModifications.splice(index, 1);\n                        }\n                        updateSvgScheme();\n                    }).root);\n                }\n                updateSsModification();\n                updateSvgScheme();\n                updateOutputExamples();\n            });\n            if (ssBases[i].value.slice(-3) != '(o)')\n                nucleotideCounter++;\n            ssModificationItems.append(ui.divH([\n                ui.div([ui.label(ssBases[i].value.slice(-3) == '(o)' ? '' : String(nucleotideCounter))], { style: { width: '20px' } }),\n                ui.block75([ssBases[i]]),\n                ui.div([ssPtoLinkages[i]]),\n            ], { style: { alignItems: 'center' } }));\n        }\n    }\n    function updateUiForNewSequenceLength() {\n        if (ssLength.value < maximalValidSequenceLength && asLength.value < maximalValidSequenceLength) {\n            if (ssLength.value > maximalSsLength)\n                maximalSsLength = ssLength.value;\n            if (asLength.value > maximalAsLength)\n                maximalAsLength = asLength.value;\n            updateSsModification();\n            updateAsModification();\n            updateSvgScheme();\n            updateInputExamples();\n            updateOutputExamples();\n        }\n        else {\n            ui.dialog('Sequence length is out of range')\n                .add(ui.divText('Sequence length should be less than ' +\n                maximalValidSequenceLength.toString() + ' due to UI constrains.'))\n                .add(ui.divText('Please change sequence length in order to define new pattern.'))\n                .show();\n        }\n    }\n    function updatePto(newPtoValue) {\n        for (let i = 0; i < ssPtoLinkages.length; i++)\n            ssPtoLinkages[i].value = newPtoValue;\n        for (let i = 0; i < asPtoLinkages.length; i++)\n            asPtoLinkages[i].value = newPtoValue;\n        updateSvgScheme();\n    }\n    function updateBases(newBasisValue) {\n        for (let i = 0; i < ssBases.length; i++)\n            ssBases[i].value = newBasisValue;\n        for (let i = 0; i < asBases.length; i++)\n            asBases[i].value = newBasisValue;\n        updateSvgScheme();\n    }\n    function updateInputExamples() {\n        ssInputExample.value = generateExample(ssLength.value, sequenceBase.value);\n        if (createAsStrand.value)\n            asInputExample.value = generateExample(asLength.value, sequenceBase.value);\n    }\n    function updateOutputExamples() {\n        ssOutputExample.value = translateSequence(ssInputExample.value, ssBases, ssPtoLinkages, ssFiveModification, ssThreeModification, firstSsPto.value);\n        if (createAsStrand.value) {\n            asOutputExample.value = translateSequence(asInputExample.value, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstAsPto.value);\n        }\n    }\n    function updateSvgScheme() {\n        svgDiv.innerHTML = '';\n        svgDiv.append(ui.span([\n            drawAxolabsPattern(getShortName(saveAs.value), createAsStrand.value, ssBases.slice(0, ssLength.value).map((e) => e.value), asBases.slice(0, asLength.value).map((e) => e.value), [firstSsPto.value].concat(ssPtoLinkages.slice(0, ssLength.value).map((e) => e.value)), [firstAsPto.value].concat(asPtoLinkages.slice(0, asLength.value).map((e) => e.value)), ssThreeModification.value, ssFiveModification.value, asThreeModification.value, asFiveModification.value, comment.value, enumerateModifications),\n        ]));\n    }\n    function detectDefaultBasis(array) {\n        const modeMap = {};\n        let maxEl = array[0];\n        let maxCount = 1;\n        for (let i = 0; i < array.length; i++) {\n            const el = array[i];\n            if (modeMap[el] == null)\n                modeMap[el] = 1;\n            else\n                modeMap[el]++;\n            if (modeMap[el] > maxCount) {\n                maxEl = el;\n                maxCount = modeMap[el];\n            }\n        }\n        return maxEl;\n    }\n    function parsePatternAndUpdateUi(newName) {\n        return __awaiter(this, void 0, void 0, function* () {\n            const pi = DG.TaskBarProgressIndicator.create('Loading pattern...');\n            yield grok.dapi.userDataStorage.get(userStorageKey, false).then((entities) => {\n                const obj = JSON.parse(entities[newName]);\n                sequenceBase.value = detectDefaultBasis(obj['asBases'].concat(obj['ssBases']));\n                createAsStrand.value = (obj['asBases'].length > 0);\n                saveAs.value = newName;\n                ssBases = [];\n                for (let i = 0; i < obj['ssBases'].length; i++)\n                    ssBases.push(ui.choiceInput('', obj['ssBases'][i], baseChoices));\n                asBases = [];\n                for (let i = 0; i < obj['asBases'].length; i++)\n                    asBases.push(ui.choiceInput('', obj['asBases'][i], baseChoices));\n                firstSsPto.value = obj['ssPtoLinkages'][0];\n                ssPtoLinkages = [];\n                for (let i = 1; i < obj['ssPtoLinkages'].length; i++)\n                    ssPtoLinkages.push(ui.boolInput('', obj['ssPtoLinkages'][i]));\n                firstAsPto.value = obj['asPtoLinkages'][0];\n                asPtoLinkages = [];\n                for (let i = 1; i < obj['asPtoLinkages'].length; i++)\n                    asPtoLinkages.push(ui.boolInput('', obj['asPtoLinkages'][i]));\n                ssLength.value = obj['ssBases'].length;\n                asLength.value = obj['asBases'].length;\n                ssThreeModification.value = obj['ssThreeModification'];\n                ssFiveModification.value = obj['ssFiveModification'];\n                asThreeModification.value = obj['asThreeModification'];\n                asFiveModification.value = obj['asFiveModification'];\n                comment.value = obj['comment'];\n            });\n            pi.close();\n        });\n    }\n    function checkWhetherAllValuesInColumnHaveTheSameLength(colName) {\n        const col = tables.value.columns.byName(colName);\n        let allLengthsAreTheSame = true;\n        for (let i = 1; i < col.length; i++) {\n            if (col.get(i - 1).length != col.get(i).length) {\n                allLengthsAreTheSame = false;\n                break;\n            }\n        }\n        if (!allLengthsAreTheSame) {\n            const dialog = ui.dialog('Sequences lengths mismatch');\n            $(dialog.getButton('OK')).hide();\n            dialog\n                .add(ui.divText('The sequence length should match the number of Raw sequences in the input file'))\n                .add(ui.divText('\\'ADD COLUMN\\' to see sequences lengths'))\n                .addButton('ADD COLUMN', () => {\n                tables.value.columns.addNewInt('Sequences lengths in ' + colName).init((j) => col.get(j).length);\n                grok.shell.info('Column with lengths added to \\'' + tables.value.name + '\\'');\n                dialog.close();\n                grok.shell.v = grok.shell.getTableView(tables.value.name);\n            })\n                .show();\n        }\n        return allLengthsAreTheSame;\n    }\n    function getCurrentUserName() {\n        return __awaiter(this, void 0, void 0, function* () {\n            return yield grok.dapi.users.current().then((user) => {\n                return ' (created by ' + user.firstName + ' ' + user.lastName + ')';\n            });\n        });\n    }\n    function postPatternToUserStorage() {\n        return __awaiter(this, void 0, void 0, function* () {\n            const author = yield getCurrentUserName();\n            if (!saveAs.stringValue.includes('(created by '))\n                saveAs.value = saveAs.stringValue + author;\n            return grok.dapi.userDataStorage.postValue(userStorageKey, saveAs.stringValue, JSON.stringify({\n                'ssBases': ssBases.slice(0, ssLength.value).map((e) => e.value),\n                'asBases': asBases.slice(0, asLength.value).map((e) => e.value),\n                'ssPtoLinkages': [firstSsPto.value].concat(ssPtoLinkages.slice(0, ssLength.value).map((e) => e.value)),\n                'asPtoLinkages': [firstAsPto.value].concat(asPtoLinkages.slice(0, asLength.value).map((e) => e.value)),\n                'ssThreeModification': ssThreeModification.value,\n                'ssFiveModification': ssFiveModification.value,\n                'asThreeModification': asThreeModification.value,\n                'asFiveModification': asFiveModification.value,\n                'comment': comment.value,\n            }), false).then(() => grok.shell.info('Pattern \\'' + saveAs.value + '\\' was successfully uploaded!'));\n        });\n    }\n    function updatePatternsList() {\n        return __awaiter(this, void 0, void 0, function* () {\n            grok.dapi.userDataStorage.get(userStorageKey, false).then((entities) => __awaiter(this, void 0, void 0, function* () {\n                const lstMy = [];\n                const lstOthers = [];\n                for (const ent of Object.keys(entities)) {\n                    if (yield isCurrentUserCreatedThisPattern(ent))\n                        lstOthers.push(ent);\n                    else\n                        lstMy.push(getShortName(ent));\n                }\n                let loadPattern = ui.choiceInput('Load Pattern', '', lstMy, (v) => parsePatternAndUpdateUi(v));\n                const myOrOthersPatternList = ui.choiceInput('', 'Mine', ['Mine', 'Others'], (v) => {\n                    const currentList = v == 'Mine' ? lstMy : lstOthers;\n                    loadPattern = ui.choiceInput('Load Pattern', '', currentList, (v) => parsePatternAndUpdateUi(v));\n                    loadPattern.root.append(myOrOthersPatternList.input);\n                    loadPattern.root.append(loadPattern.input);\n                    // @ts-ignore\n                    loadPattern.input.style.maxWidth = '100px';\n                    loadPattern.setTooltip('Apply Existing Pattern');\n                    loadPatternDiv.innerHTML = '';\n                    loadPatternDiv.append(loadPattern.root);\n                    loadPattern.root.append(ui.div([\n                        ui.button(ui.iconFA('trash-alt', () => { }), () => __awaiter(this, void 0, void 0, function* () {\n                            if (loadPattern.value == null)\n                                grok.shell.warning('Choose pattern to delete');\n                            else if (yield isCurrentUserCreatedThisPattern(saveAs.value))\n                                grok.shell.warning('Cannot delete pattern, created by other user');\n                            else {\n                                yield grok.dapi.userDataStorage.remove(userStorageKey, loadPattern.value, false)\n                                    .then(() => grok.shell.info('Pattern \\'' + loadPattern.value + '\\' deleted'));\n                            }\n                            yield updatePatternsList();\n                        })),\n                    ], 'ui-input-options'));\n                });\n                loadPattern.root.append(myOrOthersPatternList.input);\n                loadPattern.root.append(loadPattern.input);\n                // @ts-ignore\n                loadPattern.input.style.maxWidth = '100px';\n                loadPattern.setTooltip('Apply Existing Pattern');\n                loadPatternDiv.innerHTML = '';\n                loadPatternDiv.append(loadPattern.root);\n                loadPattern.root.append(ui.div([\n                    ui.button(ui.iconFA('trash-alt', () => { }), () => __awaiter(this, void 0, void 0, function* () {\n                        if (loadPattern.value == null)\n                            grok.shell.warning('Choose pattern to delete');\n                        else if (yield isCurrentUserCreatedThisPattern(saveAs.value))\n                            grok.shell.warning('Cannot delete pattern, created by other user');\n                        else {\n                            yield grok.dapi.userDataStorage.remove(userStorageKey, loadPattern.value, false)\n                                .then(() => grok.shell.info('Pattern \\'' + loadPattern.value + '\\' deleted'));\n                        }\n                        yield updatePatternsList();\n                    })),\n                ], 'ui-input-options'));\n            }));\n        });\n    }\n    function savePattern() {\n        return __awaiter(this, void 0, void 0, function* () {\n            yield grok.dapi.userDataStorage.get(userStorageKey, false)\n                .then((entities) => {\n                if (Object.keys(entities).includes(saveAs.value)) {\n                    const dialog = ui.dialog('Pattern already exists');\n                    $(dialog.getButton('OK')).hide();\n                    dialog\n                        .add(ui.divText('Pattern name \\'' + saveAs.value + '\\' already exists.'))\n                        .add(ui.divText('Replace pattern?'))\n                        .addButton('YES', () => __awaiter(this, void 0, void 0, function* () {\n                        yield grok.dapi.userDataStorage.remove(userStorageKey, saveAs.value, false)\n                            .then(() => postPatternToUserStorage());\n                        dialog.close();\n                    }))\n                        .show();\n                }\n                else\n                    postPatternToUserStorage();\n            });\n            yield updatePatternsList();\n        });\n    }\n    const inputSsColumnDiv = ui.div([]);\n    const inputAsColumnDiv = ui.div([]);\n    const inputIdColumnDiv = ui.div([]);\n    const ssModificationItems = ui.div([]);\n    const asModificationItems = ui.div([]);\n    const svgDiv = ui.div([]);\n    const asExampleDiv = ui.div([]);\n    const appAxolabsDescription = ui.div([]);\n    const loadPatternDiv = ui.div([]);\n    const asModificationDiv = ui.div([]);\n    const firstAsPtoDiv = ui.div([]);\n    const isEnumerateModificationsDiv = ui.divH([ui.boolInput(defaultBase, true, (v) => {\n            if (v) {\n                if (!enumerateModifications.includes(defaultBase))\n                    enumerateModifications.push(defaultBase);\n            }\n            else {\n                const index = enumerateModifications.indexOf(defaultBase, 0);\n                if (index > -1)\n                    enumerateModifications.splice(index, 1);\n            }\n            updateSvgScheme();\n            updateOutputExamples();\n        }).root]);\n    let ssBases = Array(defaultSequenceLength).fill(ui.choiceInput('', defaultBase, baseChoices));\n    let asBases = Array(defaultSequenceLength).fill(ui.choiceInput('', defaultBase, baseChoices));\n    let ssPtoLinkages = Array(defaultSequenceLength).fill(ui.boolInput('', defaultPto));\n    let asPtoLinkages = Array(defaultSequenceLength).fill(ui.boolInput('', defaultPto));\n    const ssLength = ui.intInput('SS Length', defaultSequenceLength, () => updateUiForNewSequenceLength());\n    const asLength = ui.intInput('AS Length', defaultSequenceLength, () => updateUiForNewSequenceLength());\n    const asLengthDiv = ui.div([asLength.root]);\n    function validateSsColumn(colName) {\n        const allLengthsAreTheSame = checkWhetherAllValuesInColumnHaveTheSameLength(colName);\n        const firstSequence = tables.value.columns.byName(colName).get(0);\n        if (allLengthsAreTheSame && firstSequence.length != ssLength.value)\n            ssLength.value = tables.value.columns.byName(colName).get(0).length;\n        ssInputExample.value = firstSequence;\n    }\n    function validateAsColumn(colName) {\n        const allLengthsAreTheSame = checkWhetherAllValuesInColumnHaveTheSameLength(colName);\n        const firstSequence = tables.value.columns.byName(colName).get(0);\n        if (allLengthsAreTheSame && firstSequence.length != asLength.value)\n            asLength.value = tables.value.columns.byName(colName).get(0).length;\n        asLengthDiv.innerHTML = '';\n        asLengthDiv.append(asLength.root);\n        asInputExample.value = firstSequence;\n    }\n    function validateIdsColumn(colName) {\n        const col = tables.value.columns.byName(colName);\n        if (col.type != DG.TYPE.INT)\n            grok.shell.error('Column should contain integers only');\n        else if (col.categories.length < col.length) {\n            const duplicates = findDuplicates(col.getRawData());\n            ui.dialog('Non-unique IDs')\n                .add(ui.divText('Press \\'OK\\' to select rows with non-unique values'))\n                .onOK(() => {\n                const selection = tables.value.selection;\n                selection.init((i) => duplicates.indexOf(col.get(i)) > -1);\n                grok.shell.v = grok.shell.getTableView(tables.value.name);\n                grok.shell.info('Rows are selected in table \\'' + tables.value.name + '\\'');\n            })\n                .show();\n        }\n    }\n    const tables = ui.tableInput('Tables', grok.shell.tables[0], grok.shell.tables, (t) => {\n        const inputSsColumn = ui.choiceInput('SS Column', '', t.columns.names(), (colName) => validateSsColumn(colName));\n        inputSsColumnDiv.innerHTML = '';\n        inputSsColumnDiv.append(inputSsColumn.root);\n        const inputAsColumn = ui.choiceInput('AS Column', '', t.columns.names(), (colName) => validateAsColumn(colName));\n        inputAsColumnDiv.innerHTML = '';\n        inputAsColumnDiv.append(inputAsColumn.root);\n        const inputIdColumn = ui.choiceInput('ID Column', '', t.columns.names(), (colName) => validateIdsColumn(colName));\n        inputIdColumnDiv.innerHTML = '';\n        inputIdColumnDiv.append(inputIdColumn.root);\n    });\n    const inputSsColumn = ui.choiceInput('SS Column', '', []);\n    inputSsColumnDiv.append(inputSsColumn.root);\n    const inputAsColumn = ui.choiceInput('AS Column', '', []);\n    inputAsColumnDiv.append(inputAsColumn.root);\n    const inputIdColumn = ui.choiceInput('ID Column', '', []);\n    inputIdColumnDiv.append(inputIdColumn.root);\n    updatePatternsList();\n    const sequenceBase = ui.choiceInput('Sequence Basis', defaultBase, baseChoices, (v) => {\n        updateBases(v);\n        updateOutputExamples();\n    });\n    const fullyPto = ui.boolInput('Fully PTO', defaultPto, (v) => {\n        firstSsPto.value = v;\n        firstAsPto.value = v;\n        updatePto(v);\n        updateOutputExamples();\n    });\n    const firstSsPto = ui.boolInput('First SS PTO', fullyPto.value, () => updateSvgScheme());\n    const firstAsPto = ui.boolInput('First AS PTO', fullyPto.value, () => updateSvgScheme());\n    firstAsPtoDiv.append(firstAsPto.root);\n    const createAsStrand = ui.boolInput('Create AS Strand', true, (v) => {\n        asModificationSection.hidden = (!v);\n        inputAsColumnDiv.hidden = (!v);\n        asLengthDiv.hidden = (!v);\n        asModificationDiv.hidden = (!v);\n        asExampleDiv.hidden = (!v);\n        firstAsPtoDiv.hidden = (!v);\n        updateSvgScheme();\n    });\n    const saveAs = ui.textInput('Save As', 'Pattern Name', () => updateSvgScheme());\n    saveAs.setTooltip('Name Of New Pattern');\n    const ssThreeModification = ui.stringInput('SS 3\\' Modification', '', () => {\n        updateSvgScheme();\n        updateOutputExamples();\n    });\n    ssThreeModification.setTooltip('Additional SS 3\\' Modification');\n    const ssFiveModification = ui.stringInput('SS 5\\' Modification', '', () => {\n        updateSvgScheme();\n        updateOutputExamples();\n    });\n    ssFiveModification.setTooltip('Additional SS 5\\' Modification');\n    const asThreeModification = ui.stringInput('AS 3\\' Modification', '', () => {\n        updateSvgScheme();\n        updateOutputExamples();\n    });\n    asThreeModification.setTooltip('Additional AS 3\\' Modification');\n    const asFiveModification = ui.stringInput('AS 5\\' Modification', '', () => {\n        updateSvgScheme();\n        updateOutputExamples();\n    });\n    asFiveModification.setTooltip('Additional AS 5\\' Modification');\n    asModificationDiv.append(asThreeModification.root);\n    asModificationDiv.append(asFiveModification.root);\n    const comment = ui.textInput('Comment', '', () => updateSvgScheme());\n    const savePatternButton = ui.button('Save', () => {\n        if (saveAs.value != '')\n            savePattern().then((r) => grok.shell.info('Pattern saved'));\n        else {\n            const name = ui.stringInput('Enter Name', '');\n            ui.dialog('Pattern Name')\n                .add(name.root)\n                .onOK(() => {\n                saveAs.value = name.value;\n                savePattern().then((r) => grok.shell.info('Pattern saved'));\n            })\n                .show();\n        }\n    });\n    const convertSequenceButton = ui.button('Convert Sequences', () => {\n        if (inputSsColumn.value == null || (createAsStrand.value && inputAsColumn.value == null))\n            grok.shell.info('Please select table and columns on which to apply pattern');\n        else if (ssLength.value != ssInputExample.value.length || asLength.value != asInputExample.value.length) {\n            const dialog = ui.dialog('Length Mismatch');\n            $(dialog.getButton('OK')).hide();\n            dialog\n                .add(ui.divText('Length of sequences in columns doesn\\'t match entered length. Update length value?'))\n                .addButton('YES', () => {\n                ssLength.value = tables.value.columns.byName(inputSsColumn.value).getString(0).length;\n                asLength.value = tables.value.columns.byName(inputAsColumn.value).getString(0).length;\n                dialog.close();\n            })\n                .show();\n        }\n        else {\n            if (inputIdColumn.value != null)\n                addColumnWithIds(tables.value.name, inputIdColumn.value, getShortName(saveAs.value));\n            addColumnWithTranslatedSequences(tables.value.name, inputSsColumn.value, ssBases, ssPtoLinkages, ssFiveModification, ssThreeModification, firstSsPto.value);\n            if (createAsStrand.value) {\n                addColumnWithTranslatedSequences(tables.value.name, inputAsColumn.value, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstAsPto.value);\n            }\n            grok.shell.v = grok.shell.getTableView(tables.value.name);\n            grok.shell.info(((createAsStrand.value) ? 'Columns were' : 'Column was') +\n                ' added to table \\'' + tables.value.name + '\\'');\n        }\n    });\n    const ssInputExample = ui.textInput('Sense Strand', generateExample(ssLength.value, sequenceBase.value), () => {\n        ssOutputExample.value = translateSequence(ssInputExample.value, ssBases, ssPtoLinkages, ssFiveModification, ssThreeModification, firstSsPto.value);\n    });\n    const ssOutputExample = ui.textInput(' ', translateSequence(ssInputExample.value, ssBases, ssPtoLinkages, ssThreeModification, ssFiveModification, firstSsPto.value));\n    ssInputExample.input.style.resize = 'none';\n    ssInputExample.input.style.minWidth = exampleMinWidth;\n    ssOutputExample.input.style.resize = 'none';\n    ssOutputExample.input.style.minWidth = exampleMinWidth;\n    // @ts-ignore\n    ssOutputExample.input.disabled = 'true';\n    ssOutputExample.root.append(ui.div([\n        ui.button(ui.iconFA('copy', () => { }), () => {\n            navigator.clipboard.writeText(ssOutputExample.value).then(() => grok.shell.info('Sequence was copied to clipboard'));\n        }),\n    ], 'ui-input-options'));\n    const asInputExample = ui.textInput('Antisense Strand', generateExample(asLength.value, sequenceBase.value), () => {\n        asOutputExample.value = translateSequence(asInputExample.value, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstSsPto.value);\n    });\n    const asOutputExample = ui.textInput(' ', translateSequence(asInputExample.value, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstSsPto.value));\n    asInputExample.input.style.resize = 'none';\n    asInputExample.input.style.minWidth = exampleMinWidth;\n    asOutputExample.input.style.resize = 'none';\n    asOutputExample.input.style.minWidth = exampleMinWidth;\n    // @ts-ignore\n    asOutputExample.input.disabled = 'true';\n    asOutputExample.root.append(ui.div([\n        ui.button(ui.iconFA('copy', () => { }), () => {\n            navigator.clipboard.writeText(asOutputExample.value).then(() => grok.shell.info('Sequence was copied to clipboard'));\n        }),\n    ], 'ui-input-options'));\n    asExampleDiv.append(asInputExample.root);\n    asExampleDiv.append(asOutputExample.root);\n    updateUiForNewSequenceLength();\n    const exampleSection = ui.div([\n        ui.h1('Example'),\n        ssInputExample.root,\n        ssOutputExample.root,\n        asExampleDiv,\n    ], 'ui-form');\n    const inputsSection = ui.div([\n        ui.h1('Inputs'),\n        ui.divH([\n            tables.root,\n            inputSsColumnDiv,\n        ]),\n        ui.divH([\n            inputAsColumnDiv,\n            inputIdColumnDiv,\n        ]),\n        ui.buttonsInput([\n            convertSequenceButton,\n        ]),\n    ], 'ui-form');\n    const mainSection = ui.panel([\n        ui.block([\n            svgDiv,\n        ], { style: { overflowX: 'scroll' } }),\n        ui.button('Download', () => svg.saveSvgAsPng(document.getElementById('mySvg'), saveAs.value)),\n        isEnumerateModificationsDiv,\n        ui.div([\n            ui.div([\n                ui.divH([\n                    ui.h1('Pattern'),\n                    ui.div([\n                        ui.iconFA('question-circle', () => {\n                            appAxolabsDescription.innerHTML = '';\n                            appAxolabsDescription.append(info);\n                        }),\n                    ], { style: { padding: '2px' } }),\n                ]),\n                ui.divH([\n                    ui.div([\n                        ssLength.root,\n                        asLengthDiv,\n                        sequenceBase.root,\n                        comment.root,\n                        loadPatternDiv,\n                        saveAs.root,\n                        ui.buttonsInput([\n                            savePatternButton,\n                        ]),\n                    ], 'ui-form'),\n                    ui.div([\n                        createAsStrand.root,\n                        fullyPto.root,\n                        firstSsPto.root,\n                        firstAsPtoDiv,\n                        ssFiveModification.root,\n                        ssThreeModification.root,\n                        asModificationDiv,\n                    ], 'ui-form'),\n                ], 'ui-form'),\n            ], 'ui-form'),\n            inputsSection,\n            exampleSection,\n        ], { style: { flexWrap: 'wrap' } }),\n    ]);\n    const ssModificationSection = ui.panel([\n        ui.h1('Sense Strand'),\n        ui.divH([\n            ui.div([ui.divText('#')], { style: { width: '20px' } }),\n            ui.block75([ui.divText('Modification')]),\n            ui.div([ui.divText('PTO')], { style: { paddingRight: '8px' } }),\n        ]),\n        ssModificationItems,\n    ]);\n    const asModificationSection = ui.panel([\n        ui.h1('Antisense Strand'),\n        ui.divH([\n            ui.div([ui.divText('#')], { style: { width: '20px' } }),\n            ui.block75([ui.divText('Modification')]),\n            ui.div([ui.divText('PTO')], { style: { paddingRight: '8px' } }),\n        ]),\n        asModificationItems,\n    ]);\n    const info = ui.info([\n        ui.divText('\\n How to define new pattern:', { style: { 'font-weight': 'bolder' } }),\n        ui.divText('1. Choose table and columns with sense and antisense strands'),\n        ui.divText('2. Choose lengths of both strands by editing checkboxes below'),\n        ui.divText('3. Choose basis and PTO status for each nucleotide'),\n        ui.divText('4. Set additional modifications for sequence edges'),\n        ui.divText('5. Press \\'Convert Sequences\\' button'),\n        ui.divText('This will add the result column(s) to the right of the table'),\n    ], 'Create and apply Axolabs translation patterns.');\n    return ui.splitH([\n        ui.div([\n            appAxolabsDescription,\n            mainSection,\n        ]),\n        ui.box(ui.divH([\n            ssModificationSection,\n            asModificationSection,\n        ]), { style: { maxWidth: '360px' } }),\n    ]);\n}\n","import { axolabsMap } from './axolabsMap';\n// https://uxdesign.cc/star-rating-make-svg-great-again-d4ce4731347e\nfunction getPointsToDrawStar(centerX, centerY) {\n    const innerCirclePoints = 5; // a 5 point star\n    const innerRadius = 15 / innerCirclePoints;\n    const innerOuterRadiusRatio = 2; // outter circle is x2 the inner\n    const outerRadius = innerRadius * innerOuterRadiusRatio;\n    const angle = Math.PI / innerCirclePoints;\n    const angleOffsetToCenterStar = 60;\n    const totalNumberOfPoints = innerCirclePoints * 2; // 10 in a 5-points star\n    let points = '';\n    for (let i = 0; i < totalNumberOfPoints; i++) {\n        const r = (i % 2 == 0) ? outerRadius : innerRadius;\n        const currentX = centerX + Math.cos(i * angle + angleOffsetToCenterStar) * r;\n        const currentY = centerY + Math.sin(i * angle + angleOffsetToCenterStar) * r;\n        points += currentX + ',' + currentY + ' ';\n    }\n    return points;\n}\nfunction countOverhangsOnTheRightEdge(modifications) {\n    let i = 0;\n    while (i < modifications.length && modifications[i].slice(-3) == '(o)')\n        i++;\n    return (i == modifications.length - 1) ? 0 : i;\n}\nfunction getTextWidth(text, font) {\n    const context = document.createElement('canvas').getContext('2d');\n    // @ts-ignore\n    context.font = String(font);\n    // @ts-ignore\n    return 2 * context.measureText(text).width;\n}\nfunction getTextInsideCircle(bases, index, nucleotideCounter, numberOfNucleotides, enumerateModifications) {\n    return (bases[index].slice(-3) == '(o)') || !enumerateModifications.includes(bases[index]) ? '' :\n        ['A', 'G', 'C', 'U', 'T'].includes(bases[index]) ? bases[index] : String(numberOfNucleotides - nucleotideCounter);\n}\nfunction getFontColorVisibleOnBackground(rgbString) {\n    const rgbIntList = rgbString.match(/\\d+/g).map((e) => Number(e));\n    return (rgbIntList[0] * 0.299 + rgbIntList[1] * 0.587 + rgbIntList[2] * 0.114) > 186 ? '#33333' : '#ffffff';\n}\nfunction getBaseColor(base) {\n    return axolabsMap[base]['color'];\n}\nexport function drawAxolabsPattern(patternName, asExists, ssBases, asBases, ssPtoStatuses, asPtoStatuses, ssThreeModification, ssFiveModification, asThreeModification, asFiveModification, comment, enumerateModifications) {\n    function getEquidistantXForLegend(index) {\n        return Math.round((index + startFrom) * width / (uniqueBases.length + startFrom) + legendRadius);\n    }\n    function getXOfBaseCircles(index, rightOverhangs) {\n        return widthOfRightModification +\n            (resultingNumberOfNucleotidesInStrands - index + rightOverhangs + 1) * baseDiameter;\n    }\n    function getShiftToAlignNumberInsideCircle(bases, generalIndex, nucleotideIndex) {\n        return (nucleotideIndex < 10 || ['A', 'G', 'C', 'U', 'T'].\n            includes(bases[generalIndex])) ? shiftToAlignOneDigitNumberInsideCircle : shiftToAlignTwoDigitNumberInsideCircle;\n    }\n    const svg = {\n        xmlns: 'http://www.w3.org/2000/svg',\n        render: function (width, height) {\n            const e = document.createElementNS(this.xmlns, 'svg');\n            e.setAttribute('id', 'mySvg');\n            e.setAttribute('width', String(width));\n            e.setAttribute('height', String(height));\n            return e;\n        },\n        circle: function (x, y, radius, color) {\n            const e = document.createElementNS(this.xmlns, 'circle');\n            e.setAttribute('cx', String(x));\n            e.setAttribute('cy', String(y));\n            e.setAttribute('r', String(radius));\n            e.setAttribute('fill', color);\n            return e;\n        },\n        text: function (text, x, y, fontSize, color) {\n            const e = document.createElementNS(this.xmlns, 'text');\n            e.setAttribute('x', String(x));\n            e.setAttribute('y', String(y));\n            e.setAttribute('font-size', String(fontSize));\n            e.setAttribute('font-weight', 'normal');\n            e.setAttribute('font-family', 'Arial');\n            e.setAttribute('fill', color);\n            e.innerHTML = text;\n            return e;\n        },\n        star: function (x, y, fill) {\n            const e = document.createElementNS(this.xmlns, 'polygon');\n            e.setAttribute('points', getPointsToDrawStar(x, y));\n            e.setAttribute('fill', fill);\n            return e;\n        },\n    };\n    ssBases = ssBases.reverse();\n    ssPtoStatuses = ssPtoStatuses.reverse();\n    const baseRadius = 15;\n    const shiftToAlignTwoDigitNumberInsideCircle = -10;\n    const shiftToAlignOneDigitNumberInsideCircle = -5;\n    const legendRadius = 6;\n    const psLinkageRadius = 5;\n    const baseFontSize = 17;\n    const legendFontSize = 14;\n    const psLinkageColor = 'red';\n    const fontColor = 'var(--grey-6)';\n    const titleFontColor = 'black';\n    const modificationsColor = 'red';\n    const ssLeftText = 'SS: 5\\'';\n    const asLeftText = 'AS: 3\\'';\n    const ssRightText = '3\\'';\n    const asRightText = '5\\'';\n    const ssRightOverhangs = countOverhangsOnTheRightEdge(ssBases);\n    const asRightOverhangs = countOverhangsOnTheRightEdge(asBases);\n    const resultingNumberOfNucleotidesInStrands = Math.max(ssBases.length - ssRightOverhangs, asBases.length - asRightOverhangs);\n    const baseDiameter = 2 * baseRadius;\n    const widthOfBases = baseDiameter * (resultingNumberOfNucleotidesInStrands + Math.max(ssRightOverhangs, asRightOverhangs));\n    const widthOfLeftModification = Math.max(getTextWidth(ssThreeModification, baseFontSize), getTextWidth(asFiveModification, baseFontSize));\n    const widthOfRightModification = Math.max(getTextWidth(ssFiveModification, baseFontSize), getTextWidth(asThreeModification, baseFontSize));\n    const widthOfLeftText = Math.max(getTextWidth(ssLeftText, baseFontSize), getTextWidth(asLeftText, baseFontSize));\n    const widthOfRightText = Math.max(getTextWidth(ssRightText, baseFontSize), getTextWidth(asRightText, baseFontSize));\n    const width = widthOfLeftText + widthOfLeftModification + widthOfBases +\n        widthOfRightModification + widthOfRightText + baseDiameter;\n    const height = asExists ? 11 * baseRadius : 9 * baseRadius;\n    const xOfTitle = baseRadius; // Math.round(width / 4),\n    const uniqueBases = asExists ? [...new Set(ssBases.concat(asBases))] : [...new Set(ssBases)];\n    const isPtoExist = asExists ? [...new Set(ssPtoStatuses.concat(asPtoStatuses))].includes(true) :\n        [...new Set(ssPtoStatuses)].includes(true);\n    const startFrom = isPtoExist ? 1 : 0;\n    const xOfLeftTexts = 0;\n    const xOfLeftModifications = xOfLeftTexts + widthOfLeftText - 5;\n    const xOfSsRightModifications = ssRightOverhangs * baseDiameter + getXOfBaseCircles(-0.5, 0);\n    const xOfAsRightModifications = asRightOverhangs * baseDiameter + getXOfBaseCircles(-0.5, 0);\n    const xOfRightTexts = Math.max(xOfSsRightModifications, xOfAsRightModifications) +\n        widthOfLeftModification + baseDiameter * (Math.max(ssRightOverhangs, asRightOverhangs));\n    const yOfTitle = baseRadius;\n    const yOfSsTexts = 4 * baseRadius;\n    const yOfAsTexts = 7 * baseRadius;\n    const yOfComment = asExists ? 11 * baseRadius : 8.5 * baseRadius;\n    const yOfSsCircles = 3.5 * baseRadius;\n    const yOfAsCircles = 6.5 * baseRadius;\n    const yOfCirclesInLegends = asExists ? 9 * baseRadius : 6 * baseRadius;\n    const yOfTextLegend = asExists ? 9.5 * baseRadius - 3 : yOfAsCircles - 3;\n    const image = svg.render(width, height);\n    image.append(svg.text(ssLeftText, xOfLeftTexts, yOfSsTexts, baseFontSize, fontColor), asExists ? svg.text(asLeftText, xOfLeftTexts, yOfAsTexts, baseFontSize, fontColor) : '', svg.text(ssRightText, xOfRightTexts, yOfSsTexts, baseFontSize, fontColor), asExists ? svg.text(asRightText, xOfRightTexts, yOfAsTexts, baseFontSize, fontColor) : '', svg.text(ssFiveModification, xOfLeftModifications, yOfSsTexts, baseFontSize, modificationsColor), asExists ? svg.text(asThreeModification, xOfLeftModifications, yOfAsTexts, baseFontSize, modificationsColor) : '', svg.text(ssThreeModification, xOfSsRightModifications, yOfSsTexts, baseFontSize, modificationsColor), asExists ? svg.text(asFiveModification, xOfAsRightModifications, yOfAsTexts, baseFontSize, modificationsColor) : '', svg.text(comment, xOfLeftTexts, yOfComment, legendFontSize, fontColor), isPtoExist ? svg.star(baseRadius, yOfCirclesInLegends, psLinkageColor) : '', isPtoExist ? svg.text('ps linkage', 2 * baseRadius - 8, yOfTextLegend, legendFontSize, fontColor) : '');\n    let numberOfSsNucleotides = 0;\n    for (let i = 0; i < ssBases.length; i++) {\n        if (ssBases[i].slice(-3) != '(o)')\n            numberOfSsNucleotides++;\n    }\n    let nucleotideCounter = numberOfSsNucleotides;\n    for (let i = ssBases.length - 1; i > -1; i--) {\n        if (ssBases[i].slice(-3) != '(o)')\n            nucleotideCounter--;\n        image.append(svg.circle(getXOfBaseCircles(i, ssRightOverhangs), yOfSsCircles, baseRadius, getBaseColor(ssBases[i])), svg.text(getTextInsideCircle(ssBases, i, nucleotideCounter, numberOfSsNucleotides, enumerateModifications), getXOfBaseCircles(i, ssRightOverhangs) +\n            getShiftToAlignNumberInsideCircle(ssBases, ssBases.length - i, numberOfSsNucleotides - nucleotideCounter), yOfSsTexts, baseFontSize, getFontColorVisibleOnBackground(axolabsMap[ssBases[i]]['color'])), ssPtoStatuses[i] ?\n            svg.star(getXOfBaseCircles(i, ssRightOverhangs) + baseRadius, yOfSsTexts + psLinkageRadius, psLinkageColor) :\n            '');\n    }\n    image.append(ssPtoStatuses[ssBases.length] ?\n        svg.star(getXOfBaseCircles(ssBases.length, ssRightOverhangs) +\n            baseRadius, yOfSsTexts + psLinkageRadius, psLinkageColor) : '');\n    let numberOfAsNucleotides = 0;\n    for (let i = 0; i < asBases.length; i++) {\n        if (asBases[i].slice(-3) != '(o)')\n            numberOfAsNucleotides++;\n    }\n    if (asExists) {\n        let nucleotideCounter = numberOfAsNucleotides;\n        for (let i = asBases.length - 1; i > -1; i--) {\n            if (asBases[i].slice(-3) != '(o)')\n                nucleotideCounter--;\n            image.append(svg.circle(getXOfBaseCircles(i, asRightOverhangs), yOfAsCircles, baseRadius, getBaseColor(asBases[i])), svg.text(getTextInsideCircle(asBases, i, numberOfAsNucleotides - nucleotideCounter - 1, numberOfAsNucleotides, enumerateModifications), getXOfBaseCircles(i, asRightOverhangs) +\n                getShiftToAlignNumberInsideCircle(asBases, i, nucleotideCounter + 1), yOfAsTexts, baseFontSize, getFontColorVisibleOnBackground(axolabsMap[asBases[i]]['color'])), asPtoStatuses[i] ? svg.star(getXOfBaseCircles(i, asRightOverhangs) +\n                baseRadius, yOfAsTexts + psLinkageRadius, psLinkageColor) : '');\n        }\n        image.append(asPtoStatuses[asBases.length] ?\n            svg.star(getXOfBaseCircles(asBases.length, asRightOverhangs) +\n                baseRadius, yOfAsTexts + psLinkageRadius, psLinkageColor) : '');\n    }\n    const title = patternName + ' for ' +\n        String(numberOfSsNucleotides) + (asExists ? '/' + String(numberOfAsNucleotides) : '') + 'mer';\n    image.append(svg.text(title, xOfTitle, yOfTitle, baseFontSize, titleFontColor));\n    for (let i = 0; i < uniqueBases.length; i++) {\n        image.append(svg.circle(getEquidistantXForLegend(i), yOfCirclesInLegends, legendRadius, getBaseColor(uniqueBases[i])), svg.text(uniqueBases[i], getEquidistantXForLegend(i) +\n            legendRadius + 4, yOfTextLegend, legendFontSize, fontColor));\n    }\n    return image;\n}\n","export const SALTS_CSV = `DISPLAY,MOLWEIGHT\nno Data Added,100`;\n","export const SOURCES = `DISPLAY\nNO DATA\n`;\n","//name: asoGapmersNucleotidesToBioSpring\n//input: string nucleotides {semType: DNA nucleotides}\n//output: string result {semType: BioSpring / Gapmers}\nexport function asoGapmersNucleotidesToBioSpring(nucleotides) {\n    let count = -1;\n    const objForEdges = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': '5*', 'A': '6*', 'C': '7*', 'G': '8*'\n    };\n    const objForCenter = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'T*', 'A': 'A*', 'C': '9*', 'G': 'G*'\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|T|C|G)/g, function (x) {\n        count++;\n        return (count > 4 && count < 15) ? objForCenter[x] : objForEdges[x];\n    }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?\n        nucleotides.length : 2 * count + 1);\n}\n//name: asoGapmersNucleotidesToGcrs\n//input: string nucleotides {semType: DNA nucleotides}\n//output: string result {semType: GCRS / Gapmers}\nexport function asoGapmersNucleotidesToGcrs(nucleotides) {\n    let count = -1;\n    const objForEdges = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'moeUnps',\n        'A': 'moeAnps', 'C': 'moe5mCnps', 'G': 'moeGnps'\n    };\n    const objForCenter = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'C': '5mCps', 'A': 'Aps', 'T': 'Tps', 'G': 'Gps' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|T|C|G)/g, function (x) {\n        count++;\n        if (count < 5)\n            return (count == 4) ? objForEdges[x].slice(0, -3) + 'ps' : objForEdges[x];\n        if (count < 15)\n            return (count == 14) ? objForCenter[x].slice(0, -2) + 'nps' : objForCenter[x];\n        return objForEdges[x];\n    }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?\n        nucleotides.length : -3);\n}\n//name: asoGapmersBioSpringToNucleotides\n//input: string nucleotides {semType: BioSpring / Gapmers}\n//output: string result {semType: DNA nucleotides}\nexport function asoGapmersBioSpringToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '*': '', '5': 'T', '6': 'A', '7': 'C', '8': 'G', '9': 'C' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|\\*|5|6|7|8|9)/g, function (x) { return obj[x]; });\n}\n//name: asoGapmersBioSpringToGcrs\n//input: string nucleotides {semType: BioSpring / Gapmers}\n//output: string result {semType: GCRS / Gapmers}\nexport function asoGapmersBioSpringToGcrs(nucleotides) {\n    let count = -1;\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '5*': 'moeUnps', '6*': 'moeAnps', '7*': 'moe5mCnps', '8*': 'moeGnps', '9*': '5mCps', 'A*': 'Aps', 'T*': 'Tps',\n        'G*': 'Gps', 'C*': 'Cps', '5': 'moeU', '6': 'moeA', '7': 'moe5mC', '8': 'moeG',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|5\\*|6\\*|7\\*|8\\*|9\\*|A\\*|T\\*|G\\*|C\\*|5|6|7|8)/g, function (x) {\n        count++;\n        return (count == 4) ? obj[x].slice(0, -3) + 'ps' : (count == 14) ? obj[x].slice(0, -2) + 'nps' : obj[x];\n    });\n}\n//name: asoGapmersGcrsToBioSpring\n//input: string nucleotides {semType: GCRS / Gapmers}\n//output: string result {semType: BioSpring / Gapmers}\nexport function asoGapmersGcrsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'moeT': '5', 'moeA': '6', 'moe5mC': '7', 'moeG': '8', 'moeU': '5', '5mC': '9', 'nps': '*', 'ps': '*', 'U': 'T',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|moeT|moeA|moe5mC|moeG|moeU|5mC|nps|ps|U)/g, function (x) { return obj[x]; });\n}\n//name: asoGapmersGcrsToNucleotides\n//input: string nucleotides {semType: GCRS / Gapmers}\n//output: string result {semType: DNA nucleotides}\nexport function asoGapmersGcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'moe': '', '5m': '', 'n': '', 'ps': '', 'U': 'T' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|moe|5m|n|ps|U)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToNucleotides\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaBioSpringToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'U', '2': 'A', '3': 'C', '4': 'G', '5': 'U', '6': 'A', '7': 'C', '8': 'G', '*': '' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToAxolabs\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: Axolabs / siRNA}\nexport function siRnaBioSpringToAxolabs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'Uf', '2': 'Af', '3': 'Cf', '4': 'Gf', '5': 'u', '6': 'a', '7': 'c', '8': 'g', '*': 's' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToGcrs\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: GCRS}\nexport function siRnaBioSpringToGcrs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'fU', '2': 'fA', '3': 'fC', '4': 'fG', '5': 'mU', '6': 'mA', '7': 'mC', '8': 'mG', '*': 'ps' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToGcrs\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: GCRS}\nexport function siRnaAxolabsToGcrs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': 'fU', 'Af': 'fA', 'Cf': 'fC', 'Gf': 'fG', 'u': 'mU', 'a': 'mA', 'c': 'mC', 'g': 'mG', 's': 'ps',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToBioSpring\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaAxolabsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': '1', 'Af': '2', 'Cf': '3', 'Gf': '4', 'u': '5', 'a': '6', 'c': '7', 'g': '8', 's': '*',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToNucleotides\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaAxolabsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': 'U', 'Af': 'A', 'Cf': 'C', 'Gf': 'G', 'u': 'U', 'a': 'A', 'c': 'C', 'g': 'G', 's': '',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToNucleotides\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaGcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G', 'ps': '',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToBioSpring\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaGcrsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': '1', 'fA': '2', 'fC': '3', 'fG': '4', 'mU': '5', 'mA': '6', 'mC': '7', 'mG': '8', 'ps': '*',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToAxolabs\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: Axolabs / siRNA}\nexport function siRnaGcrsToAxolabs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': 'Uf', 'fA': 'Af', 'fC': 'Cf', 'fG': 'Gf', 'mU': 'u', 'mA': 'a', 'mC': 'c', 'mG': 'g', 'ps': 's',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaNucleotideToBioSpringSenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaNucleotideToBioSpringSenseStrand(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '6*', 'U': '5*', 'G': '8*', 'C': '7*' };\n    const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '*6', 'U': '*5', 'G': '*8', 'C': '*7' };\n    const objForOddIndices = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '6', 'U': '5', 'G': '8', 'C': '7' };\n    const objForEvenIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': '2', 'U': '1', 'G': '4', 'C': '3' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count > nucleotides.length - 3)\n            return objForRightEdge[x];\n        return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];\n    });\n}\n//name: siRnaNucleotidesToGcrs\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: GCRS}\nexport function siRnaNucleotidesToGcrs(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'mAps', 'U': 'mUps', 'G': 'mGps', 'C': 'mCps' };\n    const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'psmA', 'U': 'psmU', 'G': 'psmG', 'C': 'psmC' };\n    const objForEvenIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'fA', 'U': 'fU', 'G': 'fG', 'C': 'fC' };\n    const objForOddIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'mA', 'U': 'mU', 'G': 'mG', 'C': 'mC' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count > nucleotides.length - 3)\n            return objForRightEdge[x];\n        return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];\n    });\n}\n//name: siRnaNucleotideToAxolabsSenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: Axolabs}\nexport function siRnaNucleotideToAxolabsSenseStrand(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };\n    const objForSomeIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count == 6 || (count > 7 && count < 11))\n            return objForSomeIndices[x];\n        if (count == nucleotides.length - 1)\n            return 'a';\n        return obj[x];\n    });\n}\n//name: siRnaNucleotideToAxolabsAntisenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: Axolabs}\nexport function siRnaNucleotideToAxolabsAntisenseStrand(nucleotides) {\n    let count = -1;\n    const objForSmallLinkages = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };\n    const objForBigLinkages = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Afs', 'U': 'Ufs', 'G': 'Gfs', 'C': 'Cfs' };\n    const objForSomeIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };\n    const obj = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count > 19 && count < 22)\n            return objForSmallLinkages[x];\n        if (count == 0)\n            return 'us';\n        if (count == 1)\n            return objForBigLinkages[x];\n        return (count == 5 || count == 7 || count == 8 || count == 13 || count == 15) ? objForSomeIndices[x] : obj[x];\n    });\n}\n//name: gcrsToNucleotides\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: RNA nucleotides}\nexport function gcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'mAps': 'A', 'mUps': 'U', 'mGps': 'G', 'mCps': 'C', 'fAps': 'A', 'fUps': 'U', 'fGps': 'G', 'fCps': 'C',\n        'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });\n}\n//name: gcrsToMermade12\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: Mermade 12 / siRNA}\nexport function gcrsToMermade12(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'mAps': 'e', 'mUps': 'h', 'mGps': 'g', 'mCps': 'f', 'fAps': 'i', 'fUps': 'l', 'fGps': 'k', 'fCps': 'j', 'fU': 'L',\n        'fA': 'I', 'fC': 'J', 'fG': 'K', 'mU': 'H', 'mA': 'E', 'mC': 'F', 'mG': 'G',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });\n}\n","import { map, stadardPhosphateLinkSmiles, SYNTHESIZERS, TECHNOLOGIES, MODIFICATIONS } from './map';\nimport { isValidSequence } from './sequence-codes-tools';\nimport { getNucleotidesMol } from './mol-transformations';\nexport function sequenceToMolV3000(sequence, inverted = false, oclRender = false, 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);\n    while (i < sequence.length) {\n        const code = codes.find((s) => s == sequence.slice(i, i + s.length));\n        i += code.length;\n        inverted ? codesList.unshift(code) : codesList.push(code);\n    }\n    for (let i = 0; i < codesList.length; i++) {\n        if (dropdowns.includes(codesList[i])) {\n            smilesCodes.push((i >= codesList.length / 2) ?\n                MODIFICATIONS[codesList[i]].right : MODIFICATIONS[codesList[i]].left);\n            smilesCodes.push(stadardPhosphateLinkSmiles);\n        }\n        else {\n            if (links.includes(codesList[i]) ||\n                includesStandardLinkAlready.includes(codesList[i]) ||\n                (i < codesList.length - 1 && links.includes(codesList[i + 1])))\n                smilesCodes.push(obj[codesList[i]]);\n            else {\n                smilesCodes.push(obj[codesList[i]]);\n                smilesCodes.push(stadardPhosphateLinkSmiles);\n            }\n        }\n    }\n    return getNucleotidesMol(smilesCodes, oclRender);\n}\nexport function sequenceToSmiles(sequence, inverted = false, 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);\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    // 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","export const SYNTHESIZERS = {\n    RAW_NUCLEOTIDES: 'Raw Nucleotides',\n    BIOSPRING: 'BioSpring Codes',\n    GCRS: 'Janssen GCRS Codes',\n    AXOLABS: 'Axolabs Codes',\n    MERMADE_12: 'Mermade 12',\n};\nexport const TECHNOLOGIES = {\n    DNA: 'DNA',\n    RNA: 'RNA',\n    ASO_GAPMERS: 'For ASO Gapmers',\n    SI_RNA: 'For 2\\'-OMe and 2\\'-F modified siRNA',\n};\nexport const COL_NAMES = {\n    CHEMISTRY: 'Chemistry',\n    NUMBER: 'Number',\n    TYPE: 'Type',\n    CHEMISTRY_NAME: 'Chemistry Name',\n    INTERNAL_COMPOUND_ID: 'Internal compound ID',\n    IDP: 'IDP',\n    SEQUENCE: 'Sequence',\n    COMPOUND_NAME: 'Compound Name',\n    COMPOUND_COMMENTS: 'Compound Comments',\n    SALT: 'Salt',\n    EQUIVALENTS: 'Equivalents',\n    PURITY: 'Purity',\n    CPD_MW: 'Cpd MW',\n    SALT_MASS: 'Salt mass',\n    BATCH_MW: 'Batch MW',\n    SOURCE: 'Source',\n    ICD: 'ICD',\n    OWNER: 'Owner',\n};\n// interface CODES {\n// }\nexport const MODIFICATIONS = {\n    '(invabasic)': {\n        molecularWeight: 118.13,\n        left: 'O[C@@H]1C[C@@H]O[C@H]1CO',\n        right: 'O[C@@H]1C[C@@H]O[C@H]1CO',\n    },\n    '(GalNAc-2-JNJ)': {\n        molecularWeight: 1273.3,\n        left: 'C(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)NC(=O)CCCC(=O)NCC(O)CO',\n        right: 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)',\n    },\n};\nexport const stadardPhosphateLinkSmiles = 'OP(=O)(O)O';\nexport const map = {\n    'Raw Nucleotides': {\n        'DNA': {\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n        },\n        'RNA': {\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'U': {\n                'name': 'Uracil',\n                'weight': 306.17,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n        },\n    },\n    'BioSpring Codes': {\n        'For ASO Gapmers': {\n            '5': {\n                'name': '2\\'MOE-5Me-rU',\n                'weight': 378.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '6': {\n                'name': '2\\'MOE-rA',\n                'weight': 387.29,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '7': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '8': {\n                'name': '2\\'MOE-rG',\n                'weight': 403.28,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '9': {\n                'name': '5-Methyl-dC',\n                'weight': 303.21,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            '*': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n        },\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            '1': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            '2': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            '3': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            '4': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            '5': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            '6': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            '7': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            '8': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            '*': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n        },\n    },\n    'Axolabs Codes': {\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'Uf': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'Af': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'Cf': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'Gf': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'u': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'a': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'c': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'g': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            's': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n        },\n    },\n    'Janssen GCRS Codes': {\n        'For ASO Gapmers': {\n            'moeT': {\n                'name': '2\\'MOE-5Me-rU',\n                'weight': 378.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            'moeA': {\n                'name': '2\\'MOE-rA',\n                'weight': 387.29,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            'moe5mC': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '(5m)moeC': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            'moeG': {\n                'name': '2\\'MOE-rG',\n                'weight': 403.28,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '5mC': {\n                'name': '5-Methyl-dC',\n                'weight': 303.28,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            '(5m)C': {\n                'name': '5-Methyl-dC',\n                'weight': 303.28,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            'ps': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'dA': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'dC': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'dG': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'dT': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'rA': {\n                'name': 'Adenine',\n                'weight': 329.21,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](O)[C@@H]1O',\n            },\n            'rC': {\n                'name': 'Cytosine',\n                'weight': 305.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](O)[C@@H]1O',\n            },\n            'rG': {\n                'name': 'Guanine',\n                'weight': 345.21,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](O)[C@@H]1O',\n            },\n            'rU': {\n                'name': 'Uracil',\n                'weight': 306.17,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',\n            },\n        },\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'fU': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'fA': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'fC': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'fG': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'mU': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'mA': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'mC': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'mG': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n        },\n    },\n    'Mermade 12': {\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'e': {\n                'name': '2\\'OMe-rA-ps',\n                'weight': 359.31,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'h': {\n                'name': '2\\'OMe-rU-ps',\n                'weight': 336.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'g': {\n                'name': '2\\'OMe-rG-ps',\n                'weight': 375.31,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'f': {\n                'name': '2\\'OMe-rC-ps',\n                'weight': 335.28,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'i': {\n                'name': '2\\'-fluoro-A-ps',\n                'weight': 347.27,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'l': {\n                'name': '2\\'-fluoro-U-ps',\n                'weight': 324.23,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'k': {\n                'name': '2\\'-fluoro-G-ps',\n                'weight': 363.26,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'j': {\n                'name': '2\\'-fluoro-C-ps',\n                'weight': 323.25,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'L': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'I': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'J': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'K': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'H': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'E': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'F': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'G': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n        },\n    },\n};\n","import * as OCL from 'openchemlib/full.js';\nconst PHOSHATE = `\nDatagrok monomer library Nucleotides\n\n  0  0  0  0  0  0              0 V3000\nM  V30 BEGIN CTAB\nM  V30 COUNTS 5 4 0 0 0\nM  V30 BEGIN ATOM\nM  V30 1 O -1.5 0 0 0\nM  V30 2 P 0 0 0 0\nM  V30 3 O 0 1 0 0\nM  V30 4 O 0 -1 0 0\nM  V30 5 O 1.5 0 0 0\nM  V30 END ATOM\nM  V30 BEGIN BOND\nM  V30 1 1 1 2\nM  V30 2 2 2 3\nM  V30 3 1 2 4\nM  V30 4 1 2 5\nM  V30 END BOND\nM  V30 END CTAB\nM  V30 BEGIN COLLECTION\nM  V30 END COLLECTION\nM  END`;\nconst THIOPHOSHATE = `\nDatagrok monomer library Nucleotides\n\n  0  0  0  0  0  0              0 V3000\nM  V30 BEGIN CTAB\nM  V30 COUNTS 5 4 0 0 0\nM  V30 BEGIN ATOM\nM  V30 1 O -1.5 0 0 0\nM  V30 2 P 0 0 0 0\nM  V30 3 O 0 1 0 0\nM  V30 4 S 0 -1 0 0\nM  V30 5 O 1.5 0 0 0\nM  V30 END ATOM\nM  V30 BEGIN BOND\nM  V30 1 1 1 2\nM  V30 2 2 2 3\nM  V30 3 1 2 4\nM  V30 4 1 2 5\nM  V30 END BOND\nM  V30 END CTAB\nM  V30 BEGIN COLLECTION\nM  V30 END COLLECTION\nM  END`;\nconst INVABASIC = `\nDatagrok monomer library Nucleotides\n\n  0  0  0  0  0  0              0 V3000\nM  V30 BEGIN CTAB\nM  V30 COUNTS 8 8 0 0 0\nM  V30 BEGIN ATOM\nM  V30 1 O 1.0934 -2.1636 0 0\nM  V30 2 C 1.8365 -1.4945 0 0 CFG=2\nM  V30 3 C 2.8147 -1.7024 0 0\nM  V30 4 C 3.3147 -0.8364 0 0 VAL=3\nM  V30 5 O 2.6455 -0.0932 0 0\nM  V30 6 C 1.732 -0.5 0 0 CFG=1\nM  V30 7 C 0.866 0 0 0\nM  V30 8 O 0.866 1 0 0\nM  V30 END ATOM\nM  V30 BEGIN BOND\nM  V30 1 1 2 1 CFG=1\nM  V30 2 1 2 3\nM  V30 3 1 3 4\nM  V30 4 1 4 5\nM  V30 5 1 6 5\nM  V30 6 1 2 6\nM  V30 7 1 6 7 CFG=3\nM  V30 8 1 7 8\nM  V30 END BOND\nM  V30 BEGIN COLLECTION\nM  V30 MDLV30/STEABS ATOMS=(2 2 6)\nM  V30 END COLLECTION\nM  V30 END CTAB\nM  END`;\nexport function getNucleotidesMol(smilesCodes, oclRender = false) {\n    const molBlocks = [];\n    for (let i = 0; i < smilesCodes.length - 1; i++) {\n        smilesCodes[i] == 'OP(=O)(O)O' ? molBlocks.push(PHOSHATE) :\n            smilesCodes[i] == 'OP(=O)(S)O' ? molBlocks.push(THIOPHOSHATE) :\n                smilesCodes[i] == 'O[C@@H]1C[C@@H]O[C@H]1CO' ? molBlocks.push(rotateNucleotidesV3000(INVABASIC)) :\n                    molBlocks.push(rotateNucleotidesV3000(smilesCodes[i]));\n    }\n    return linkV3000(molBlocks, false, oclRender);\n}\nexport function linkV3000(molBlocks, twoChains = false, oclRender = false) {\n    let macroMolBlock = '\\nDatagrok macromolecule handler\\n\\n';\n    macroMolBlock += '  0  0  0  0  0  0            999 V3000\\n';\n    macroMolBlock += 'M  V30 BEGIN CTAB\\n';\n    let atomBlock = '';\n    let bondBlock = '';\n    let collectionBlock = '';\n    const collection = [];\n    let natom = 0;\n    let nbond = 0;\n    let 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    }\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    macroMolBlock += 'M  V30 BEGIN COLLECTION\\n';\n    macroMolBlock += collectionBlock;\n    macroMolBlock += 'M  V30 END COLLECTION\\n';\n    macroMolBlock += 'M  V30 END CTAB\\n';\n    macroMolBlock += 'M  END\\n';\n    return macroMolBlock;\n}\nfunction rotateNucleotidesV3000(molecule) {\n    let molBlock = molecule.includes('M  END') ? molecule : OCL.Molecule.fromSmiles(molecule).toMolfileV3();\n    const coordinates = extractAtomDataV3000(molBlock);\n    const natom = coordinates.atomIndex.length;\n    const indexFivePrime = coordinates.atomIndex.indexOf(1);\n    const indexThreePrime = coordinates.atomIndex.indexOf(natom);\n    //fix 5 prime if inadequate\n    if (natom > 8)\n        fix5Prime(coordinates, indexFivePrime, indexThreePrime);\n    const xCenter = (coordinates.x[indexThreePrime] + coordinates.x[indexFivePrime]) / 2;\n    const yCenter = (coordinates.y[indexThreePrime] + coordinates.y[indexFivePrime]) / 2;\n    //place to center\n    for (let i = 0; i < natom; i++) {\n        coordinates.x[i] -= xCenter;\n        coordinates.y[i] -= yCenter;\n    }\n    let angle = 0;\n    if (coordinates.x[indexFivePrime] == 0)\n        angle = coordinates.y[indexFivePrime] > coordinates.y[indexThreePrime] ? Math.PI / 2 : 3 * Math.PI / 2;\n    else if (coordinates.y[indexFivePrime] == 0)\n        angle = coordinates.x[indexFivePrime] > coordinates.x[indexThreePrime] ? Math.PI : 0;\n    else {\n        const derivative = coordinates.y[indexFivePrime] / coordinates.x[indexFivePrime];\n        angle = derivative > 0 ? Math.PI - Math.atan(derivative) : Math.atan(derivative);\n    }\n    const cos = Math.cos(angle);\n    const sin = Math.sin(angle);\n    for (let i = 0; i < natom; i++) {\n        const xAdd = coordinates.x[i];\n        coordinates.x[i] = xAdd * cos - coordinates.y[i] * sin;\n        coordinates.y[i] = xAdd * sin + coordinates.y[i] * cos;\n    }\n    //place to right\n    const xShift = coordinates.x[indexFivePrime];\n    for (let i = 0; i < natom; i++)\n        coordinates.x[i] -= xShift;\n    //rewrite molBlock\n    let index = molBlock.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n    index = molBlock.indexOf('\\n', index);\n    let indexEnd = index;\n    for (let i = 0; i < natom; i++) {\n        index = molBlock.indexOf('V30', index) + 4;\n        index = molBlock.indexOf(' ', index) + 1;\n        index = molBlock.indexOf(' ', index) + 1;\n        indexEnd = molBlock.indexOf(' ', index) + 1;\n        indexEnd = molBlock.indexOf(' ', indexEnd);\n        molBlock = molBlock.slice(0, index) +\n            coordinates.x[i] + ' ' + coordinates.y[i] +\n            molBlock.slice(indexEnd);\n        index = molBlock.indexOf('\\n', index) + 1;\n    }\n    return molBlock;\n}\nfunction invertNucleotidesV3000(molecule) {\n    let molBlock = molecule.includes('M  END') ? molecule : OCL.Molecule.fromSmiles(molecule).toMolfileV3();\n    const coordinates = extractAtomDataV3000(molBlock);\n    const natom = coordinates.atomIndex.length;\n    const xCenter = (Math.max(...coordinates.x) + Math.min(...coordinates.x)) / 2;\n    const yCenter = (Math.max(...coordinates.y) + Math.min(...coordinates.y)) / 2;\n    //place to center\n    for (let i = 0; i < natom; i++) {\n        coordinates.x[i] -= xCenter;\n        coordinates.y[i] -= yCenter;\n    }\n    const angle = Math.PI;\n    const cos = Math.cos(angle);\n    const sin = Math.sin(angle);\n    for (let i = 0; i < natom; i++) {\n        const xAdd = coordinates.x[i];\n        coordinates.x[i] = xAdd * cos - coordinates.y[i] * sin;\n        coordinates.y[i] = xAdd * sin + coordinates.y[i] * cos;\n    }\n    //place back\n    const yShift = Math.max(...coordinates.y);\n    for (let i = 0; i < natom; i++) {\n        coordinates.x[i] += xCenter;\n        coordinates.y[i] -= yShift;\n    }\n    //rewrite molBlock\n    let index = molBlock.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n    index = molBlock.indexOf('\\n', index);\n    let indexEnd = index;\n    for (let i = 0; i < natom; i++) {\n        index = molBlock.indexOf('V30', index) + 4;\n        index = molBlock.indexOf(' ', index) + 1;\n        index = molBlock.indexOf(' ', index) + 1;\n        indexEnd = molBlock.indexOf(' ', index) + 1;\n        indexEnd = molBlock.indexOf(' ', indexEnd);\n        molBlock = molBlock.slice(0, index) +\n            coordinates.x[i] + ' ' + coordinates.y[i] +\n            molBlock.slice(indexEnd);\n        index = molBlock.indexOf('\\n', index) + 1;\n    }\n    return molBlock;\n}\nfunction fix5Prime(coordinates, indexFivePrime, indexThreePrime) {\n    const indexFivePrimeNeighbour = indexFivePrime + 1;\n    const xShift = coordinates.x[indexFivePrimeNeighbour];\n    const yShift = coordinates.y[indexFivePrimeNeighbour];\n    const base3PrimeX = coordinates.x[indexThreePrime] - xShift;\n    const base3PrimeY = coordinates.y[indexThreePrime] - yShift;\n    const base5PrimeX = coordinates.x[indexFivePrime] - xShift;\n    const base5PrimeY = coordinates.y[indexFivePrime] - yShift;\n    const rotated5PrimeX = base5PrimeX * Math.cos(Math.PI * 2 / 3) - base5PrimeY * Math.sin(Math.PI * 2 / 3);\n    const rotated5PrimeY = base5PrimeX * Math.sin(Math.PI * 2 / 3) + base5PrimeY * Math.cos(Math.PI * 2 / 3);\n    const dx = base5PrimeX - base3PrimeX;\n    const dy = base5PrimeY - base3PrimeY;\n    const dxRotated = rotated5PrimeX - base3PrimeX;\n    const dyRotated = rotated5PrimeY - base3PrimeY;\n    if (Math.sqrt(dyRotated * dyRotated + dxRotated * dxRotated) >= Math.sqrt(dy * dy + dx * dx)) {\n        coordinates.x[indexFivePrime] = rotated5PrimeX + xShift;\n        coordinates.y[indexFivePrime] = rotated5PrimeY + yShift;\n    }\n}\nfunction extractAtomsBondsNumbersV3000(molBlock) {\n    molBlock = molBlock.replaceAll('\\r', ''); //equalize old and new sdf standards\n    let index = molBlock.indexOf('COUNTS') + 7; // V3000 index for atoms and bonds number\n    let indexEnd = molBlock.indexOf(' ', index);\n    const atomsNumber = parseInt(molBlock.substring(index, indexEnd));\n    index = indexEnd + 1;\n    indexEnd = molBlock.indexOf(' ', index);\n    const bondsNumber = parseInt(molBlock.substring(index, indexEnd));\n    return { natom: atomsNumber, nbond: bondsNumber };\n}\nfunction extractAtomDataV3000(molBlock) {\n    const numbers = extractAtomsBondsNumbersV3000(molBlock);\n    let index = molBlock.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n    index = molBlock.indexOf('\\n', index);\n    let indexEnd = index;\n    const indexes = Array(numbers.natom);\n    const types = Array(numbers.natom);\n    const x = Array(numbers.natom);\n    const y = Array(numbers.natom);\n    for (let i = 0; i < numbers.natom; i++) {\n        index = molBlock.indexOf('V30', index) + 4;\n        indexEnd = molBlock.indexOf(' ', index);\n        indexes[i] = parseInt(molBlock.substring(index, indexEnd));\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        types[i] = molBlock.substring(index, indexEnd);\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        x[i] = parseFloat(molBlock.substring(index, indexEnd));\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        y[i] = parseFloat(molBlock.substring(index, indexEnd));\n        index = molBlock.indexOf('\\n', index) + 1;\n    }\n    return { atomIndex: indexes, atomType: types, x: x, y: y };\n}\n","import * as ui from 'datagrok-api/ui';\nimport { sequenceToMolV3000 } from '../structures-works/from-monomers';\nimport { linkV3000 } from '../structures-works/mol-transformations';\nimport { getFormat } from '../structures-works/sequence-codes-tools';\nexport function saveSdf(as, ss, oneEntity, fit3dx) {\n    const formatAs = getFormat(as);\n    const formatSs = getFormat(ss);\n    const molSS = sequenceToMolV3000(ss, false, false, formatSs);\n    const molAS = sequenceToMolV3000(as, true, false, formatAs);\n    let result;\n    if (oneEntity)\n        result = linkV3000([molSS, molAS], true, !fit3dx) + '\\n\\n$$$$\\n';\n    else {\n        result =\n            molSS + '\\n' +\n                `>  <Sequence>\\nSense Strand\\n\\n$$$$\\n` +\n                molAS + '\\n' +\n                `>  <Sequence>\\nAnti Sense\\n\\n$$$$\\n`;\n    }\n    const element = document.createElement('a');\n    element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(result));\n    element.setAttribute('download', ss.replace(/\\s/g, '') + '.sdf');\n    element.click();\n}\nexport function saveSenseAntiSense() {\n    const moleculeSvgDiv = ui.block([]);\n    const ssInput = ui.textInput('Sense Strand 5\\' ->3\\'', '');\n    const asInput = ui.textInput('Anti Sense 3\\' ->5\\'', '');\n    const saveOption = ui.switchInput('Save as one entity', true);\n    const save3dx = ui.switchInput('Save 3dx', true);\n    const saveBtn = ui.button('Save SDF', () => saveSdf(asInput.value, ssInput.value, saveOption.value, save3dx.value));\n    const saveSection = ui.panel([\n        ui.div([\n            ui.div([\n                ui.divH([ui.h1('Inputs')]),\n                ui.divV([\n                    ui.div([ssInput.root]),\n                    ui.div([asInput.root]),\n                    saveOption,\n                    save3dx,\n                    ui.buttonsInput([saveBtn]),\n                ], 'ui-form'),\n            ], 'ui-form'),\n        ], 'ui-form'),\n        moleculeSvgDiv,\n    ]);\n    return saveSection;\n}\n","// import * as grok from 'datagrok-api/grok';\n// import * as ui from 'datagrok-api/ui';\n// import * as DG from 'datagrok-api/dg';\nimport { map, SYNTHESIZERS, TECHNOLOGIES, MODIFICATIONS } from './map';\nimport { asoGapmersNucleotidesToBioSpring, asoGapmersNucleotidesToGcrs, asoGapmersBioSpringToNucleotides, asoGapmersBioSpringToGcrs, asoGapmersGcrsToNucleotides, asoGapmersGcrsToBioSpring, gcrsToMermade12, siRnaNucleotideToBioSpringSenseStrand, siRnaNucleotideToAxolabsSenseStrand, siRnaNucleotidesToGcrs, siRnaBioSpringToNucleotides, siRnaBioSpringToAxolabs, siRnaBioSpringToGcrs, siRnaAxolabsToNucleotides, siRnaAxolabsToBioSpring, siRnaAxolabsToGcrs, siRnaGcrsToNucleotides, siRnaGcrsToBioSpring, siRnaGcrsToAxolabs, gcrsToNucleotides } from './converters';\nconst noTranslationTableAvailable = 'No translation table available';\nexport const undefinedInputSequence = 'Type of input sequence is undefined';\nexport function 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}\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 = 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: null, technology: null };\n    outputIndex = 0;\n    possibleTechnologies.forEach((technology) => {\n        const codes = Object.keys(map[possibleSynthesizers[0]][technology]);\n        while (outputIndex < sequence.length) {\n            const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));\n            if (matchedCode == null)\n                break;\n            if ( // for mistake pattern 'rAA'\n            outputIndex > 1 &&\n                nucleotides.includes(sequence[outputIndex]) &&\n                firstUniqueCharacters.includes(sequence[outputIndex - 2]))\n                break;\n            if ( // for mistake pattern 'ArA'\n            firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&\n                nucleotides.includes(sequence[outputIndex])) {\n                outputIndex++;\n                break;\n            }\n            outputIndex += matchedCode.length;\n        }\n    });\n    return {\n        indexOfFirstNotValidChar: indexOfFirstNotValidChar,\n        synthesizer: possibleSynthesizers,\n        technology: [possibleTechnologies[outputIndex]],\n    };\n}\nfunction getAllCodesOfSynthesizer(synthesizer) {\n    let codes = [];\n    for (const technology of Object.keys(map[synthesizer]))\n        codes = codes.concat(Object.keys(map[synthesizer][technology]));\n    return codes.concat(Object.keys(MODIFICATIONS));\n}\nfunction getListOfPossibleSynthesizersByFirstMatchedCode(sequence) {\n    const synthesizers = [];\n    Object.keys(map).forEach((synthesizer) => {\n        const codes = getAllCodesOfSynthesizer(synthesizer);\n        //TODO: get first non-dropdown code when there are two modifications\n        let start = 0;\n        for (let i = 0; i < sequence.length; i++) {\n            if (sequence[i] == ')' && i != sequence.length - 1) {\n                start = i + 1;\n                break;\n            }\n        }\n        if (codes.some((s) => s == sequence.slice(start, start + s.length)))\n            synthesizers.push(synthesizer);\n    });\n    return synthesizers;\n}\nfunction getListOfPossibleTechnologiesByFirstMatchedCode(sequence, synthesizer) {\n    const technologies = [];\n    Object.keys(map[synthesizer]).forEach((technology) => {\n        const codes = Object.keys(map[synthesizer][technology]).concat(Object.keys(MODIFICATIONS));\n        if (codes.some((s) => s == sequence.slice(0, s.length)))\n            technologies.push(technology);\n    });\n    return technologies;\n}\nexport function convertSequence(sequence, output) {\n    if (output.indexOfFirstNotValidChar != -1) {\n        return {\n            // type: '',\n            indexOfFirstNotValidChar: JSON.stringify(output),\n            Error: undefinedInputSequence,\n        };\n    }\n    if (output.synthesizer.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        };\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        };\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        };\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","export const USERS_CSV = `DISPLAY\nNO DATA\n`;\n","module.exports = DG;","module.exports = OCL;","module.exports = grok;","module.exports = ui;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\n/* Do not change these import lines. Datagrok will import API library in exactly the same manner */\nimport * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\nimport * as OCL from 'openchemlib/full.js';\nimport $ from 'cash-dom';\nimport { defineAxolabsPattern } from './defineAxolabsPattern';\nimport { saveSenseAntiSense } from './structures-works/save-sense-antisense';\nimport { sequenceToSmiles, sequenceToMolV3000 } from './structures-works/from-monomers';\nimport { convertSequence, undefinedInputSequence, isValidSequence, getFormat } from './structures-works/sequence-codes-tools';\nimport { map, COL_NAMES, MODIFICATIONS } from './structures-works/map';\nimport { SALTS_CSV } from './salts';\nimport { USERS_CSV } from './users';\nimport { ICDS } from './ICDs';\nimport { SOURCES } from './sources';\nimport { IDPS } from './IDPs';\nexport const _package = new DG.Package();\nconst defaultInput = 'fAmCmGmAmCpsmU';\nconst sequenceWasCopied = 'Copied';\nconst tooltipSequence = 'Copy sequence';\n//name: Sequence Translator\n//tags: app\nexport function sequenceTranslator() {\n    const windows = grok.shell.windows;\n    windows.showProperties = false;\n    windows.showToolbox = false;\n    windows.showHelp = false;\n    function updateTableAndMolecule(sequence, inputFormat, isSet) {\n        moleculeSvgDiv.innerHTML = '';\n        outputTableDiv.innerHTML = '';\n        const pi = DG.TaskBarProgressIndicator.create('Rendering table and molecule...');\n        let errorsExist = false;\n        try {\n            sequence = sequence.replace(/\\s/g, '');\n            const output = isValidSequence(sequence, null);\n            if (isSet)\n                output.synthesizer = [inputFormat];\n            inputFormatChoiceInput.value = output.synthesizer[0];\n            const outputSequenceObj = convertSequence(sequence, output);\n            const tableRows = [];\n            for (const key of Object.keys(outputSequenceObj).slice(1)) {\n                const indexOfFirstNotValidChar = ('indexOfFirstNotValidChar' in outputSequenceObj) ?\n                    JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).indexOfFirstNotValidChar :\n                    -1;\n                if ('indexOfFirstNotValidChar' in outputSequenceObj) {\n                    const indexOfFirstNotValidChar = ('indexOfFirstNotValidChar' in outputSequenceObj) ?\n                        JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).indexOfFirstNotValidChar :\n                        -1;\n                    if (indexOfFirstNotValidChar != -1)\n                        errorsExist = true;\n                }\n                tableRows.push({\n                    'key': key,\n                    'value': ('indexOfFirstNotValidChar' in outputSequenceObj) ?\n                        ui.divH([\n                            ui.divText(sequence.slice(0, indexOfFirstNotValidChar), { style: { color: 'grey' } }),\n                            ui.tooltip.bind(ui.divText(sequence.slice(indexOfFirstNotValidChar), { style: { color: 'red' } }), 'Expected format: ' + JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).synthesizer +\n                                '. See tables with valid codes on the right'),\n                        ]) : //@ts-ignore\n                        ui.link(outputSequenceObj[key], () => navigator.clipboard.writeText(outputSequenceObj[key])\n                            .then(() => grok.shell.info(sequenceWasCopied)), tooltipSequence, ''),\n                });\n            }\n            if (errorsExist) {\n                const synthesizer = JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).synthesizer.slice(0, -6);\n                asoGapmersGrid.onCellPrepare(function (gc) {\n                    gc.style.backColor = (gc.gridColumn.name == synthesizer) ? 0xFFF00000 : 0xFFFFFFFF;\n                });\n                omeAndFluoroGrid.onCellPrepare(function (gc) {\n                    gc.style.backColor = (gc.gridColumn.name == synthesizer) ? 0xFFF00000 : 0xFFFFFFFF;\n                });\n                switchInput.enabled = true;\n            }\n            else {\n                asoGapmersGrid.onCellPrepare(function (gc) { gc.style.backColor = 0xFFFFFFFF; });\n                omeAndFluoroGrid.onCellPrepare(function (gc) { gc.style.backColor = 0xFFFFFFFF; });\n            }\n            outputTableDiv.append(ui.div([\n                DG.HtmlTable.create(tableRows, (item) => [item.key, item.value], ['Code', 'Sequence']).root,\n            ]));\n            if (outputSequenceObj.type != undefinedInputSequence && outputSequenceObj.Error != undefinedInputSequence) {\n                const canvas = ui.canvas(300, 170);\n                canvas.addEventListener('click', () => {\n                    const canv = ui.canvas($(window).width(), $(window).height());\n                    const mol = sequenceToMolV3000(inputSequenceField.value.replace(/\\s/g, ''), false, true, output.synthesizer[0]);\n                    // @ts-ignore\n                    OCL.StructureView.drawMolecule(canv, OCL.Molecule.fromMolfile(mol), { suppressChiralText: true });\n                    ui.dialog('Molecule: ' + inputSequenceField.value)\n                        .add(canv)\n                        .showModal(true);\n                });\n                $(canvas).on('mouseover', () => $(canvas).css('cursor', 'zoom-in'));\n                $(canvas).on('mouseout', () => $(canvas).css('cursor', 'default'));\n                const mol = sequenceToMolV3000(inputSequenceField.value.replace(/\\s/g, ''), false, true, output.synthesizer[0]);\n                // @ts-ignore\n                OCL.StructureView.drawMolecule(canvas, OCL.Molecule.fromMolfile(mol), { suppressChiralText: true });\n                moleculeSvgDiv.append(canvas);\n            }\n            else\n                moleculeSvgDiv.innerHTML = '';\n        }\n        finally {\n            pi.close();\n        }\n    }\n    const inputFormatChoiceInput = ui.choiceInput('Input format: ', 'Janssen GCRS Codes', Object.keys(map), (format) => {\n        updateTableAndMolecule(inputSequenceField.value.replace(/\\s/g, ''), format, true);\n    });\n    const moleculeSvgDiv = ui.block([]);\n    const outputTableDiv = ui.div([]);\n    const inputSequenceField = ui.textInput('', defaultInput, (sequence) => updateTableAndMolecule(sequence, inputFormatChoiceInput.value, false));\n    const asoDf = DG.DataFrame.fromObjects([\n        { 'Name': '2\\'MOE-5Me-rU', 'BioSpring': '5', 'Janssen GCRS': 'moeT' },\n        { 'Name': '2\\'MOE-rA', 'BioSpring': '6', 'Janssen GCRS': 'moeA' },\n        { 'Name': '2\\'MOE-5Me-rC', 'BioSpring': '7', 'Janssen GCRS': 'moe5mC' },\n        { 'Name': '2\\'MOE-rG', 'BioSpring': '8', 'Janssen GCRS': 'moeG' },\n        { 'Name': '5-Methyl-dC', 'BioSpring': '9', 'Janssen GCRS': '5mC' },\n        { 'Name': 'ps linkage', 'BioSpring': '*', 'Janssen GCRS': 'ps' },\n        { 'Name': 'dA', 'BioSpring': 'A', 'Janssen GCRS': 'A, dA' },\n        { 'Name': 'dC', 'BioSpring': 'C', 'Janssen GCRS': 'C, dC' },\n        { 'Name': 'dG', 'BioSpring': 'G', 'Janssen GCRS': 'G, dG' },\n        { 'Name': 'dT', 'BioSpring': 'T', 'Janssen GCRS': 'T, dT' },\n        { 'Name': 'rA', 'BioSpring': '', 'Janssen GCRS': 'rA' },\n        { 'Name': 'rC', 'BioSpring': '', 'Janssen GCRS': 'rC' },\n        { 'Name': 'rG', 'BioSpring': '', 'Janssen GCRS': 'rG' },\n        { 'Name': 'rU', 'BioSpring': '', 'Janssen GCRS': 'rU' },\n    ]);\n    const asoGapmersGrid = DG.Viewer.grid(asoDf, { showRowHeader: false, showCellTooltip: false });\n    asoDf.onCurrentCellChanged.subscribe((_) => {\n        navigator.clipboard.writeText(asoDf.currentCell.value).then(() => grok.shell.info('Copied'));\n    });\n    const omeAndFluoroGrid = DG.Viewer.grid(DG.DataFrame.fromObjects([\n        { 'Name': '2\\'-fluoro-U', 'BioSpring': '1', 'Axolabs': 'Uf', 'Janssen GCRS': 'fU' },\n        { 'Name': '2\\'-fluoro-A', 'BioSpring': '2', 'Axolabs': 'Af', 'Janssen GCRS': 'fA' },\n        { 'Name': '2\\'-fluoro-C', 'BioSpring': '3', 'Axolabs': 'Cf', 'Janssen GCRS': 'fC' },\n        { 'Name': '2\\'-fluoro-G', 'BioSpring': '4', 'Axolabs': 'Gf', 'Janssen GCRS': 'fG' },\n        { 'Name': '2\\'OMe-rU', 'BioSpring': '5', 'Axolabs': 'u', 'Janssen GCRS': 'mU' },\n        { 'Name': '2\\'OMe-rA', 'BioSpring': '6', 'Axolabs': 'a', 'Janssen GCRS': 'mA' },\n        { 'Name': '2\\'OMe-rC', 'BioSpring': '7', 'Axolabs': 'c', 'Janssen GCRS': 'mC' },\n        { 'Name': '2\\'OMe-rG', 'BioSpring': '8', 'Axolabs': 'g', 'Janssen GCRS': 'mG' },\n        { 'Name': 'ps linkage', 'BioSpring': '*', 'Axolabs': 's', 'Janssen GCRS': 'ps' },\n    ]), { showRowHeader: false, showCellTooltip: false });\n    const overhangModificationsGrid = DG.Viewer.grid(DG.DataFrame.fromColumns([\n        DG.Column.fromStrings('Name', Object.keys(MODIFICATIONS)),\n    ]), { showRowHeader: false, showCellTooltip: false });\n    updateTableAndMolecule(defaultInput, inputFormatChoiceInput.value, true);\n    const appMainDescription = ui.info([\n        ui.divText('How to convert one sequence:', { style: { 'font-weight': 'bolder' } }),\n        ui.divText('Paste sequence into the text field below'),\n        ui.divText('\\n How to convert many sequences:', { style: { 'font-weight': 'bolder' } }),\n        ui.divText('1. Drag & drop an Excel or CSV file with sequences into Datagrok'),\n        ui.divText('2. Right-click on the column header, then see the \\'Convert\\' menu'),\n        ui.divText('This will add the result column to the right of the table'),\n    ], 'Convert oligonucleotide sequences between Nucleotides, BioSpring, Axolabs, Mermade 12 and GCRS representations.');\n    const codesTablesDiv = ui.splitV([\n        ui.box(ui.h2('ASO Gapmers'), { style: { maxHeight: '40px' } }),\n        asoGapmersGrid.root,\n        ui.box(ui.h2('2\\'-OMe and 2\\'-F siRNA'), { style: { maxHeight: '40px' } }),\n        omeAndFluoroGrid.root,\n        ui.box(ui.h2('Overhang modifications'), { style: { maxHeight: '40px' } }),\n        overhangModificationsGrid.root,\n    ], { style: { maxWidth: '350px' } });\n    const tabControl = ui.tabControl({\n        'MAIN': ui.box(ui.splitH([\n            ui.splitV([\n                ui.panel([\n                    appMainDescription,\n                    ui.div([\n                        ui.h1('Input sequence'),\n                        ui.div([\n                            inputSequenceField.root,\n                        ], 'input-base'),\n                    ], 'inputSequence'),\n                    ui.div([inputFormatChoiceInput], { style: { padding: '5px 0' } }),\n                    ui.block([\n                        ui.h1('Output'),\n                        outputTableDiv,\n                    ]),\n                    moleculeSvgDiv,\n                ], 'sequence'),\n            ]),\n            codesTablesDiv,\n        ], { style: { height: '100%', width: '100%' } })),\n        'AXOLABS': defineAxolabsPattern(),\n        'SDF': saveSenseAntiSense(),\n    });\n    const v = grok.shell.newView('Sequence Translator', [tabControl]);\n    v.box = true;\n    const switchInput = ui.switchInput('Codes', true, (v) => (v) ?\n        $(codesTablesDiv).show() :\n        $(codesTablesDiv).hide());\n    const topPanel = [\n        ui.iconFA('download', () => {\n            const result = sequenceToMolV3000(inputSequenceField.value.replace(/\\s/g, ''), false, false, inputFormatChoiceInput.value);\n            const element = document.createElement('a');\n            element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(result));\n            element.setAttribute('download', inputSequenceField.value.replace(/\\s/g, '') + '.mol');\n            element.click();\n        }, 'Save .mol file'),\n        ui.iconFA('copy', () => {\n            navigator.clipboard.writeText(sequenceToSmiles(inputSequenceField.value.replace(/\\s/g, ''), false, inputFormatChoiceInput.value))\n                .then(() => grok.shell.info(sequenceWasCopied));\n        }, 'Copy SMILES'),\n        switchInput.root,\n    ];\n    tabControl.onTabChanged.subscribe((_) => v.setRibbonPanels([(tabControl.currentPane.name == 'MAIN') ? topPanel : []]));\n    v.setRibbonPanels([topPanel]);\n}\nfunction saveTableAsSdFile(table) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (!table.columns.contains('Compound Name')) {\n            grok.shell.warning('File saved without columns \\'' +\n                [COL_NAMES.COMPOUND_NAME, COL_NAMES.COMPOUND_COMMENTS, COL_NAMES.CPD_MW,\n                    COL_NAMES.SALT_MASS, COL_NAMES.BATCH_MW].join('\\', \\''));\n        }\n        const structureColumn = table.col(COL_NAMES.SEQUENCE);\n        const typeColumn = table.col(COL_NAMES.TYPE);\n        let result = '';\n        for (let i = 0; i < table.rowCount; i++) {\n            const format = getFormat(structureColumn.get(i));\n            result += (typeColumn.get(i) == 'SS') ?\n                sequenceToMolV3000(structureColumn.get(i), false, true, format) + '\\n' + `>  <Sequence>\\nSense Strand\\n\\n` :\n                sequenceToMolV3000(structureColumn.get(i), true, true, format) + '\\n' + `>  <Sequence>\\nAnti Sense\\n\\n`;\n            for (const col of table.columns) {\n                if (col.name != COL_NAMES.SEQUENCE)\n                    result += `>  <${col.name}>\\n${col.get(i)}\\n\\n`;\n            }\n            result += '$$$$\\n\\n';\n        }\n        const element = document.createElement('a');\n        element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(result));\n        element.setAttribute('download', table.name + '.sdf');\n        element.click();\n    });\n}\nconst weightsObj = {};\nfor (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            weightsObj[code] = map[synthesizer][technology][code].weight;\n    }\n}\nfor (const [key, value] of Object.entries(MODIFICATIONS))\n    weightsObj[key] = value.molecularWeight;\nfunction sortByStringLengthInDescendingOrder(array) {\n    return array.sort(function (a, b) { return b.length - a.length; });\n}\nfunction stringifyItems(items) {\n    return '[\"' + items.join('\", \"') + '\"]';\n}\nfunction molecularWeight(sequence, weightsObj) {\n    const codes = sortByStringLengthInDescendingOrder(Object.keys(weightsObj)).concat(Object.keys(MODIFICATIONS));\n    let weight = 0;\n    let i = 0;\n    while (i < sequence.length) {\n        const matchedCode = codes.find((s) => s == sequence.slice(i, i + s.length));\n        weight += weightsObj[sequence.slice(i, i + matchedCode.length)];\n        i += matchedCode.length;\n    }\n    return weight - 61.97;\n}\n//tags: autostart\nexport function autostartOligoSdFileSubscription() {\n    grok.events.onViewAdded.subscribe((v) => {\n        if (v.type == 'TableView' && v.dataFrame.columns.contains(COL_NAMES.TYPE))\n            oligoSdFile(v.dataFrame);\n    });\n}\nexport function oligoSdFile(table) {\n    const saltsDf = DG.DataFrame.fromCsv(SALTS_CSV);\n    const usersDf = DG.DataFrame.fromCsv(USERS_CSV);\n    const sourcesDf = DG.DataFrame.fromCsv(SOURCES);\n    const icdsDf = DG.DataFrame.fromCsv(ICDS);\n    const idpsDf = DG.DataFrame.fromCsv(IDPS);\n    function addColumns(t, saltsDf) {\n        if (t.columns.contains(COL_NAMES.COMPOUND_NAME))\n            return grok.shell.error('Columns already exist!');\n        const sequence = t.col(COL_NAMES.SEQUENCE);\n        const salt = t.col(COL_NAMES.SALT);\n        const equivalents = t.col(COL_NAMES.EQUIVALENTS);\n        t.columns.addNewString(COL_NAMES.COMPOUND_NAME).init((i) => sequence.get(i));\n        t.columns.addNewString(COL_NAMES.COMPOUND_COMMENTS).init((i) => (i > 0 && i % 2 == 0) ?\n            sequence.getString(i) + '; duplex of SS: ' + sequence.getString(i - 2) + ' and AS: ' + sequence.getString(i - 1) :\n            sequence.getString(i));\n        const molWeightCol = saltsDf.col('MOLWEIGHT');\n        const saltNamesList = saltsDf.col('DISPLAY').toList();\n        t.columns.addNewFloat(COL_NAMES.CPD_MW)\n            .init((i) => molecularWeight(sequence.get(i), weightsObj));\n        t.columns.addNewFloat(COL_NAMES.SALT_MASS).init((i) => {\n            const saltRowIndex = saltNamesList.indexOf(salt.get(i));\n            const mw = molWeightCol.get(saltRowIndex);\n            return mw * equivalents.get(i);\n        });\n        t.columns.addNewCalculated(COL_NAMES.BATCH_MW, '${' + COL_NAMES.CPD_MW + '} + ${' + COL_NAMES.SALT_MASS + '}', DG.COLUMN_TYPE.FLOAT, false);\n        addColumnsPressed = true;\n        return newDf = t;\n    }\n    let newDf;\n    let addColumnsPressed = false;\n    const d = ui.div([\n        ui.icons.edit(() => {\n            d.innerHTML = '';\n            if (table.col(COL_NAMES.IDP).type != DG.COLUMN_TYPE.STRING)\n                table.changeColumnType(COL_NAMES.IDP, DG.COLUMN_TYPE.STRING);\n            d.append(ui.link('Add Columns', () => {\n                addColumns(table, saltsDf);\n                grok.shell.tableView(table.name).grid.columns.setOrder(Object.values(COL_NAMES));\n            }, 'Add columns: \\'' + [COL_NAMES.COMPOUND_NAME, COL_NAMES.COMPOUND_COMMENTS, COL_NAMES.CPD_MW,\n                COL_NAMES.SALT_MASS, COL_NAMES.BATCH_MW].join('\\', \\''), ''), ui.button('Save SD file', () => saveTableAsSdFile(addColumnsPressed ? newDf : table)));\n            const view = grok.shell.getTableView(table.name);\n            view.table.col(COL_NAMES.TYPE).setTag(DG.TAGS.CHOICES, '[\"AS\", \"SS\", \"Duplex\"]');\n            view.table.col(COL_NAMES.OWNER).setTag(DG.TAGS.CHOICES, stringifyItems(usersDf.columns.byIndex(0).toList()));\n            view.table.col(COL_NAMES.SALT).setTag(DG.TAGS.CHOICES, stringifyItems(saltsDf.columns.byIndex(0).toList()));\n            view.table.col(COL_NAMES.SOURCE).setTag(DG.TAGS.CHOICES, stringifyItems(sourcesDf.columns.byIndex(0).toList()));\n            view.table.col(COL_NAMES.ICD).setTag(DG.TAGS.CHOICES, stringifyItems(icdsDf.columns.byIndex(0).toList()));\n            view.table.col(COL_NAMES.IDP).setTag(DG.TAGS.CHOICES, stringifyItems(idpsDf.columns.byIndex(0).toList()));\n            grok.events.onContextMenu.subscribe((args) => {\n                if ([COL_NAMES.TYPE, COL_NAMES.OWNER, COL_NAMES.SALT, COL_NAMES.SOURCE, COL_NAMES.ICD, COL_NAMES.IDP]\n                    .includes(args.args.context.table.currentCol.name)) {\n                    args.args.menu.item('Fill Column With Value', () => {\n                        const v = args.args.context.table.currentCell.value;\n                        args.args.context.table.currentCell.column.init(v);\n                    });\n                }\n            });\n        }),\n    ]);\n    grok.shell.v.setRibbonPanels([[d]]);\n}\n"],"names":[],"sourceRoot":""}
|
|
5479
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"package.js","mappings":";;;;;;;;;;AAAA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;;AAErB;AACA;AACA,EAAE;AACF;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN,mCAAmC;AACnC;;AAEA;AACA;;AAEA,qCAAqC,OAAO;AAC5C;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA,+BAA+B;;AAE/B;AACA,oBAAoB;;AAEpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA,GAAG;;;AAGH;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA,eAAe;;AAEf;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;;AAEA,qCAAqC,OAAO;AAC5C;AACA;AACA;AACA,IAAI;AACJ,oCAAoC,OAAO;AAC3C;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;;AAEA,mBAAmB,uBAAuB;AAC1C;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,kBAAkB,YAAY;AAC9B;;AAEA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA,GAAG;AACH;;;AAGA;AACA;AACA;AACA,IAAI;AACJ;AACA,IAAI;AACJ;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH,GAAG;;;AAGH;AACA;AACA,EAAE;;;AAGF;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,kCAAkC,OAAO;AACzC;AACA;AACA;AACA,MAAM;AACN;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;AAEA;AACA;AACA,GAAG;AACH;;;AAGA;AACA;AACA;AACA;AACA,EAAE;;;AAGF;AACA;AACA;;AAEA,2BAA2B;;AAE3B;AACA;AACA,EAAE;AACF;AACA;AACA;AACA;;;AAGA,sBAAsB;AACtB;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;AAEA,EAAE;AACF;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,QAAQ;AACR;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,cAAc;AACd;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,EAAE;AACF;;;AAGA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,gBAAgB;;AAEhB;AACA;AACA;AACA,EAAE;;;AAGF;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH,CAAC;AACD;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,CAAC,GAAG;AACJ;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAE;;;AAGF;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;;AAGA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD;AACA;AACA;AACA,CAAC;AACD,8EAA8E;;AAE9E;AACA;AACA,EAAE;;;AAGF;AACA;AACA,EAAE;AACF;;;AAGA;AACA;AACA;AACA;AACA;AACA,EAAE;;;AAGF;AACA;AACA,4CAA4C;AAC5C,EAAE;AACF;AACA;;;AAGA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL,IAAI;AACJ;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA,wFAAwF;;AAExF;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,8BAA8B;AAC9B;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,uCAAuC;;AAEvC;;AAEA,wCAAwC;AACxC;;AAEA;AACA,GAAG;AACH,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT,QAAQ;AACR;AACA;AACA,MAAM;AACN;AACA;AACA,GAAG;AACH;;AAEA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA,GAAG;AACH,GAAG;AACH;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,GAAG;AACH,EAAE;;;AAGF;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA,EAAE;;;AAGF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL,GAAG;AACH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA,IAAI,IAA8B;AAClC;AACA;AACA,EAAE,KAAK,EAGN;AACD,CAAC;;;;;;;;;;;AC71CD,gEAAa;;AAEb;AACA,aAAa,KAA6B,eAAe,KAA4B,OAAO;AAC5F,MAAM,IAA6B,EAAE,iCAA0B,EAAE,mCAAE;AACnE;AACA,GAAG;AAAA,kGAAC;AACJ;;AAEA;AACA;AACA;AACA,8KAA8K;AAC9K;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,mFAAmF;AACnF;AACA;AACA;AACA,qCAAqC,iEAAiE;AACtG,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,2EAA2E,EAAE;AAC7E;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA,6DAA6D;AAC7D;AACA;AACA,oBAAoB,uBAAuB;AAC3C;AACA;AACA,gCAAgC,kBAAkB;AAClD;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;;AAEA;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,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mFAAmF;AACnF;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB,QAAQ;AACR;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA,4BAA4B;AAC5B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,qBAAqB,cAAc;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,yGAAyG;AACzG;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA,OAAO;AACP,KAAK;;AAEL;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA,eAAe;AACf;AACA;;AAEA;AACA;;AAEA,6BAA6B;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,kDAAkD;;AAElD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;;AAEA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA,iEAAiE,cAAc;AAC/E,QAAQ;AACR;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,mEAAmE,cAAc;AACjF,SAAS;AACT;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,uCAAuC;AACvC;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;AAEA,6BAA6B;AAC7B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,oCAAoC;;AAEpC;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA,sEAAsE;AACtE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA,qFAAqF;AACrF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;;AAEA;AACA,0CAA0C;AAC1C;AACA,gDAAgD;AAChD,KAAK;AACL;AACA,KAAK;AACL;;AAEA;AACA,0CAA0C;AAC1C;AACA,+CAA+C;AAC/C,KAAK;AACL;AACA,KAAK;AACL;AACA,CAAC;;;;;;;;;;;;;;;AC5bM;AACP;AACA;;;;;;;;;;;;;;;;ACFO;AACP;AACA;;;;;;;;;;;;;;;;ACFA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;;;;;;;;;;;;;;;;;;;;;;;;;;;;AClGA,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;AACA;AAC0C;AACJ;AACA;AACtC;AACuC;AACd;AACiC;AAChB;AAC1C,gCAAgC,mDAAU;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,mDAAU;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,iEAAuB;AAC5C;AACA;AACA,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA,oBAAoB,wBAAwB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,wBAAwB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,uEAAoC;AAClE,uBAAuB,mDAAU;AACjC;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,0DAAgB;AACpC;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,oBAAoB,0DAAgB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,oBAAoB;AAC5C,+BAA+B,sDAAY;AAC3C;AACA;AACA,aAAa;AACb,yBAAyB,wDAAc;AACvC;AACA;AACA,uDAAuD,sDAAY;AACnE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,uCAAuC,iDAAO;AAC9C,gBAAgB,gDAAM,EAAE,kDAAQ,2EAA2E,SAAS,iBAAiB;AACrI,gBAAgB,oDAAU;AAC1B,gBAAgB,gDAAM;AACtB,iBAAiB,SAAS,wBAAwB;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,oBAAoB;AAC5C,+BAA+B,sDAAY;AAC3C;AACA;AACA,aAAa;AACb,yBAAyB,wDAAc;AACvC;AACA;AACA,uDAAuD,sDAAY;AACnE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,uCAAuC,iDAAO;AAC9C,gBAAgB,gDAAM,EAAE,kDAAQ,2EAA2E,SAAS,iBAAiB;AACrI,gBAAgB,oDAAU;AAC1B,gBAAgB,gDAAM;AACtB,iBAAiB,SAAS,wBAAwB;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,mDAAS;AACrB,qBAAqB,oDAAU;AAC/B;AACA,qBAAqB,oDAAU;AAC/B;AACA;AACA;AACA;AACA,wBAAwB,0BAA0B;AAClD;AACA,wBAAwB,0BAA0B;AAClD;AACA;AACA;AACA;AACA,wBAAwB,oBAAoB;AAC5C;AACA,wBAAwB,oBAAoB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,iDAAO;AAC7B,YAAY,uEAAkB;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,kBAAkB;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,4EAAkC;AACzD,kBAAkB,uEAA6B;AAC/C;AACA;AACA;AACA;AACA;AACA,gCAAgC,2BAA2B;AAC3D,iCAAiC,wDAAc;AAC/C;AACA,gCAAgC,2BAA2B;AAC3D,iCAAiC,wDAAc;AAC/C;AACA;AACA,gCAAgC,iCAAiC;AACjE,uCAAuC,sDAAY;AACnD;AACA;AACA,gCAAgC,iCAAiC;AACjE,uCAAuC,sDAAY;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,mDAAS;AACpC,YAAY,+CAAC;AACb;AACA,qBAAqB,oDAAU;AAC/B,qBAAqB,oDAAU;AAC/B;AACA;AACA,gBAAgB,yDAAe;AAC/B;AACA,gBAAgB,sDAAY,GAAG,iEAAuB;AACtD,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB,iEAAuB;AAChD;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,6EAAmC;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,qBAAqB,yDAAe;AACjD,SAAS;AACT;AACA;AACA;AACA,YAAY,uEAA6B;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC;AACzC;AACA,kCAAkC,wDAAc;AAChD,8CAA8C,wDAAc;AAC5D;AACA,kCAAkC,wDAAc;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,gDAAM;AAClD,wBAAwB,mDAAS,CAAC,mDAAS,uBAAuB;AAClE;AACA,gCAAgC,4DAAkB;AAClD;AACA,gCAAgC,4DAAkB;AAClD;AACA,sCAAsC,0EAAgC;AACtE,gDAAgD,yDAAe;AAC/D;AACA;AACA,yBAAyB;AACzB;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,gDAAM;AAC9C,oBAAoB,mDAAS,CAAC,mDAAS,uBAAuB;AAC9D;AACA,4BAA4B,4DAAkB;AAC9C;AACA,4BAA4B,4DAAkB;AAC9C;AACA,kCAAkC,0EAAgC;AAClE,4CAA4C,yDAAe;AAC3D;AACA;AACA,qBAAqB;AACrB;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA,kBAAkB,uEAA6B;AAC/C;AACA;AACA,mCAAmC,mDAAS;AAC5C,oBAAoB,+CAAC;AACrB;AACA,6BAA6B,oDAAU;AACvC,6BAA6B,oDAAU;AACvC;AACA,8BAA8B,0EAAgC;AAC9D;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,SAAS;AACT;AACA,6BAA6B,gDAAM;AACnC,6BAA6B,gDAAM;AACnC,6BAA6B,gDAAM;AACnC,gCAAgC,gDAAM;AACtC,gCAAgC,gDAAM;AACtC,mBAAmB,gDAAM;AACzB,yBAAyB,gDAAM;AAC/B,kCAAkC,gDAAM;AACxC,2BAA2B,gDAAM;AACjC,8BAA8B,gDAAM;AACpC,0BAA0B,gDAAM;AAChC,wCAAwC,iDAAO,EAAE,sDAAY;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,oDAAoD,wDAAc;AAClE,oDAAoD,wDAAc;AAClE,0DAA0D,sDAAY;AACtE,0DAA0D,sDAAY;AACtE,qBAAqB,qDAAW;AAChC,qBAAqB,qDAAW;AAChC,wBAAwB,gDAAM;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,qDAAW;AACnC,YAAY,0DAAgB;AAC5B;AACA;AACA,YAAY,mDAAS;AACrB,qBAAqB,oDAAU;AAC/B;AACA;AACA;AACA,gBAAgB,sDAAY,GAAG,iEAAuB;AACtD,gBAAgB,yDAAe;AAC/B,aAAa;AACb;AACA;AACA;AACA,mBAAmB,uDAAa,WAAW,8DAAoB,EAAE,2DAAiB;AAClF,8BAA8B,wDAAc;AAC5C;AACA;AACA,SAAS;AACT;AACA;AACA,8BAA8B,wDAAc;AAC5C;AACA;AACA,SAAS;AACT;AACA;AACA,8BAA8B,wDAAc;AAC5C;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA,0BAA0B,wDAAc;AACxC;AACA;AACA,KAAK;AACL;AACA;AACA,0BAA0B,wDAAc;AACxC;AACA;AACA,KAAK;AACL;AACA;AACA,0BAA0B,wDAAc;AACxC;AACA;AACA,KAAK;AACL;AACA;AACA,yBAAyB,wDAAc;AACvC;AACA;AACA,KAAK;AACL,qBAAqB,sDAAY;AACjC;AACA;AACA;AACA;AACA,KAAK;AACL,uBAAuB,sDAAY;AACnC,uBAAuB,sDAAY;AACnC;AACA,2BAA2B,sDAAY;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,mBAAmB,sDAAY;AAC/B;AACA,gCAAgC,wDAAc;AAC9C;AACA;AACA,KAAK;AACL;AACA,+BAA+B,wDAAc;AAC7C;AACA;AACA,KAAK;AACL;AACA,gCAAgC,wDAAc;AAC9C;AACA;AACA,KAAK;AACL;AACA,+BAA+B,wDAAc;AAC7C;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,oBAAoB,sDAAY;AAChC,8BAA8B,mDAAS;AACvC;AACA,sCAAsC,yDAAe;AACrD;AACA,yBAAyB,wDAAc;AACvC,YAAY,mDAAS;AACrB;AACA;AACA;AACA,0CAA0C,yDAAe;AACzD,aAAa;AACb;AACA;AACA,KAAK;AACL,kCAAkC,mDAAS;AAC3C;AACA,YAAY,yDAAe;AAC3B;AACA,2BAA2B,mDAAS;AACpC,YAAY,+CAAC;AACb;AACA,qBAAqB,oDAAU;AAC/B;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,sDAAY,GAAG,iEAAuB;AAClD,YAAY,yDAAe;AAC3B;AACA;AACA,KAAK;AACL,2BAA2B,sDAAY;AACvC;AACA,KAAK;AACL,4BAA4B,sDAAY;AACxC;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,gDAAM;AACtC,QAAQ,mDAAS,CAAC,mDAAS,kBAAkB;AAC7C,4EAA4E,yDAAe;AAC3F,SAAS;AACT;AACA,2BAA2B,sDAAY;AACvC;AACA,KAAK;AACL,4BAA4B,sDAAY;AACxC;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,gDAAM;AACtC,QAAQ,mDAAS,CAAC,mDAAS,kBAAkB;AAC7C,4EAA4E,yDAAe;AAC3F,SAAS;AACT;AACA;AACA;AACA;AACA,2BAA2B,gDAAM;AACjC,QAAQ,+CAAK;AACb;AACA;AACA;AACA;AACA,0BAA0B,gDAAM;AAChC,QAAQ,+CAAK;AACb,QAAQ,iDAAO;AACf;AACA;AACA;AACA,QAAQ,iDAAO;AACf;AACA;AACA;AACA,QAAQ,yDAAe;AACvB;AACA;AACA;AACA,wBAAwB,kDAAQ;AAChC,QAAQ,kDAAQ;AAChB;AACA,aAAa,SAAS,uBAAuB;AAC7C,QAAQ,mDAAS,mBAAmB,yDAAgB;AACpD;AACA,QAAQ,gDAAM;AACd,YAAY,gDAAM;AAClB,gBAAgB,iDAAO;AACvB,oBAAoB,+CAAK;AACzB,oBAAoB,gDAAM;AAC1B,wBAAwB,mDAAS;AACjC;AACA;AACA,yBAAyB;AACzB,yBAAyB,SAAS,kBAAkB;AACpD;AACA,gBAAgB,iDAAO;AACvB,oBAAoB,gDAAM;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,yDAAe;AACvC;AACA;AACA;AACA,oBAAoB,gDAAM;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,SAAS,oBAAoB;AAC1C;AACA,kCAAkC,kDAAQ;AAC1C,QAAQ,+CAAK;AACb,QAAQ,iDAAO;AACf,YAAY,gDAAM,EAAE,oDAAU,UAAU,SAAS,iBAAiB;AAClE,YAAY,oDAAU,EAAE,oDAAU;AAClC,YAAY,gDAAM,EAAE,oDAAU,YAAY,SAAS,uBAAuB;AAC1E;AACA;AACA;AACA,kCAAkC,kDAAQ;AAC1C,QAAQ,+CAAK;AACb,QAAQ,iDAAO;AACf,YAAY,gDAAM,EAAE,oDAAU,UAAU,SAAS,iBAAiB;AAClE,YAAY,oDAAU,EAAE,oDAAU;AAClC,YAAY,gDAAM,EAAE,oDAAU,YAAY,SAAS,uBAAuB;AAC1E;AACA;AACA;AACA,iBAAiB,iDAAO;AACxB,QAAQ,oDAAU,oCAAoC,SAAS,2BAA2B;AAC1F,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB;AACA,WAAW,mDAAS;AACpB,QAAQ,gDAAM;AACd;AACA;AACA;AACA,QAAQ,gDAAM,CAAC,iDAAO;AACtB;AACA;AACA,cAAc,SAAS,qBAAqB;AAC5C;AACA;;;;;;;;;;;;;;;;;ACluB0C;AAC1C;AACA;AACA,iCAAiC;AACjC;AACA,qCAAqC;AACrC;AACA;AACA;AACA,uDAAuD;AACvD;AACA,oBAAoB,yBAAyB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,mDAAU;AACrB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,oBAAoB;AACxC;AACA;AACA;AACA;AACA,qCAAqC,QAAQ;AAC7C;AACA;AACA;AACA,iLAAiL,mDAAU;AAC3L;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,oBAAoB;AACxC;AACA;AACA;AACA;AACA;AACA,yCAAyC,QAAQ;AACjD;AACA;AACA;AACA,gJAAgJ,mDAAU;AAC1J;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,wBAAwB;AAC5C;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;ACvLO;AACP;;;;;;;;;;;;;;;;ACDO;AACP;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACFmC;AACG;AACtC;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,eAAe,8DAAoB,CAAC,4CAAU;AAC9C;AACA;AACA;AACA;AACA,oBAAoB,iBAAiB;AACrC;AACA;AACA;AACA;AACA,sDAAsD,mBAAmB;AACzE;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;;;;;;;;;;;;;;;;;;;;AC1RmG;AAC1C;AACC;AACnD;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,+CAAa;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA,gBAAgB,+CAAa,uBAAuB,+CAAa;AACjE,6BAA6B,4DAA0B;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,4DAA0B;AAC3D;AACA;AACA;AACA,WAAW,uEAAiB;AAC5B;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,+CAAa;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA,gBAAgB,+CAAa,uBAAuB,4DAA0B;AAC9E,gBAAgB,+CAAa,sBAAsB,4DAA0B;AAC7E;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,4DAA0B;AACxE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,mEAAiC;AACzE;AACA;AACA;AACA;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;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;;;;;;;;;;;;;;;;;;;;;;;;;;ACtGsC;AAC4B;AAC3D;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;AACO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACO;AACA;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,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;;;;;;;;;;;;;;;;;AChtB5C;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,wBAAwB,uBAAuB;AAC/C;AACA;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA,4BAA4B,oBAAoB;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;;;;;;;;;;;;;;;;;;;;;ACvXsC;AACiC;AACH;AACC;AAC9D;AACP,qBAAqB,iFAAS;AAC9B,qBAAqB,iFAAS;AAC9B,kBAAkB,mFAAkB;AACpC,kBAAkB,mFAAkB;AACpC;AACA;AACA,iBAAiB,gFAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kDAAkD;AAClD;AACA;AACA;AACO;AACP,2BAA2B,kDAAQ;AACnC,oBAAoB,sDAAY;AAChC,oBAAoB,sDAAY;AAChC,uBAAuB,wDAAc;AACrC,oBAAoB,wDAAc;AAClC,oBAAoB,mDAAS;AAC7B,wBAAwB,kDAAQ;AAChC,QAAQ,gDAAM;AACd,YAAY,gDAAM;AAClB,gBAAgB,iDAAO,EAAE,+CAAK;AAC9B,gBAAgB,iDAAO;AACvB,oBAAoB,gDAAM;AAC1B,oBAAoB,gDAAM;AAC1B;AACA;AACA,oBAAoB,yDAAe;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;AC/CuE;AACqf;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;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,kCAAkC,qCAAG;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,yCAAyC,qCAAG;AAC5C,yCAAyC,qCAAG;AAC5C,oCAAoC,+CAAa;AACjD;AACA;AACA;AACA,gBAAgB,qCAAG;AACnB;AACA;AACA;AACA,wBAAwB,qBAAqB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,gBAAgB,qCAAG;AACnB,kCAAkC,qCAAG,8CAA8C,+CAAa;AAChG;AACA;AACA,KAAK;AACL;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,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;;;;;;;;;;;;;;;;ACpRO;AACP;AACA;;;;;;;;;;;;ACFA;;;;;;;;;;;ACAA;;;;;;;;;;;ACAA;;;;;;UCAA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;WACA;WACA;WACA;WACA;WACA,iCAAiC,WAAW;WAC5C;WACA;;;;;WCPA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA;;;;;WCPA;;;;;WCAA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACNA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACA;AACA;AAC0C;AACJ;AACA;AACb;AACqC;AACe;AACW;AACsC;AACvD;AAC4D;AAC/F;AACA;AACN;AACM;AACN;AACvB,qBAAqB,oDAAU;AACtC;AACA;AACA;AACA;AACA;AACO;AACP,oBAAoB,4DAAkB;AACtC;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,4EAAkC;AACrD;AACA;AACA;AACA,2BAA2B,uFAAe;AAC1C;AACA;AACA;AACA,sCAAsC,uFAAe;AACrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,iDAAO;AAC/B,4BAA4B,oDAAU,gDAAgD,SAAS,iBAAiB;AAChH,4BAA4B,yDAAe,CAAC,oDAAU,6CAA6C,SAAS,gBAAgB;AAC5H;AACA;AACA,wBAAwB,iDAAO;AAC/B,wCAAwC,yDAAe;AACvD,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA,6DAA6D,kCAAkC;AAC/F,+DAA+D,kCAAkC;AACjG;AACA,kCAAkC,gDAAM;AACxC,gBAAgB,6DAAmB;AACnC;AACA,0CAA0C,0FAAsB,+BAA+B,0FAAsB;AACrH,+BAA+B,mDAAS;AACxC;AACA,iCAAiC,mDAAS,CAAC,+CAAC,kBAAkB,+CAAC;AAC/D,gCAAgC,mFAAkB;AAClD;AACA,0FAA0F,0BAA0B;AACpH,oBAAoB,mDAAS;AAC7B;AACA;AACA,iBAAiB;AACjB,gBAAgB,+CAAC,+BAA+B,+CAAC;AACjD,gBAAgB,+CAAC,8BAA8B,+CAAC;AAChD,4BAA4B,mFAAkB;AAC9C;AACA,wFAAwF,0BAA0B;AAClH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,wDAAc,qDAAqD,sDAAG;AACzG;AACA,KAAK;AACL,2BAA2B,kDAAQ;AACnC,2BAA2B,gDAAM;AACjC,+BAA+B,sDAAY;AAC3C,kBAAkB,kEAAwB;AAC1C,UAAU,mEAAmE;AAC7E,UAAU,+DAA+D;AACzE,UAAU,qEAAqE;AAC/E,UAAU,+DAA+D;AACzE,UAAU,gEAAgE;AAC1E,UAAU,8DAA8D;AACxE,UAAU,yDAAyD;AACnE,UAAU,yDAAyD;AACnE,UAAU,yDAAyD;AACnE,UAAU,yDAAyD;AACnE,UAAU,qDAAqD;AAC/D,UAAU,qDAAqD;AAC/D,UAAU,qDAAqD;AAC/D,UAAU,qDAAqD;AAC/D;AACA,2BAA2B,wDAAc,UAAU,8CAA8C;AACjG;AACA,0EAA0E,yDAAe;AACzF,KAAK;AACL,6BAA6B,wDAAc,CAAC,kEAAwB;AACpE,UAAU,iFAAiF;AAC3F,UAAU,iFAAiF;AAC3F,UAAU,iFAAiF;AAC3F,UAAU,iFAAiF;AAC3F,UAAU,6EAA6E;AACvF,UAAU,6EAA6E;AACvF,UAAU,6EAA6E;AACvF,UAAU,6EAA6E;AACvF,UAAU,8EAA8E;AACxF,UAAU,8CAA8C;AACxD,sCAAsC,wDAAc,CAAC,kEAAwB;AAC7E,QAAQ,+DAAqB,qBAAqB,gEAAa;AAC/D,UAAU,8CAA8C;AACxD;AACA,+BAA+B,iDAAO;AACtC,QAAQ,oDAAU,mCAAmC,SAAS,2BAA2B;AACzF,QAAQ,oDAAU;AAClB,QAAQ,oDAAU,wCAAwC,SAAS,2BAA2B;AAC9F,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB;AACA,2BAA2B,mDAAS;AACpC,QAAQ,gDAAM,CAAC,+CAAK,mBAAmB,SAAS,qBAAqB;AACrE;AACA,QAAQ,gDAAM,CAAC,+CAAK,+BAA+B,SAAS,qBAAqB;AACjF;AACA,QAAQ,gDAAM,CAAC,+CAAK,8BAA8B,SAAS,qBAAqB;AAChF;AACA,SAAS,SAAS,qBAAqB;AACvC,uBAAuB,uDAAa;AACpC,gBAAgB,gDAAM,CAAC,mDAAS;AAChC,YAAY,mDAAS;AACrB,gBAAgB,kDAAQ;AACxB;AACA,oBAAoB,gDAAM;AAC1B,wBAAwB,+CAAK;AAC7B,wBAAwB,gDAAM;AAC9B;AACA;AACA;AACA,oBAAoB,gDAAM,6BAA6B,SAAS,oBAAoB;AACpF,oBAAoB,kDAAQ;AAC5B,wBAAwB,+CAAK;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,SAAS,iCAAiC;AACvD,mBAAmB,2EAAoB;AACvC,eAAe,0FAAkB;AACjC,KAAK;AACL,IAAI,+CAAC;AACL,cAAc,4DAAkB;AAChC;AACA,wBAAwB,wDAAc;AACtC,QAAQ,+CAAC;AACT,QAAQ,+CAAC;AACT;AACA,QAAQ,mDAAS;AACjB,2BAA2B,mFAAkB;AAC7C;AACA,0DAA0D;AAC1D;AACA;AACA,SAAS;AACT,QAAQ,mDAAS;AACjB,0CAA0C,iFAAgB;AAC1D,4BAA4B,yDAAe;AAC3C,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,4DAAkB;AAC9B,iBAAiB,0EAAuB,EAAE,8EAA2B,EAAE,mEAAgB;AACvF,oBAAoB,sEAAmB,EAAE,qEAAkB;AAC3D;AACA,0CAA0C,qEAAkB;AAC5D,qCAAqC,iEAAc;AACnD;AACA,wBAAwB,oBAAoB;AAC5C,2BAA2B,iFAAS;AACpC;AACA,gBAAgB,mFAAkB;AAClC,gBAAgB,mFAAkB;AAClC;AACA,gCAAgC,qEAAkB;AAClD,qCAAqC,SAAS,KAAK,WAAW;AAC9D;AACA;AACA;AACA;AACA,sDAAsD;AACtD;AACA;AACA,KAAK;AACL;AACA;AACA,sCAAsC,sDAAG;AACzC,yCAAyC,sDAAG;AAC5C,uCAAuC,sDAAG;AAC1C,qEAAqE,sDAAG;AACxE;AACA;AACA,0CAA0C,gEAAa;AACvD;AACA;AACA,wCAAwC,6BAA6B;AACrE;AACA;AACA;AACA;AACA;AACA,kGAAkG,gEAAa;AAC/G;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP,IAAI,2EAAiC;AACrC;AACA,6CAA6C,iEAAc;AAC3D;AACA,YAAY,6EAAmC;AAC/C;AACA,oBAAoB,sEAA4B,+BAA+B,GAAG;AAClF;AACA;AACA,mCAAmC,gFAAkB;AACrD,yBAAyB;AACzB,qBAAqB;AACrB;AACA,yBAAyB,sEAA4B,6BAA6B,GAAG;AACrF,oBAAoB,sEAA4B,6CAA6C,GAAG;AAChG;AACA;AACA,mCAAmC,+EAAiB;AACpD,yBAAyB;AACzB,qBAAqB;AACrB;AACA;AACA,mCAAmC,6EAAe;AAClD,yBAAyB;AACzB,qBAAqB;AACrB;AACA,yBAAyB,sEAA4B,+BAA+B,GAAG;AACvF;AACA;AACA;AACA,mCAAmC,uFAAyB;AAC5D,yBAAyB;AACzB,qBAAqB;AACrB;AACA,yBAAyB,sEAA4B,yBAAyB,GAAG;AACjF;AACA;AACA,mCAAmC,gFAAkB;AACrD,yBAAyB;AACzB,qBAAqB;AACrB;AACA,aAAa;AACb;AACA,KAAK;AACL;AACO;AACP,oBAAoB,8DAAoB,CAAC,8CAAS;AAClD,oBAAoB,8DAAoB,CAAC,8CAAS;AAClD,sBAAsB,8DAAoB,CAAC,8CAAO;AAClD,mBAAmB,8DAAoB,CAAC,wCAAI;AAC5C,mBAAmB,8DAAoB,CAAC,wCAAI;AAC5C;AACA,+BAA+B,0EAAuB;AACtD,mBAAmB,0DAAgB;AACnC,+BAA+B,qEAAkB;AACjD,2BAA2B,iEAAc;AACzC,kCAAkC,wEAAqB;AACvD,+BAA+B,0EAAuB;AACtD,+BAA+B,8EAA2B;AAC1D,uCAAuC;AACvC;AACA;AACA;AACA,8BAA8B,mEAAgB;AAC9C;AACA,8BAA8B,sEAAmB;AACjD;AACA;AACA;AACA,SAAS;AACT,mCAAmC,qEAAkB,KAAK,IAAI,mEAAgB,MAAM,IAAI,IAAI,sEAAmB,KAAK,GAAG,8DAAoB;AAC3I;AACA;AACA;AACA;AACA;AACA,cAAc,gDAAM;AACpB,QAAQ,uDAAa;AACrB;AACA,0BAA0B,gEAAa,UAAU,+DAAqB;AACtE,uCAAuC,gEAAa,EAAE,+DAAqB;AAC3E,qBAAqB,iDAAO;AAC5B;AACA,gBAAgB,8DAAoB,iDAAiD,4DAAS;AAC9F,aAAa,uBAAuB,0EAAuB,EAAE,8EAA2B,EAAE,mEAAgB;AAC1G,gBAAgB,sEAAmB,EAAE,qEAAkB,uBAAuB,mDAAS;AACvF,yBAAyB,iEAAuB;AAChD,2BAA2B,iEAAc,SAAS,yDAAe;AACjE,2BAA2B,kEAAe,SAAS,yDAAe;AAClE,2BAA2B,iEAAc,SAAS,yDAAe;AACjE,2BAA2B,mEAAgB,SAAS,yDAAe;AACnE,2BAA2B,gEAAa,SAAS,yDAAe;AAChE,2BAA2B,gEAAa,SAAS,yDAAe;AAChE,YAAY,6EAAmC;AAC/C,qBAAqB,iEAAc,EAAE,kEAAe,EAAE,iEAAc,EAAE,mEAAgB,EAAE,gEAAa,EAAE,gEAAa;AACpH;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA,aAAa;AACb,SAAS;AACT;AACA,IAAI,sEAA4B;AAChC","sources":["webpack://sequencetranslator/./node_modules/cash-dom/dist/cash.js","webpack://sequencetranslator/./node_modules/save-svg-as-png/lib/saveSvgAsPng.js","webpack://sequencetranslator/./src/ICDs.ts","webpack://sequencetranslator/./src/IDPs.ts","webpack://sequencetranslator/./src/axolabsMap.ts","webpack://sequencetranslator/./src/defineAxolabsPattern.ts","webpack://sequencetranslator/./src/drawAxolabsPattern.ts","webpack://sequencetranslator/./src/salts.ts","webpack://sequencetranslator/./src/sources.ts","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/save-sense-antisense.ts","webpack://sequencetranslator/./src/structures-works/sequence-codes-tools.ts","webpack://sequencetranslator/./src/users.ts","webpack://sequencetranslator/external var \"DG\"","webpack://sequencetranslator/external var \"grok\"","webpack://sequencetranslator/external var \"ui\"","webpack://sequencetranslator/webpack/bootstrap","webpack://sequencetranslator/webpack/runtime/compat get default export","webpack://sequencetranslator/webpack/runtime/define property getters","webpack://sequencetranslator/webpack/runtime/hasOwnProperty shorthand","webpack://sequencetranslator/webpack/runtime/make namespace object","webpack://sequencetranslator/./src/package.ts"],"sourcesContent":["/* MIT https://github.com/fabiospampinato/cash */\n(function(){\n\"use strict\";\n\nvar propMap = {\n  /* GENERAL */\n  \"class\": 'className',\n  contenteditable: 'contentEditable',\n\n  /* LABEL */\n  \"for\": 'htmlFor',\n\n  /* INPUT */\n  readonly: 'readOnly',\n  maxlength: 'maxLength',\n  tabindex: 'tabIndex',\n\n  /* TABLE */\n  colspan: 'colSpan',\n  rowspan: 'rowSpan',\n\n  /* IMAGE */\n  usemap: 'useMap'\n};\n\nfunction attempt(fn, arg) {\n  try {\n    return fn(arg);\n  } catch (_a) {\n    return arg;\n  }\n}\n\nvar doc = document,\n    win = window,\n    docEle = doc.documentElement,\n    createElement = doc.createElement.bind(doc),\n    div = createElement('div'),\n    table = createElement('table'),\n    tbody = createElement('tbody'),\n    tr = createElement('tr'),\n    isArray = Array.isArray,\n    ArrayPrototype = Array.prototype,\n    concat = ArrayPrototype.concat,\n    filter = ArrayPrototype.filter,\n    indexOf = ArrayPrototype.indexOf,\n    map = ArrayPrototype.map,\n    push = ArrayPrototype.push,\n    slice = ArrayPrototype.slice,\n    some = ArrayPrototype.some,\n    splice = ArrayPrototype.splice;\nvar idRe = /^#(?:[\\w-]|\\\\.|[^\\x00-\\xa0])*$/,\n    classRe = /^\\.(?:[\\w-]|\\\\.|[^\\x00-\\xa0])*$/,\n    htmlRe = /<.+>/,\n    tagRe = /^\\w+$/; // @require ./variables.ts\n\nfunction find(selector, context) {\n  return !selector || !isDocument(context) && !isElement(context) ? [] : classRe.test(selector) ? context.getElementsByClassName(selector.slice(1)) : tagRe.test(selector) ? context.getElementsByTagName(selector) : context.querySelectorAll(selector);\n} // @require ./find.ts\n// @require ./variables.ts\n\n\nvar Cash =\n/** @class */\nfunction () {\n  function Cash(selector, context) {\n    if (!selector) return;\n    if (isCash(selector)) return selector;\n    var eles = selector;\n\n    if (isString(selector)) {\n      var ctx = (isCash(context) ? context[0] : context) || doc;\n      eles = idRe.test(selector) ? ctx.getElementById(selector.slice(1)) : htmlRe.test(selector) ? parseHTML(selector) : find(selector, ctx);\n      if (!eles) return;\n    } else if (isFunction(selector)) {\n      return this.ready(selector); //FIXME: `fn.ready` is not included in `core`, but it's actually a core functionality\n    }\n\n    if (eles.nodeType || eles === win) eles = [eles];\n    this.length = eles.length;\n\n    for (var i = 0, l = this.length; i < l; i++) {\n      this[i] = eles[i];\n    }\n  }\n\n  Cash.prototype.init = function (selector, context) {\n    return new Cash(selector, context);\n  };\n\n  return Cash;\n}();\n\nvar fn = Cash.prototype,\n    cash = fn.init;\ncash.fn = cash.prototype = fn; // Ensuring that `cash () instanceof cash`\n\nfn.length = 0;\nfn.splice = splice; // Ensuring a cash collection gets printed as array-like in Chrome's devtools\n\nif (typeof Symbol === 'function') {\n  // Ensuring a cash collection is iterable\n  fn[Symbol['iterator']] = ArrayPrototype[Symbol['iterator']];\n}\n\nfn.map = function (callback) {\n  return cash(concat.apply([], map.call(this, function (ele, i) {\n    return callback.call(ele, i, ele);\n  })));\n};\n\nfn.slice = function (start, end) {\n  return cash(slice.call(this, start, end));\n}; // @require ./cash.ts\n\n\nvar dashAlphaRe = /-([a-z])/g;\n\nfunction camelCase(str) {\n  return str.replace(dashAlphaRe, function (match, letter) {\n    return letter.toUpperCase();\n  });\n}\n\ncash.guid = 1; // @require ./cash.ts\n\nfunction matches(ele, selector) {\n  var matches = ele && (ele['matches'] || ele['webkitMatchesSelector'] || ele['msMatchesSelector']);\n  return !!matches && !!selector && matches.call(ele, selector);\n}\n\nfunction isCash(x) {\n  return x instanceof Cash;\n}\n\nfunction isWindow(x) {\n  return !!x && x === x.window;\n}\n\nfunction isDocument(x) {\n  return !!x && x.nodeType === 9;\n}\n\nfunction isElement(x) {\n  return !!x && x.nodeType === 1;\n}\n\nfunction isBoolean(x) {\n  return typeof x === 'boolean';\n}\n\nfunction isFunction(x) {\n  return typeof x === 'function';\n}\n\nfunction isString(x) {\n  return typeof x === 'string';\n}\n\nfunction isUndefined(x) {\n  return x === undefined;\n}\n\nfunction isNull(x) {\n  return x === null;\n}\n\nfunction isNumeric(x) {\n  return !isNaN(parseFloat(x)) && isFinite(x);\n}\n\nfunction isPlainObject(x) {\n  if (typeof x !== 'object' || x === null) return false;\n  var proto = Object.getPrototypeOf(x);\n  return proto === null || proto === Object.prototype;\n}\n\ncash.isWindow = isWindow;\ncash.isFunction = isFunction;\ncash.isArray = isArray;\ncash.isNumeric = isNumeric;\ncash.isPlainObject = isPlainObject;\n\nfn.get = function (index) {\n  if (isUndefined(index)) return slice.call(this);\n  index = Number(index);\n  return this[index < 0 ? index + this.length : index];\n};\n\nfn.eq = function (index) {\n  return cash(this.get(index));\n};\n\nfn.first = function () {\n  return this.eq(0);\n};\n\nfn.last = function () {\n  return this.eq(-1);\n};\n\nfunction each(arr, callback, _reverse) {\n  if (_reverse) {\n    var i = arr.length;\n\n    while (i--) {\n      if (callback.call(arr[i], i, arr[i]) === false) return arr;\n    }\n  } else if (isPlainObject(arr)) {\n    var keys = Object.keys(arr);\n\n    for (var i = 0, l = keys.length; i < l; i++) {\n      var key = keys[i];\n      if (callback.call(arr[key], key, arr[key]) === false) return arr;\n    }\n  } else {\n    for (var i = 0, l = arr.length; i < l; i++) {\n      if (callback.call(arr[i], i, arr[i]) === false) return arr;\n    }\n  }\n\n  return arr;\n}\n\ncash.each = each;\n\nfn.each = function (callback) {\n  return each(this, callback);\n};\n\nfn.prop = function (prop, value) {\n  if (!prop) return;\n\n  if (isString(prop)) {\n    prop = propMap[prop] || prop;\n    if (arguments.length < 2) return this[0] && this[0][prop];\n    return this.each(function (i, ele) {\n      ele[prop] = value;\n    });\n  }\n\n  for (var key in prop) {\n    this.prop(key, prop[key]);\n  }\n\n  return this;\n};\n\nfn.removeProp = function (prop) {\n  return this.each(function (i, ele) {\n    delete ele[propMap[prop] || prop];\n  });\n};\n\nfunction extend() {\n  var sources = [];\n\n  for (var _i = 0; _i < arguments.length; _i++) {\n    sources[_i] = arguments[_i];\n  }\n\n  var deep = isBoolean(sources[0]) ? sources.shift() : false,\n      target = sources.shift(),\n      length = sources.length;\n  if (!target) return {};\n  if (!length) return extend(deep, cash, target);\n\n  for (var i = 0; i < length; i++) {\n    var source = sources[i];\n\n    for (var key in source) {\n      if (deep && (isArray(source[key]) || isPlainObject(source[key]))) {\n        if (!target[key] || target[key].constructor !== source[key].constructor) target[key] = new source[key].constructor();\n        extend(deep, target[key], source[key]);\n      } else {\n        target[key] = source[key];\n      }\n    }\n  }\n\n  return target;\n}\n\ncash.extend = extend;\n\nfn.extend = function (plugins) {\n  return extend(fn, plugins);\n}; // @require ./matches.ts\n// @require ./type_checking.ts\n\n\nfunction getCompareFunction(comparator) {\n  return isString(comparator) ? function (i, ele) {\n    return matches(ele, comparator);\n  } : isFunction(comparator) ? comparator : isCash(comparator) ? function (i, ele) {\n    return comparator.is(ele);\n  } : !comparator ? function () {\n    return false;\n  } : function (i, ele) {\n    return ele === comparator;\n  };\n}\n\nfn.filter = function (comparator) {\n  var compare = getCompareFunction(comparator);\n  return cash(filter.call(this, function (ele, i) {\n    return compare.call(ele, i, ele);\n  }));\n}; // @require collection/filter.ts\n\n\nfunction filtered(collection, comparator) {\n  return !comparator ? collection : collection.filter(comparator);\n} // @require ./type_checking.ts\n\n\nvar splitValuesRe = /\\S+/g;\n\nfunction getSplitValues(str) {\n  return isString(str) ? str.match(splitValuesRe) || [] : [];\n}\n\nfn.hasClass = function (cls) {\n  return !!cls && some.call(this, function (ele) {\n    return isElement(ele) && ele.classList.contains(cls);\n  });\n};\n\nfn.removeAttr = function (attr) {\n  var attrs = getSplitValues(attr);\n  return this.each(function (i, ele) {\n    if (!isElement(ele)) return;\n    each(attrs, function (i, a) {\n      ele.removeAttribute(a);\n    });\n  });\n};\n\nfunction attr(attr, value) {\n  if (!attr) return;\n\n  if (isString(attr)) {\n    if (arguments.length < 2) {\n      if (!this[0] || !isElement(this[0])) return;\n      var value_1 = this[0].getAttribute(attr);\n      return isNull(value_1) ? undefined : value_1;\n    }\n\n    if (isUndefined(value)) return this;\n    if (isNull(value)) return this.removeAttr(attr);\n    return this.each(function (i, ele) {\n      if (!isElement(ele)) return;\n      ele.setAttribute(attr, value);\n    });\n  }\n\n  for (var key in attr) {\n    this.attr(key, attr[key]);\n  }\n\n  return this;\n}\n\nfn.attr = attr;\n\nfn.toggleClass = function (cls, force) {\n  var classes = getSplitValues(cls),\n      isForce = !isUndefined(force);\n  return this.each(function (i, ele) {\n    if (!isElement(ele)) return;\n    each(classes, function (i, c) {\n      if (isForce) {\n        force ? ele.classList.add(c) : ele.classList.remove(c);\n      } else {\n        ele.classList.toggle(c);\n      }\n    });\n  });\n};\n\nfn.addClass = function (cls) {\n  return this.toggleClass(cls, true);\n};\n\nfn.removeClass = function (cls) {\n  if (arguments.length) return this.toggleClass(cls, false);\n  return this.attr('class', '');\n};\n\nfunction pluck(arr, prop, deep, until) {\n  var plucked = [],\n      isCallback = isFunction(prop),\n      compare = until && getCompareFunction(until);\n\n  for (var i = 0, l = arr.length; i < l; i++) {\n    if (isCallback) {\n      var val_1 = prop(arr[i]);\n      if (val_1.length) push.apply(plucked, val_1);\n    } else {\n      var val_2 = arr[i][prop];\n\n      while (val_2 != null) {\n        if (until && compare(-1, val_2)) break;\n        plucked.push(val_2);\n        val_2 = deep ? val_2[prop] : null;\n      }\n    }\n  }\n\n  return plucked;\n}\n\nfunction unique(arr) {\n  return arr.length > 1 ? filter.call(arr, function (item, index, self) {\n    return indexOf.call(self, item) === index;\n  }) : arr;\n}\n\ncash.unique = unique;\n\nfn.add = function (selector, context) {\n  return cash(unique(this.get().concat(cash(selector, context).get())));\n}; // @require core/type_checking.ts\n// @require core/variables.ts\n\n\nfunction computeStyle(ele, prop, isVariable) {\n  if (!isElement(ele)) return;\n  var style = win.getComputedStyle(ele, null);\n  return isVariable ? style.getPropertyValue(prop) || undefined : style[prop] || ele.style[prop];\n} // @require ./compute_style.ts\n\n\nfunction computeStyleInt(ele, prop) {\n  return parseInt(computeStyle(ele, prop), 10) || 0;\n}\n\nvar cssVariableRe = /^--/; // @require ./variables.ts\n\nfunction isCSSVariable(prop) {\n  return cssVariableRe.test(prop);\n} // @require core/camel_case.ts\n// @require core/cash.ts\n// @require core/each.ts\n// @require core/variables.ts\n// @require ./is_css_variable.ts\n\n\nvar prefixedProps = {},\n    style = div.style,\n    vendorsPrefixes = ['webkit', 'moz', 'ms'];\n\nfunction getPrefixedProp(prop, isVariable) {\n  if (isVariable === void 0) {\n    isVariable = isCSSVariable(prop);\n  }\n\n  if (isVariable) return prop;\n\n  if (!prefixedProps[prop]) {\n    var propCC = camelCase(prop),\n        propUC = \"\" + propCC[0].toUpperCase() + propCC.slice(1),\n        props = (propCC + \" \" + vendorsPrefixes.join(propUC + \" \") + propUC).split(' ');\n    each(props, function (i, p) {\n      if (p in style) {\n        prefixedProps[prop] = p;\n        return false;\n      }\n    });\n  }\n\n  return prefixedProps[prop];\n}\n\n; // @require core/type_checking.ts\n// @require ./is_css_variable.ts\n\nvar numericProps = {\n  animationIterationCount: true,\n  columnCount: true,\n  flexGrow: true,\n  flexShrink: true,\n  fontWeight: true,\n  gridArea: true,\n  gridColumn: true,\n  gridColumnEnd: true,\n  gridColumnStart: true,\n  gridRow: true,\n  gridRowEnd: true,\n  gridRowStart: true,\n  lineHeight: true,\n  opacity: true,\n  order: true,\n  orphans: true,\n  widows: true,\n  zIndex: true\n};\n\nfunction getSuffixedValue(prop, value, isVariable) {\n  if (isVariable === void 0) {\n    isVariable = isCSSVariable(prop);\n  }\n\n  return !isVariable && !numericProps[prop] && isNumeric(value) ? value + \"px\" : value;\n}\n\nfunction css(prop, value) {\n  if (isString(prop)) {\n    var isVariable_1 = isCSSVariable(prop);\n    prop = getPrefixedProp(prop, isVariable_1);\n    if (arguments.length < 2) return this[0] && computeStyle(this[0], prop, isVariable_1);\n    if (!prop) return this;\n    value = getSuffixedValue(prop, value, isVariable_1);\n    return this.each(function (i, ele) {\n      if (!isElement(ele)) return;\n\n      if (isVariable_1) {\n        ele.style.setProperty(prop, value);\n      } else {\n        ele.style[prop] = value;\n      }\n    });\n  }\n\n  for (var key in prop) {\n    this.css(key, prop[key]);\n  }\n\n  return this;\n}\n\n;\nfn.css = css; // @optional ./css.ts\n// @require core/attempt.ts\n// @require core/camel_case.ts\n\nvar JSONStringRe = /^\\s+|\\s+$/;\n\nfunction getData(ele, key) {\n  var value = ele.dataset[key] || ele.dataset[camelCase(key)];\n  if (JSONStringRe.test(value)) return value;\n  return attempt(JSON.parse, value);\n} // @require core/attempt.ts\n// @require core/camel_case.ts\n\n\nfunction setData(ele, key, value) {\n  value = attempt(JSON.stringify, value);\n  ele.dataset[camelCase(key)] = value;\n}\n\nfunction data(name, value) {\n  if (!name) {\n    if (!this[0]) return;\n    var datas = {};\n\n    for (var key in this[0].dataset) {\n      datas[key] = getData(this[0], key);\n    }\n\n    return datas;\n  }\n\n  if (isString(name)) {\n    if (arguments.length < 2) return this[0] && getData(this[0], name);\n    if (isUndefined(value)) return this;\n    return this.each(function (i, ele) {\n      setData(ele, name, value);\n    });\n  }\n\n  for (var key in name) {\n    this.data(key, name[key]);\n  }\n\n  return this;\n}\n\nfn.data = data; // @optional ./data.ts\n\nfunction getDocumentDimension(doc, dimension) {\n  var docEle = doc.documentElement;\n  return Math.max(doc.body[\"scroll\" + dimension], docEle[\"scroll\" + dimension], doc.body[\"offset\" + dimension], docEle[\"offset\" + dimension], docEle[\"client\" + dimension]);\n} // @require css/helpers/compute_style_int.ts\n\n\nfunction getExtraSpace(ele, xAxis) {\n  return computeStyleInt(ele, \"border\" + (xAxis ? 'Left' : 'Top') + \"Width\") + computeStyleInt(ele, \"padding\" + (xAxis ? 'Left' : 'Top')) + computeStyleInt(ele, \"padding\" + (xAxis ? 'Right' : 'Bottom')) + computeStyleInt(ele, \"border\" + (xAxis ? 'Right' : 'Bottom') + \"Width\");\n}\n\neach([true, false], function (i, outer) {\n  each(['Width', 'Height'], function (i, prop) {\n    var name = \"\" + (outer ? 'outer' : 'inner') + prop;\n\n    fn[name] = function (includeMargins) {\n      if (!this[0]) return;\n      if (isWindow(this[0])) return outer ? this[0][\"inner\" + prop] : this[0].document.documentElement[\"client\" + prop];\n      if (isDocument(this[0])) return getDocumentDimension(this[0], prop);\n      return this[0][\"\" + (outer ? 'offset' : 'client') + prop] + (includeMargins && outer ? computeStyleInt(this[0], \"margin\" + (i ? 'Top' : 'Left')) + computeStyleInt(this[0], \"margin\" + (i ? 'Bottom' : 'Right')) : 0);\n    };\n  });\n});\neach(['Width', 'Height'], function (index, prop) {\n  var propLC = prop.toLowerCase();\n\n  fn[propLC] = function (value) {\n    if (!this[0]) return isUndefined(value) ? undefined : this;\n\n    if (!arguments.length) {\n      if (isWindow(this[0])) return this[0].document.documentElement[\"client\" + prop];\n      if (isDocument(this[0])) return getDocumentDimension(this[0], prop);\n      return this[0].getBoundingClientRect()[propLC] - getExtraSpace(this[0], !index);\n    }\n\n    var valueNumber = parseInt(value, 10);\n    return this.each(function (i, ele) {\n      if (!isElement(ele)) return;\n      var boxSizing = computeStyle(ele, 'boxSizing');\n      ele.style[propLC] = getSuffixedValue(propLC, valueNumber + (boxSizing === 'border-box' ? getExtraSpace(ele, !index) : 0));\n    });\n  };\n}); // @optional ./inner_outer.ts\n// @optional ./normal.ts\n// @require css/helpers/compute_style.ts\n\nvar defaultDisplay = {};\n\nfunction getDefaultDisplay(tagName) {\n  if (defaultDisplay[tagName]) return defaultDisplay[tagName];\n  var ele = createElement(tagName);\n  doc.body.insertBefore(ele, null);\n  var display = computeStyle(ele, 'display');\n  doc.body.removeChild(ele);\n  return defaultDisplay[tagName] = display !== 'none' ? display : 'block';\n} // @require css/helpers/compute_style.ts\n\n\nfunction isHidden(ele) {\n  return computeStyle(ele, 'display') === 'none';\n}\n\nvar displayProperty = '___cd';\n\nfn.toggle = function (force) {\n  return this.each(function (i, ele) {\n    if (!isElement(ele)) return;\n    var show = isUndefined(force) ? isHidden(ele) : force;\n\n    if (show) {\n      ele.style.display = ele[displayProperty] || '';\n\n      if (isHidden(ele)) {\n        ele.style.display = getDefaultDisplay(ele.tagName);\n      }\n    } else {\n      ele[displayProperty] = computeStyle(ele, 'display');\n      ele.style.display = 'none';\n    }\n  });\n};\n\nfn.hide = function () {\n  return this.toggle(false);\n};\n\nfn.show = function () {\n  return this.toggle(true);\n}; // @optional ./hide.ts\n// @optional ./show.ts\n// @optional ./toggle.ts\n\n\nfunction hasNamespaces(ns1, ns2) {\n  return !ns2 || !some.call(ns2, function (ns) {\n    return ns1.indexOf(ns) < 0;\n  });\n}\n\nvar eventsNamespace = '___ce',\n    eventsNamespacesSeparator = '.',\n    eventsFocus = {\n  focus: 'focusin',\n  blur: 'focusout'\n},\n    eventsHover = {\n  mouseenter: 'mouseover',\n  mouseleave: 'mouseout'\n},\n    eventsMouseRe = /^(mouse|pointer|contextmenu|drag|drop|click|dblclick)/i; // @require ./variables.ts\n\nfunction getEventNameBubbling(name) {\n  return eventsHover[name] || eventsFocus[name] || name;\n} // @require ./variables.ts\n\n\nfunction getEventsCache(ele) {\n  return ele[eventsNamespace] = ele[eventsNamespace] || {};\n} // @require core/guid.ts\n// @require events/helpers/get_events_cache.ts\n\n\nfunction addEvent(ele, name, namespaces, selector, callback) {\n  var eventCache = getEventsCache(ele);\n  eventCache[name] = eventCache[name] || [];\n  eventCache[name].push([namespaces, selector, callback]);\n  ele.addEventListener(name, callback);\n} // @require ./variables.ts\n\n\nfunction parseEventName(eventName) {\n  var parts = eventName.split(eventsNamespacesSeparator);\n  return [parts[0], parts.slice(1).sort()]; // [name, namespace[]]\n} // @require ./get_events_cache.ts\n// @require ./has_namespaces.ts\n// @require ./parse_event_name.ts\n\n\nfunction removeEvent(ele, name, namespaces, selector, callback) {\n  var cache = getEventsCache(ele);\n\n  if (!name) {\n    for (name in cache) {\n      removeEvent(ele, name, namespaces, selector, callback);\n    }\n  } else if (cache[name]) {\n    cache[name] = cache[name].filter(function (_a) {\n      var ns = _a[0],\n          sel = _a[1],\n          cb = _a[2];\n      if (callback && cb.guid !== callback.guid || !hasNamespaces(ns, namespaces) || selector && selector !== sel) return true;\n      ele.removeEventListener(name, cb);\n    });\n  }\n}\n\nfn.off = function (eventFullName, selector, callback) {\n  var _this = this;\n\n  if (isUndefined(eventFullName)) {\n    this.each(function (i, ele) {\n      if (!isElement(ele) && !isDocument(ele) && !isWindow(ele)) return;\n      removeEvent(ele);\n    });\n  } else if (!isString(eventFullName)) {\n    for (var key in eventFullName) {\n      this.off(key, eventFullName[key]);\n    }\n  } else {\n    if (isFunction(selector)) {\n      callback = selector;\n      selector = '';\n    }\n\n    each(getSplitValues(eventFullName), function (i, eventFullName) {\n      var _a = parseEventName(eventFullName),\n          nameOriginal = _a[0],\n          namespaces = _a[1],\n          name = getEventNameBubbling(nameOriginal);\n\n      _this.each(function (i, ele) {\n        if (!isElement(ele) && !isDocument(ele) && !isWindow(ele)) return;\n        removeEvent(ele, name, namespaces, selector, callback);\n      });\n    });\n  }\n\n  return this;\n};\n\nfunction on(eventFullName, selector, data, callback, _one) {\n  var _this = this;\n\n  if (!isString(eventFullName)) {\n    for (var key in eventFullName) {\n      this.on(key, selector, data, eventFullName[key], _one);\n    }\n\n    return this;\n  }\n\n  if (!isString(selector)) {\n    if (isUndefined(selector) || isNull(selector)) {\n      selector = '';\n    } else if (isUndefined(data)) {\n      data = selector;\n      selector = '';\n    } else {\n      callback = data;\n      data = selector;\n      selector = '';\n    }\n  }\n\n  if (!isFunction(callback)) {\n    callback = data;\n    data = undefined;\n  }\n\n  if (!callback) return this;\n  each(getSplitValues(eventFullName), function (i, eventFullName) {\n    var _a = parseEventName(eventFullName),\n        nameOriginal = _a[0],\n        namespaces = _a[1],\n        name = getEventNameBubbling(nameOriginal),\n        isEventHover = nameOriginal in eventsHover,\n        isEventFocus = nameOriginal in eventsFocus;\n\n    if (!name) return;\n\n    _this.each(function (i, ele) {\n      if (!isElement(ele) && !isDocument(ele) && !isWindow(ele)) return;\n\n      var finalCallback = function finalCallback(event) {\n        if (event.target[\"___i\" + event.type]) return event.stopImmediatePropagation(); // Ignoring native event in favor of the upcoming custom one\n\n        if (event.namespace && !hasNamespaces(namespaces, event.namespace.split(eventsNamespacesSeparator))) return;\n        if (!selector && (isEventFocus && (event.target !== ele || event.___ot === name) || isEventHover && event.relatedTarget && ele.contains(event.relatedTarget))) return;\n        var thisArg = ele;\n\n        if (selector) {\n          var target = event.target;\n\n          while (!matches(target, selector)) {\n            if (target === ele) return;\n            target = target.parentNode;\n            if (!target) return;\n          }\n\n          thisArg = target;\n          event.___cd = true; // Delegate\n        }\n\n        if (event.___cd) {\n          Object.defineProperty(event, 'currentTarget', {\n            configurable: true,\n            get: function get() {\n              return thisArg;\n            }\n          });\n        }\n\n        Object.defineProperty(event, 'data', {\n          configurable: true,\n          get: function get() {\n            return data;\n          }\n        });\n        var returnValue = callback.call(thisArg, event, event.___td);\n\n        if (_one) {\n          removeEvent(ele, name, namespaces, selector, finalCallback);\n        }\n\n        if (returnValue === false) {\n          event.preventDefault();\n          event.stopPropagation();\n        }\n      };\n\n      finalCallback.guid = callback.guid = callback.guid || cash.guid++;\n      addEvent(ele, name, namespaces, selector, finalCallback);\n    });\n  });\n  return this;\n}\n\nfn.on = on;\n\nfunction one(eventFullName, selector, data, callback) {\n  return this.on(eventFullName, selector, data, callback, true);\n}\n\n;\nfn.one = one;\n\nfn.ready = function (callback) {\n  var cb = function cb() {\n    return setTimeout(callback, 0, cash);\n  };\n\n  if (doc.readyState !== 'loading') {\n    cb();\n  } else {\n    doc.addEventListener('DOMContentLoaded', cb);\n  }\n\n  return this;\n};\n\nfn.trigger = function (event, data) {\n  if (isString(event)) {\n    var _a = parseEventName(event),\n        nameOriginal = _a[0],\n        namespaces = _a[1],\n        name_1 = getEventNameBubbling(nameOriginal);\n\n    if (!name_1) return this;\n    var type = eventsMouseRe.test(name_1) ? 'MouseEvents' : 'HTMLEvents';\n    event = doc.createEvent(type);\n    event.initEvent(name_1, true, true);\n    event.namespace = namespaces.join(eventsNamespacesSeparator);\n    event.___ot = nameOriginal;\n  }\n\n  event.___td = data;\n  var isEventFocus = event.___ot in eventsFocus;\n  return this.each(function (i, ele) {\n    if (isEventFocus && isFunction(ele[event.___ot])) {\n      ele[\"___i\" + event.type] = true; // Ensuring the native event is ignored\n\n      ele[event.___ot]();\n\n      ele[\"___i\" + event.type] = false; // Ensuring the custom event is not ignored\n    }\n\n    ele.dispatchEvent(event);\n  });\n}; // @optional ./off.ts\n// @optional ./on.ts\n// @optional ./one.ts\n// @optional ./ready.ts\n// @optional ./trigger.ts\n// @require core/pluck.ts\n// @require core/variables.ts\n\n\nfunction getValue(ele) {\n  if (ele.multiple && ele.options) return pluck(filter.call(ele.options, function (option) {\n    return option.selected && !option.disabled && !option.parentNode.disabled;\n  }), 'value');\n  return ele.value || '';\n}\n\nvar queryEncodeSpaceRe = /%20/g,\n    queryEncodeCRLFRe = /\\r?\\n/g;\n\nfunction queryEncode(prop, value) {\n  return \"&\" + encodeURIComponent(prop) + \"=\" + encodeURIComponent(value.replace(queryEncodeCRLFRe, '\\r\\n')).replace(queryEncodeSpaceRe, '+');\n}\n\nvar skippableRe = /file|reset|submit|button|image/i,\n    checkableRe = /radio|checkbox/i;\n\nfn.serialize = function () {\n  var query = '';\n  this.each(function (i, ele) {\n    each(ele.elements || [ele], function (i, ele) {\n      if (ele.disabled || !ele.name || ele.tagName === 'FIELDSET' || skippableRe.test(ele.type) || checkableRe.test(ele.type) && !ele.checked) return;\n      var value = getValue(ele);\n\n      if (!isUndefined(value)) {\n        var values = isArray(value) ? value : [value];\n        each(values, function (i, value) {\n          query += queryEncode(ele.name, value);\n        });\n      }\n    });\n  });\n  return query.slice(1);\n};\n\nfunction val(value) {\n  if (!arguments.length) return this[0] && getValue(this[0]);\n  return this.each(function (i, ele) {\n    var isSelect = ele.multiple && ele.options;\n\n    if (isSelect || checkableRe.test(ele.type)) {\n      var eleValue_1 = isArray(value) ? map.call(value, String) : isNull(value) ? [] : [String(value)];\n\n      if (isSelect) {\n        each(ele.options, function (i, option) {\n          option.selected = eleValue_1.indexOf(option.value) >= 0;\n        }, true);\n      } else {\n        ele.checked = eleValue_1.indexOf(ele.value) >= 0;\n      }\n    } else {\n      ele.value = isUndefined(value) || isNull(value) ? '' : value;\n    }\n  });\n}\n\nfn.val = val;\n\nfn.clone = function () {\n  return this.map(function (i, ele) {\n    return ele.cloneNode(true);\n  });\n};\n\nfn.detach = function (comparator) {\n  filtered(this, comparator).each(function (i, ele) {\n    if (ele.parentNode) {\n      ele.parentNode.removeChild(ele);\n    }\n  });\n  return this;\n};\n\nvar fragmentRe = /^\\s*<(\\w+)[^>]*>/,\n    singleTagRe = /^<(\\w+)\\s*\\/?>(?:<\\/\\1>)?$/;\nvar containers = {\n  '*': div,\n  tr: tbody,\n  td: tr,\n  th: tr,\n  thead: table,\n  tbody: table,\n  tfoot: table\n}; //TODO: Create elements inside a document fragment, in order to prevent inline event handlers from firing\n//TODO: Ensure the created elements have the fragment as their parent instead of null, this also ensures we can deal with detatched nodes more reliably\n\nfunction parseHTML(html) {\n  if (!isString(html)) return [];\n  if (singleTagRe.test(html)) return [createElement(RegExp.$1)];\n  var fragment = fragmentRe.test(html) && RegExp.$1,\n      container = containers[fragment] || containers['*'];\n  container.innerHTML = html;\n  return cash(container.childNodes).detach().get();\n}\n\ncash.parseHTML = parseHTML;\n\nfn.empty = function () {\n  return this.each(function (i, ele) {\n    while (ele.firstChild) {\n      ele.removeChild(ele.firstChild);\n    }\n  });\n};\n\nfunction html(html) {\n  if (!arguments.length) return this[0] && this[0].innerHTML;\n  if (isUndefined(html)) return this;\n  return this.each(function (i, ele) {\n    if (!isElement(ele)) return;\n    ele.innerHTML = html;\n  });\n}\n\nfn.html = html;\n\nfn.remove = function (comparator) {\n  filtered(this, comparator).detach().off();\n  return this;\n};\n\nfunction text(text) {\n  if (isUndefined(text)) return this[0] ? this[0].textContent : '';\n  return this.each(function (i, ele) {\n    if (!isElement(ele)) return;\n    ele.textContent = text;\n  });\n}\n\n;\nfn.text = text;\n\nfn.unwrap = function () {\n  this.parent().each(function (i, ele) {\n    if (ele.tagName === 'BODY') return;\n    var $ele = cash(ele);\n    $ele.replaceWith($ele.children());\n  });\n  return this;\n};\n\nfn.offset = function () {\n  var ele = this[0];\n  if (!ele) return;\n  var rect = ele.getBoundingClientRect();\n  return {\n    top: rect.top + win.pageYOffset,\n    left: rect.left + win.pageXOffset\n  };\n};\n\nfn.offsetParent = function () {\n  return this.map(function (i, ele) {\n    var offsetParent = ele.offsetParent;\n\n    while (offsetParent && computeStyle(offsetParent, 'position') === 'static') {\n      offsetParent = offsetParent.offsetParent;\n    }\n\n    return offsetParent || docEle;\n  });\n};\n\nfn.position = function () {\n  var ele = this[0];\n  if (!ele) return;\n  var isFixed = computeStyle(ele, 'position') === 'fixed',\n      offset = isFixed ? ele.getBoundingClientRect() : this.offset();\n\n  if (!isFixed) {\n    var doc_1 = ele.ownerDocument;\n    var offsetParent = ele.offsetParent || doc_1.documentElement;\n\n    while ((offsetParent === doc_1.body || offsetParent === doc_1.documentElement) && computeStyle(offsetParent, 'position') === 'static') {\n      offsetParent = offsetParent.parentNode;\n    }\n\n    if (offsetParent !== ele && isElement(offsetParent)) {\n      var parentOffset = cash(offsetParent).offset();\n      offset.top -= parentOffset.top + computeStyleInt(offsetParent, 'borderTopWidth');\n      offset.left -= parentOffset.left + computeStyleInt(offsetParent, 'borderLeftWidth');\n    }\n  }\n\n  return {\n    top: offset.top - computeStyleInt(ele, 'marginTop'),\n    left: offset.left - computeStyleInt(ele, 'marginLeft')\n  };\n};\n\nfn.children = function (comparator) {\n  return filtered(cash(unique(pluck(this, function (ele) {\n    return ele.children;\n  }))), comparator);\n};\n\nfn.contents = function () {\n  return cash(unique(pluck(this, function (ele) {\n    return ele.tagName === 'IFRAME' ? [ele.contentDocument] : ele.tagName === 'TEMPLATE' ? ele.content.childNodes : ele.childNodes;\n  })));\n};\n\nfn.find = function (selector) {\n  return cash(unique(pluck(this, function (ele) {\n    return find(selector, ele);\n  })));\n}; // @require core/variables.ts\n// @require collection/filter.ts\n// @require traversal/find.ts\n\n\nvar HTMLCDATARe = /^\\s*<!(?:\\[CDATA\\[|--)|(?:\\]\\]|--)>\\s*$/g,\n    scriptTypeRe = /^$|^module$|\\/(java|ecma)script/i,\n    scriptAttributes = ['type', 'src', 'nonce', 'noModule'];\n\nfunction evalScripts(node, doc) {\n  var collection = cash(node);\n  collection.filter('script').add(collection.find('script')).each(function (i, ele) {\n    if (scriptTypeRe.test(ele.type) && docEle.contains(ele)) {\n      // The script type is supported // The element is attached to the DOM // Using `documentElement` for broader browser support\n      var script_1 = createElement('script');\n      script_1.text = ele.textContent.replace(HTMLCDATARe, '');\n      each(scriptAttributes, function (i, attr) {\n        if (ele[attr]) script_1[attr] = ele[attr];\n      });\n      doc.head.insertBefore(script_1, null);\n      doc.head.removeChild(script_1);\n    }\n  });\n} // @require ./eval_scripts.ts\n\n\nfunction insertElement(anchor, target, left, inside, evaluate) {\n  if (inside) {\n    // prepend/append\n    anchor.insertBefore(target, left ? anchor.firstChild : null);\n  } else {\n    // before/after\n    anchor.parentNode.insertBefore(target, left ? anchor : anchor.nextSibling);\n  }\n\n  if (evaluate) {\n    evalScripts(target, anchor.ownerDocument);\n  }\n} // @require ./insert_element.ts\n\n\nfunction insertSelectors(selectors, anchors, inverse, left, inside, reverseLoop1, reverseLoop2, reverseLoop3) {\n  each(selectors, function (si, selector) {\n    each(cash(selector), function (ti, target) {\n      each(cash(anchors), function (ai, anchor) {\n        var anchorFinal = inverse ? target : anchor,\n            targetFinal = inverse ? anchor : target,\n            indexFinal = inverse ? ti : ai;\n        insertElement(anchorFinal, !indexFinal ? targetFinal : targetFinal.cloneNode(true), left, inside, !indexFinal);\n      }, reverseLoop3);\n    }, reverseLoop2);\n  }, reverseLoop1);\n  return anchors;\n}\n\nfn.after = function () {\n  return insertSelectors(arguments, this, false, false, false, true, true);\n};\n\nfn.append = function () {\n  return insertSelectors(arguments, this, false, false, true);\n};\n\nfn.appendTo = function (selector) {\n  return insertSelectors(arguments, this, true, false, true);\n};\n\nfn.before = function () {\n  return insertSelectors(arguments, this, false, true);\n};\n\nfn.insertAfter = function (selector) {\n  return insertSelectors(arguments, this, true, false, false, false, false, true);\n};\n\nfn.insertBefore = function (selector) {\n  return insertSelectors(arguments, this, true, true);\n};\n\nfn.prepend = function () {\n  return insertSelectors(arguments, this, false, true, true, true, true);\n};\n\nfn.prependTo = function (selector) {\n  return insertSelectors(arguments, this, true, true, true, false, false, true);\n};\n\nfn.replaceWith = function (selector) {\n  return this.before(selector).remove();\n};\n\nfn.replaceAll = function (selector) {\n  cash(selector).replaceWith(this);\n  return this;\n};\n\nfn.wrapAll = function (selector) {\n  var structure = cash(selector),\n      wrapper = structure[0];\n\n  while (wrapper.children.length) {\n    wrapper = wrapper.firstElementChild;\n  }\n\n  this.first().before(structure);\n  return this.appendTo(wrapper);\n};\n\nfn.wrap = function (selector) {\n  return this.each(function (i, ele) {\n    var wrapper = cash(selector)[0];\n    cash(ele).wrapAll(!i ? wrapper : wrapper.cloneNode(true));\n  });\n};\n\nfn.wrapInner = function (selector) {\n  return this.each(function (i, ele) {\n    var $ele = cash(ele),\n        contents = $ele.contents();\n    contents.length ? contents.wrapAll(selector) : $ele.append(selector);\n  });\n};\n\nfn.has = function (selector) {\n  var comparator = isString(selector) ? function (i, ele) {\n    return find(selector, ele).length;\n  } : function (i, ele) {\n    return ele.contains(selector);\n  };\n  return this.filter(comparator);\n};\n\nfn.is = function (comparator) {\n  var compare = getCompareFunction(comparator);\n  return some.call(this, function (ele, i) {\n    return compare.call(ele, i, ele);\n  });\n};\n\nfn.next = function (comparator, _all, _until) {\n  return filtered(cash(unique(pluck(this, 'nextElementSibling', _all, _until))), comparator);\n};\n\nfn.nextAll = function (comparator) {\n  return this.next(comparator, true);\n};\n\nfn.nextUntil = function (until, comparator) {\n  return this.next(comparator, true, until);\n};\n\nfn.not = function (comparator) {\n  var compare = getCompareFunction(comparator);\n  return this.filter(function (i, ele) {\n    return (!isString(comparator) || isElement(ele)) && !compare.call(ele, i, ele);\n  });\n};\n\nfn.parent = function (comparator) {\n  return filtered(cash(unique(pluck(this, 'parentNode'))), comparator);\n};\n\nfn.index = function (selector) {\n  var child = selector ? cash(selector)[0] : this[0],\n      collection = selector ? this : cash(child).parent().children();\n  return indexOf.call(collection, child);\n};\n\nfn.closest = function (comparator) {\n  var filtered = this.filter(comparator);\n  if (filtered.length) return filtered;\n  var $parent = this.parent();\n  if (!$parent.length) return filtered;\n  return $parent.closest(comparator);\n};\n\nfn.parents = function (comparator, _until) {\n  return filtered(cash(unique(pluck(this, 'parentElement', true, _until))), comparator);\n};\n\nfn.parentsUntil = function (until, comparator) {\n  return this.parents(comparator, until);\n};\n\nfn.prev = function (comparator, _all, _until) {\n  return filtered(cash(unique(pluck(this, 'previousElementSibling', _all, _until))), comparator);\n};\n\nfn.prevAll = function (comparator) {\n  return this.prev(comparator, true);\n};\n\nfn.prevUntil = function (until, comparator) {\n  return this.prev(comparator, true, until);\n};\n\nfn.siblings = function (comparator) {\n  return filtered(cash(unique(pluck(this, function (ele) {\n    return cash(ele).parent().children().not(ele);\n  }))), comparator);\n}; // @optional ./children.ts\n// @optional ./closest.ts\n// @optional ./contents.ts\n// @optional ./find.ts\n// @optional ./has.ts\n// @optional ./is.ts\n// @optional ./next.ts\n// @optional ./next_all.ts\n// @optional ./next_until.ts\n// @optional ./not.ts\n// @optional ./parent.ts\n// @optional ./parents.ts\n// @optional ./parents_until.ts\n// @optional ./prev.ts\n// @optional ./prev_all.ts\n// @optional ./prev_until.ts\n// @optional ./siblings.ts\n// @optional attributes/index.ts\n// @optional collection/index.ts\n// @optional css/index.ts\n// @optional data/index.ts\n// @optional dimensions/index.ts\n// @optional effects/index.ts\n// @optional events/index.ts\n// @optional forms/index.ts\n// @optional manipulation/index.ts\n// @optional offset/index.ts\n// @optional traversal/index.ts\n// @require core/index.ts\n// @priority -100\n// @require ./cash.ts\n// @require ./variables.ts\n\n\nif (typeof exports !== 'undefined') {\n  // Node.js\n  module.exports = cash;\n} else {\n  // Browser\n  win['cash'] = win['$'] = cash;\n}\n})();","'use strict';\n\n(function () {\n  var out$ = typeof exports != 'undefined' && exports || typeof define != 'undefined' && {} || this || window;\n  if (typeof define !== 'undefined') define('save-svg-as-png', [], function () {\n    return out$;\n  });\n  out$.default = out$;\n\n  var xmlNs = 'http://www.w3.org/2000/xmlns/';\n  var xhtmlNs = 'http://www.w3.org/1999/xhtml';\n  var svgNs = 'http://www.w3.org/2000/svg';\n  var doctype = '<?xml version=\"1.0\" standalone=\"no\"?><!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\" \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\" [<!ENTITY nbsp \"&#160;\">]>';\n  var urlRegex = /url\\([\"']?(.+?)[\"']?\\)/;\n  var fontFormats = {\n    woff2: 'font/woff2',\n    woff: 'font/woff',\n    otf: 'application/x-font-opentype',\n    ttf: 'application/x-font-ttf',\n    eot: 'application/vnd.ms-fontobject',\n    sfnt: 'application/font-sfnt',\n    svg: 'image/svg+xml'\n  };\n\n  var isElement = function isElement(obj) {\n    return obj instanceof HTMLElement || obj instanceof SVGElement;\n  };\n  var requireDomNode = function requireDomNode(el) {\n    if (!isElement(el)) throw new Error('an HTMLElement or SVGElement is required; got ' + el);\n  };\n  var requireDomNodePromise = function requireDomNodePromise(el) {\n    return new Promise(function (resolve, reject) {\n      if (isElement(el)) resolve(el);else reject(new Error('an HTMLElement or SVGElement is required; got ' + el));\n    });\n  };\n  var isExternal = function isExternal(url) {\n    return url && url.lastIndexOf('http', 0) === 0 && url.lastIndexOf(window.location.host) === -1;\n  };\n\n  var getFontMimeTypeFromUrl = function getFontMimeTypeFromUrl(fontUrl) {\n    var formats = Object.keys(fontFormats).filter(function (extension) {\n      return fontUrl.indexOf('.' + extension) > 0;\n    }).map(function (extension) {\n      return fontFormats[extension];\n    });\n    if (formats) return formats[0];\n    console.error('Unknown font format for ' + fontUrl + '. Fonts may not be working correctly.');\n    return 'application/octet-stream';\n  };\n\n  var arrayBufferToBase64 = function arrayBufferToBase64(buffer) {\n    var binary = '';\n    var bytes = new Uint8Array(buffer);\n    for (var i = 0; i < bytes.byteLength; i++) {\n      binary += String.fromCharCode(bytes[i]);\n    }return window.btoa(binary);\n  };\n\n  var getDimension = function getDimension(el, clone, dim) {\n    var v = el.viewBox && el.viewBox.baseVal && el.viewBox.baseVal[dim] || clone.getAttribute(dim) !== null && !clone.getAttribute(dim).match(/%$/) && parseInt(clone.getAttribute(dim)) || el.getBoundingClientRect()[dim] || parseInt(clone.style[dim]) || parseInt(window.getComputedStyle(el).getPropertyValue(dim));\n    return typeof v === 'undefined' || v === null || isNaN(parseFloat(v)) ? 0 : v;\n  };\n\n  var getDimensions = function getDimensions(el, clone, width, height) {\n    if (el.tagName === 'svg') return {\n      width: width || getDimension(el, clone, 'width'),\n      height: height || getDimension(el, clone, 'height')\n    };else if (el.getBBox) {\n      var _el$getBBox = el.getBBox(),\n          x = _el$getBBox.x,\n          y = _el$getBBox.y,\n          _width = _el$getBBox.width,\n          _height = _el$getBBox.height;\n\n      return {\n        width: x + _width,\n        height: y + _height\n      };\n    }\n  };\n\n  var reEncode = function reEncode(data) {\n    return decodeURIComponent(encodeURIComponent(data).replace(/%([0-9A-F]{2})/g, function (match, p1) {\n      var c = String.fromCharCode('0x' + p1);\n      return c === '%' ? '%25' : c;\n    }));\n  };\n\n  var uriToBlob = function uriToBlob(uri) {\n    var byteString = window.atob(uri.split(',')[1]);\n    var mimeString = uri.split(',')[0].split(':')[1].split(';')[0];\n    var buffer = new ArrayBuffer(byteString.length);\n    var intArray = new Uint8Array(buffer);\n    for (var i = 0; i < byteString.length; i++) {\n      intArray[i] = byteString.charCodeAt(i);\n    }\n    return new Blob([buffer], { type: mimeString });\n  };\n\n  var query = function query(el, selector) {\n    if (!selector) return;\n    try {\n      return el.querySelector(selector) || el.parentNode && el.parentNode.querySelector(selector);\n    } catch (err) {\n      console.warn('Invalid CSS selector \"' + selector + '\"', err);\n    }\n  };\n\n  var detectCssFont = function detectCssFont(rule, href) {\n    // Match CSS font-face rules to external links.\n    // @font-face {\n    //   src: local('Abel'), url(https://fonts.gstatic.com/s/abel/v6/UzN-iejR1VoXU2Oc-7LsbvesZW2xOQ-xsNqO47m55DA.woff2);\n    // }\n    var match = rule.cssText.match(urlRegex);\n    var url = match && match[1] || '';\n    if (!url || url.match(/^data:/) || url === 'about:blank') return;\n    var fullUrl = url.startsWith('../') ? href + '/../' + url : url.startsWith('./') ? href + '/.' + url : url;\n    return {\n      text: rule.cssText,\n      format: getFontMimeTypeFromUrl(fullUrl),\n      url: fullUrl\n    };\n  };\n\n  var inlineImages = function inlineImages(el) {\n    return Promise.all(Array.from(el.querySelectorAll('image')).map(function (image) {\n      var href = image.getAttributeNS('http://www.w3.org/1999/xlink', 'href') || image.getAttribute('href');\n      if (!href) return Promise.resolve(null);\n      if (isExternal(href)) {\n        href += (href.indexOf('?') === -1 ? '?' : '&') + 't=' + new Date().valueOf();\n      }\n      return new Promise(function (resolve, reject) {\n        var canvas = document.createElement('canvas');\n        var img = new Image();\n        img.crossOrigin = 'anonymous';\n        img.src = href;\n        img.onerror = function () {\n          return reject(new Error('Could not load ' + href));\n        };\n        img.onload = function () {\n          canvas.width = img.width;\n          canvas.height = img.height;\n          canvas.getContext('2d').drawImage(img, 0, 0);\n          image.setAttributeNS('http://www.w3.org/1999/xlink', 'href', canvas.toDataURL('image/png'));\n          resolve(true);\n        };\n      });\n    }));\n  };\n\n  var cachedFonts = {};\n  var inlineFonts = function inlineFonts(fonts) {\n    return Promise.all(fonts.map(function (font) {\n      return new Promise(function (resolve, reject) {\n        if (cachedFonts[font.url]) return resolve(cachedFonts[font.url]);\n\n        var req = new XMLHttpRequest();\n        req.addEventListener('load', function () {\n          // TODO: it may also be worth it to wait until fonts are fully loaded before\n          // attempting to rasterize them. (e.g. use https://developer.mozilla.org/en-US/docs/Web/API/FontFaceSet)\n          var fontInBase64 = arrayBufferToBase64(req.response);\n          var fontUri = font.text.replace(urlRegex, 'url(\"data:' + font.format + ';base64,' + fontInBase64 + '\")') + '\\n';\n          cachedFonts[font.url] = fontUri;\n          resolve(fontUri);\n        });\n        req.addEventListener('error', function (e) {\n          console.warn('Failed to load font from: ' + font.url, e);\n          cachedFonts[font.url] = null;\n          resolve(null);\n        });\n        req.addEventListener('abort', function (e) {\n          console.warn('Aborted loading font from: ' + font.url, e);\n          resolve(null);\n        });\n        req.open('GET', font.url);\n        req.responseType = 'arraybuffer';\n        req.send();\n      });\n    })).then(function (fontCss) {\n      return fontCss.filter(function (x) {\n        return x;\n      }).join('');\n    });\n  };\n\n  var cachedRules = null;\n  var styleSheetRules = function styleSheetRules() {\n    if (cachedRules) return cachedRules;\n    return cachedRules = Array.from(document.styleSheets).map(function (sheet) {\n      try {\n        return { rules: sheet.cssRules, href: sheet.href };\n      } catch (e) {\n        console.warn('Stylesheet could not be loaded: ' + sheet.href, e);\n        return {};\n      }\n    });\n  };\n\n  var inlineCss = function inlineCss(el, options) {\n    var _ref = options || {},\n        selectorRemap = _ref.selectorRemap,\n        modifyStyle = _ref.modifyStyle,\n        modifyCss = _ref.modifyCss,\n        fonts = _ref.fonts,\n        excludeUnusedCss = _ref.excludeUnusedCss;\n\n    var generateCss = modifyCss || function (selector, properties) {\n      var sel = selectorRemap ? selectorRemap(selector) : selector;\n      var props = modifyStyle ? modifyStyle(properties) : properties;\n      return sel + '{' + props + '}\\n';\n    };\n    var css = [];\n    var detectFonts = typeof fonts === 'undefined';\n    var fontList = fonts || [];\n    styleSheetRules().forEach(function (_ref2) {\n      var rules = _ref2.rules,\n          href = _ref2.href;\n\n      if (!rules) return;\n      Array.from(rules).forEach(function (rule) {\n        if (typeof rule.style != 'undefined') {\n          if (query(el, rule.selectorText)) css.push(generateCss(rule.selectorText, rule.style.cssText));else if (detectFonts && rule.cssText.match(/^@font-face/)) {\n            var font = detectCssFont(rule, href);\n            if (font) fontList.push(font);\n          } else if (!excludeUnusedCss) {\n            css.push(rule.cssText);\n          }\n        }\n      });\n    });\n\n    return inlineFonts(fontList).then(function (fontCss) {\n      return css.join('\\n') + fontCss;\n    });\n  };\n\n  var downloadOptions = function downloadOptions() {\n    if (!navigator.msSaveOrOpenBlob && !('download' in document.createElement('a'))) {\n      return { popup: window.open() };\n    }\n  };\n\n  out$.prepareSvg = function (el, options, done) {\n    requireDomNode(el);\n\n    var _ref3 = options || {},\n        _ref3$left = _ref3.left,\n        left = _ref3$left === undefined ? 0 : _ref3$left,\n        _ref3$top = _ref3.top,\n        top = _ref3$top === undefined ? 0 : _ref3$top,\n        w = _ref3.width,\n        h = _ref3.height,\n        _ref3$scale = _ref3.scale,\n        scale = _ref3$scale === undefined ? 1 : _ref3$scale,\n        _ref3$responsive = _ref3.responsive,\n        responsive = _ref3$responsive === undefined ? false : _ref3$responsive,\n        _ref3$excludeCss = _ref3.excludeCss,\n        excludeCss = _ref3$excludeCss === undefined ? false : _ref3$excludeCss;\n\n    return inlineImages(el).then(function () {\n      var clone = el.cloneNode(true);\n      clone.style.backgroundColor = (options || {}).backgroundColor || el.style.backgroundColor;\n\n      var _getDimensions = getDimensions(el, clone, w, h),\n          width = _getDimensions.width,\n          height = _getDimensions.height;\n\n      if (el.tagName !== 'svg') {\n        if (el.getBBox) {\n          if (clone.getAttribute('transform') != null) {\n            clone.setAttribute('transform', clone.getAttribute('transform').replace(/translate\\(.*?\\)/, ''));\n          }\n          var svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg');\n          svg.appendChild(clone);\n          clone = svg;\n        } else {\n          console.error('Attempted to render non-SVG element', el);\n          return;\n        }\n      }\n\n      clone.setAttribute('version', '1.1');\n      clone.setAttribute('viewBox', [left, top, width, height].join(' '));\n      if (!clone.getAttribute('xmlns')) clone.setAttributeNS(xmlNs, 'xmlns', svgNs);\n      if (!clone.getAttribute('xmlns:xlink')) clone.setAttributeNS(xmlNs, 'xmlns:xlink', 'http://www.w3.org/1999/xlink');\n\n      if (responsive) {\n        clone.removeAttribute('width');\n        clone.removeAttribute('height');\n        clone.setAttribute('preserveAspectRatio', 'xMinYMin meet');\n      } else {\n        clone.setAttribute('width', width * scale);\n        clone.setAttribute('height', height * scale);\n      }\n\n      Array.from(clone.querySelectorAll('foreignObject > *')).forEach(function (foreignObject) {\n        foreignObject.setAttributeNS(xmlNs, 'xmlns', foreignObject.tagName === 'svg' ? svgNs : xhtmlNs);\n      });\n\n      if (excludeCss) {\n        var outer = document.createElement('div');\n        outer.appendChild(clone);\n        var src = outer.innerHTML;\n        if (typeof done === 'function') done(src, width, height);else return { src: src, width: width, height: height };\n      } else {\n        return inlineCss(el, options).then(function (css) {\n          var style = document.createElement('style');\n          style.setAttribute('type', 'text/css');\n          style.innerHTML = '<![CDATA[\\n' + css + '\\n]]>';\n\n          var defs = document.createElement('defs');\n          defs.appendChild(style);\n          clone.insertBefore(defs, clone.firstChild);\n\n          var outer = document.createElement('div');\n          outer.appendChild(clone);\n          var src = outer.innerHTML.replace(/NS\\d+:href/gi, 'xmlns:xlink=\"http://www.w3.org/1999/xlink\" xlink:href');\n\n          if (typeof done === 'function') done(src, width, height);else return { src: src, width: width, height: height };\n        });\n      }\n    });\n  };\n\n  out$.svgAsDataUri = function (el, options, done) {\n    requireDomNode(el);\n    return out$.prepareSvg(el, options).then(function (_ref4) {\n      var src = _ref4.src,\n          width = _ref4.width,\n          height = _ref4.height;\n\n      var svgXml = 'data:image/svg+xml;base64,' + window.btoa(reEncode(doctype + src));\n      if (typeof done === 'function') {\n        done(svgXml, width, height);\n      }\n      return svgXml;\n    });\n  };\n\n  out$.svgAsPngUri = function (el, options, done) {\n    requireDomNode(el);\n\n    var _ref5 = options || {},\n        _ref5$encoderType = _ref5.encoderType,\n        encoderType = _ref5$encoderType === undefined ? 'image/png' : _ref5$encoderType,\n        _ref5$encoderOptions = _ref5.encoderOptions,\n        encoderOptions = _ref5$encoderOptions === undefined ? 0.8 : _ref5$encoderOptions,\n        canvg = _ref5.canvg;\n\n    var convertToPng = function convertToPng(_ref6) {\n      var src = _ref6.src,\n          width = _ref6.width,\n          height = _ref6.height;\n\n      var canvas = document.createElement('canvas');\n      var context = canvas.getContext('2d');\n      var pixelRatio = window.devicePixelRatio || 1;\n\n      canvas.width = width * pixelRatio;\n      canvas.height = height * pixelRatio;\n      canvas.style.width = canvas.width + 'px';\n      canvas.style.height = canvas.height + 'px';\n      context.setTransform(pixelRatio, 0, 0, pixelRatio, 0, 0);\n\n      if (canvg) canvg(canvas, src);else context.drawImage(src, 0, 0);\n\n      var png = void 0;\n      try {\n        png = canvas.toDataURL(encoderType, encoderOptions);\n      } catch (e) {\n        if (typeof SecurityError !== 'undefined' && e instanceof SecurityError || e.name === 'SecurityError') {\n          console.error('Rendered SVG images cannot be downloaded in this browser.');\n          return;\n        } else throw e;\n      }\n      if (typeof done === 'function') done(png, canvas.width, canvas.height);\n      return Promise.resolve(png);\n    };\n\n    if (canvg) return out$.prepareSvg(el, options).then(convertToPng);else return out$.svgAsDataUri(el, options).then(function (uri) {\n      return new Promise(function (resolve, reject) {\n        var image = new Image();\n        image.onload = function () {\n          return resolve(convertToPng({\n            src: image,\n            width: image.width,\n            height: image.height\n          }));\n        };\n        image.onerror = function () {\n          reject('There was an error loading the data URI as an image on the following SVG\\n' + window.atob(uri.slice(26)) + 'Open the following link to see browser\\'s diagnosis\\n' + uri);\n        };\n        image.src = uri;\n      });\n    });\n  };\n\n  out$.download = function (name, uri, options) {\n    if (navigator.msSaveOrOpenBlob) navigator.msSaveOrOpenBlob(uriToBlob(uri), name);else {\n      var saveLink = document.createElement('a');\n      if ('download' in saveLink) {\n        saveLink.download = name;\n        saveLink.style.display = 'none';\n        document.body.appendChild(saveLink);\n        try {\n          var blob = uriToBlob(uri);\n          var url = URL.createObjectURL(blob);\n          saveLink.href = url;\n          saveLink.onclick = function () {\n            return requestAnimationFrame(function () {\n              return URL.revokeObjectURL(url);\n            });\n          };\n        } catch (e) {\n          console.error(e);\n          console.warn('Error while getting object URL. Falling back to string URL.');\n          saveLink.href = uri;\n        }\n        saveLink.click();\n        document.body.removeChild(saveLink);\n      } else if (options && options.popup) {\n        options.popup.document.title = name;\n        options.popup.location.replace(uri);\n      }\n    }\n  };\n\n  out$.saveSvg = function (el, name, options) {\n    var downloadOpts = downloadOptions(); // don't inline, can't be async\n    return requireDomNodePromise(el).then(function (el) {\n      return out$.svgAsDataUri(el, options || {});\n    }).then(function (uri) {\n      return out$.download(name, uri, downloadOpts);\n    });\n  };\n\n  out$.saveSvgAsPng = function (el, name, options) {\n    var downloadOpts = downloadOptions(); // don't inline, can't be async\n    return requireDomNodePromise(el).then(function (el) {\n      return out$.svgAsPngUri(el, options || {});\n    }).then(function (uri) {\n      return out$.download(name, uri, downloadOpts);\n    });\n  };\n})();","export const ICDS = `DISPLAY\nNO DATA\n`;\n","export const IDPS = `DISPLAY\nNO DATA\n`;\n","const rnaColor = 'rgb(255,230,153)';\nconst invAbasicColor = 'rgb(255,230,153)';\nexport const axolabsMap = {\n    'RNA': {\n        fullName: 'RNA nucleotides',\n        symbols: ['A', 'C', 'G', 'U'],\n        color: rnaColor,\n    },\n    'DNA': {\n        fullName: 'DNA nucleotides',\n        symbols: ['dA', 'dC', 'dG', 'dT'],\n        color: 'rgb(197,224,180)',\n    },\n    '2\\'-Fluoro': {\n        fullName: '2\\'-Fluoro nucleotides',\n        symbols: ['Af', 'Cf', 'Gf', 'Uf'],\n        color: 'rgb(68,114,196)',\n    },\n    '2\\'-O-Methyl': {\n        fullName: '2\\'-O-Methyl nucleotides',\n        symbols: ['a', 'c', 'g', 'u'],\n        color: 'rgb(166,166,166)',\n    },\n    '2\\'-O-MOE': {\n        fullName: '2\\'-O-MOE nucleotides (including 5-Methyl C)',\n        symbols: ['Am', 'Cm', 'Gm', 'Tm'],\n        color: 'rgb(112,48,160)',\n    },\n    'GNA': {\n        fullName: 'Glycol nucleic acid',\n        symbols: ['(GNA-A)', '(GNA-C)', '(GNA-G)', '(GNA-T)'],\n        color: 'rgb(255,192,0)',\n    },\n    'LNA': {\n        fullName: 'Locked nucleic acid (including 5-Methyl C)',\n        symbols: ['Ab', 'Cb', 'Gb', 'Tb'],\n        color: 'rgb(54,229,238)',\n    },\n    'UNA': {\n        fullName: 'Unlocked nucleotides',\n        symbols: ['Ao', 'Co', 'Go', 'Uo'],\n        color: 'rgb(255,192,0)',\n    },\n    'A': {\n        fullName: 'Adenine',\n        symbols: ['a', 'a', 'a', 'a'],\n        color: rnaColor,\n    },\n    'C': {\n        fullName: 'Cytosine',\n        symbols: ['c', 'c', 'c', 'c'],\n        color: rnaColor,\n    },\n    'G': {\n        fullName: 'Guanine',\n        symbols: ['g', 'g', 'g', 'g'],\n        color: rnaColor,\n    },\n    'U': {\n        fullName: 'Uracil',\n        symbols: ['u', 'u', 'u', 'u'],\n        color: rnaColor,\n    },\n    'X-New': {\n        fullName: '',\n        symbols: ['X', 'X', 'X', 'X'],\n        color: 'rgb(108,0,0)',\n    },\n    'Y-New': {\n        fullName: '',\n        symbols: ['Y', 'Y', 'Y', 'Y'],\n        color: 'rgb(210,146,146)',\n    },\n    'Z-New': {\n        fullName: '',\n        symbols: ['Z', 'Z', 'Z', 'Z'],\n        color: 'rgb(155,108,132)',\n    },\n    'InvAbasic': {\n        fullName: 'Inverted abasic capped',\n        symbols: ['(invabasic)', '(invabasic)', '(invabasic)', '(invabasic)'],\n        color: invAbasicColor,\n    },\n    '5\\'-vinylps': {\n        fullName: '5\\'-vinylphosphonate-2\\'-OMe-uridine',\n        symbols: ['(vinu)', '(vinu)', '(vinu)', '(vinu)'],\n        color: 'rgb(0,0,139)',\n    },\n    'InvAbasic(o)': {\n        fullName: 'Inverted abasic capped (overhang)',\n        symbols: ['(invabasic)', '(invabasic)', '(invabasic)', '(invabasic)'],\n        color: invAbasicColor,\n    },\n    '2\\'-OMe-U(o)': {\n        fullName: 'Nucleotide Uridine with 2’O-Methyl protection (overhang)',\n        symbols: ['mU', 'mU', 'mU', 'mU'],\n        color: 'rgb(65,233,80)',\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};\n/* Do not change these import lines. Datagrok will import API library in exactly the same manner */\nimport * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\n// @ts-ignore\nimport * as svg from 'save-svg-as-png';\nimport $ from 'cash-dom';\nimport { drawAxolabsPattern } from './drawAxolabsPattern';\nimport { axolabsMap } from './axolabsMap';\nconst baseChoices = Object.keys(axolabsMap);\nconst defaultBase = baseChoices[0];\nconst defaultPto = true;\nconst defaultSequenceLength = 23;\nconst maximalValidSequenceLength = 35;\nconst userStorageKey = 'SequenceTranslator';\nconst exampleMinWidth = '400px';\nfunction generateExample(sequenceLength, sequenceBasis) {\n    const uniqueSymbols = axolabsMap[sequenceBasis].symbols.join('');\n    return uniqueSymbols.repeat(Math.floor(sequenceLength / 4)) + uniqueSymbols.slice(0, sequenceLength % 4);\n}\nfunction findDuplicates(data) {\n    return Array.from(new Set(data)).filter((value) => data.indexOf(value) !== data.lastIndexOf(value));\n}\nfunction isCurrentUserCreatedThisPattern(patternName) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return yield grok.dapi.users.current().then((user) => {\n            const [firstName, lastName] = getUserName(patternName);\n            return (user.firstName != firstName || user.lastName != lastName);\n        });\n    });\n}\nfunction getShortName(patternName) {\n    let first = patternName.length + 1;\n    for (let i = 0; i < patternName.length; i++) {\n        if (patternName[i] == '(') {\n            first = i;\n            break;\n        }\n    }\n    return patternName.slice(0, first - 1);\n}\nfunction getUserName(patternName) {\n    let first = -1;\n    for (let i = 0; i < patternName.length; i++) {\n        if (patternName[i] == '(') {\n            first = i;\n            break;\n        }\n    }\n    return (first == -1) ? ['', ''] : patternName.slice(first + 9, patternName.length - 1).split(' ').slice(1);\n}\nfunction translateSequence(sequence, bases, ptoLinkages, startModification, endModification, firstPtoExist) {\n    let counter = -1;\n    let mainSequence = sequence.replace(/[AUGC]/g, function (x) {\n        counter++;\n        const indexOfSymbol = axolabsMap['RNA']['symbols'].indexOf(x);\n        const symbol = axolabsMap[bases[counter].value]['symbols'][indexOfSymbol];\n        return (ptoLinkages[counter].value) ? symbol + 's' : symbol;\n    });\n    if (mainSequence.slice(0, 5).split('mU').length == 3)\n        mainSequence = '(uu)' + mainSequence.slice(4);\n    if (mainSequence.slice(mainSequence.length - 7).split('mU').length == 3)\n        mainSequence = mainSequence.slice(0, mainSequence.length - 4) + '(uu)';\n    return startModification.value + (firstPtoExist ? 's' : '') + mainSequence + endModification.value;\n}\nfunction addColumnWithIds(tableName, columnName, patternName) {\n    const nameOfNewColumn = 'ID ' + patternName;\n    const columns = grok.shell.table(tableName).columns;\n    if (columns.contains(nameOfNewColumn))\n        columns.remove(nameOfNewColumn);\n    const columnWithIds = columns.byName(columnName);\n    return columns.addNewString(nameOfNewColumn).init((i) => {\n        return (columnWithIds.getString(i) == '') ? '' : columnWithIds.get(i) + '_' + patternName;\n    });\n}\nfunction addColumnWithTranslatedSequences(tableName, columnName, bases, ptoLinkages, startModification, endModification, firstPtoExist) {\n    const nameOfNewColumn = 'Axolabs ' + columnName;\n    const columns = grok.shell.table(tableName).columns;\n    if (columns.contains(nameOfNewColumn))\n        columns.remove(nameOfNewColumn);\n    const columnWithInputSequences = columns.byName(columnName);\n    return columns.addNewString(nameOfNewColumn).init((i) => {\n        return columnWithInputSequences.getString(i) == '' ?\n            '' :\n            translateSequence(columnWithInputSequences.getString(i), bases, ptoLinkages, startModification, endModification, firstPtoExist);\n    });\n}\nexport function defineAxolabsPattern() {\n    const enumerateModifications = [defaultBase];\n    let maximalSsLength = defaultSequenceLength;\n    let maximalAsLength = defaultSequenceLength;\n    function updateAsModification() {\n        asModificationItems.innerHTML = '';\n        asPtoLinkages = asPtoLinkages.concat(Array(maximalAsLength - asBases.length).fill(fullyPto));\n        asBases = asBases.concat(Array(maximalAsLength - asBases.length).fill(sequenceBase));\n        let nucleotideCounter = 0;\n        for (let i = 0; i < asLength.value; i++) {\n            asPtoLinkages[i] = ui.boolInput('', asPtoLinkages[i].value, () => {\n                updateSvgScheme();\n                updateOutputExamples();\n            });\n            asBases[i] = ui.choiceInput('', asBases[i].value, baseChoices, (v) => {\n                if (!enumerateModifications.includes(v)) {\n                    enumerateModifications.push(v);\n                    isEnumerateModificationsDiv.append(ui.boolInput(v, true, (boolV) => {\n                        if (boolV) {\n                            if (!enumerateModifications.includes(v))\n                                enumerateModifications.push(v);\n                        }\n                        else {\n                            const index = enumerateModifications.indexOf(v, 0);\n                            if (index > -1)\n                                enumerateModifications.splice(index, 1);\n                        }\n                        updateSvgScheme();\n                    }).root);\n                }\n                updateAsModification();\n                updateSvgScheme();\n                updateOutputExamples();\n            });\n            if (asBases[i].value.slice(-3) != '(o)')\n                nucleotideCounter++;\n            asModificationItems.append(ui.divH([\n                ui.div([ui.label(asBases[i].value.slice(-3) == '(o)' ? '' : String(nucleotideCounter))], { style: { width: '20px' } }),\n                ui.block75([asBases[i]]),\n                ui.div([asPtoLinkages[i]]),\n            ], { style: { alignItems: 'center' } }));\n        }\n    }\n    function updateSsModification() {\n        ssModificationItems.innerHTML = '';\n        ssPtoLinkages = ssPtoLinkages.concat(Array(maximalSsLength - ssBases.length).fill(fullyPto));\n        ssBases = ssBases.concat(Array(maximalSsLength - ssBases.length).fill(sequenceBase));\n        let nucleotideCounter = 0;\n        for (let i = 0; i < ssLength.value; i++) {\n            ssPtoLinkages[i] = ui.boolInput('', ssPtoLinkages[i].value, () => {\n                updateSvgScheme();\n                updateOutputExamples();\n            });\n            ssBases[i] = ui.choiceInput('', ssBases[i].value, baseChoices, (v) => {\n                if (!enumerateModifications.includes(v)) {\n                    enumerateModifications.push(v);\n                    isEnumerateModificationsDiv.append(ui.boolInput(v, true, (boolV) => {\n                        if (boolV) {\n                            if (!enumerateModifications.includes(v))\n                                enumerateModifications.push(v);\n                        }\n                        else {\n                            const index = enumerateModifications.indexOf(v, 0);\n                            if (index > -1)\n                                enumerateModifications.splice(index, 1);\n                        }\n                        updateSvgScheme();\n                    }).root);\n                }\n                updateSsModification();\n                updateSvgScheme();\n                updateOutputExamples();\n            });\n            if (ssBases[i].value.slice(-3) != '(o)')\n                nucleotideCounter++;\n            ssModificationItems.append(ui.divH([\n                ui.div([ui.label(ssBases[i].value.slice(-3) == '(o)' ? '' : String(nucleotideCounter))], { style: { width: '20px' } }),\n                ui.block75([ssBases[i]]),\n                ui.div([ssPtoLinkages[i]]),\n            ], { style: { alignItems: 'center' } }));\n        }\n    }\n    function updateUiForNewSequenceLength() {\n        if (ssLength.value < maximalValidSequenceLength && asLength.value < maximalValidSequenceLength) {\n            if (ssLength.value > maximalSsLength)\n                maximalSsLength = ssLength.value;\n            if (asLength.value > maximalAsLength)\n                maximalAsLength = asLength.value;\n            updateSsModification();\n            updateAsModification();\n            updateSvgScheme();\n            updateInputExamples();\n            updateOutputExamples();\n        }\n        else {\n            ui.dialog('Sequence length is out of range')\n                .add(ui.divText('Sequence length should be less than ' +\n                maximalValidSequenceLength.toString() + ' due to UI constrains.'))\n                .add(ui.divText('Please change sequence length in order to define new pattern.'))\n                .show();\n        }\n    }\n    function updatePto(newPtoValue) {\n        for (let i = 0; i < ssPtoLinkages.length; i++)\n            ssPtoLinkages[i].value = newPtoValue;\n        for (let i = 0; i < asPtoLinkages.length; i++)\n            asPtoLinkages[i].value = newPtoValue;\n        updateSvgScheme();\n    }\n    function updateBases(newBasisValue) {\n        for (let i = 0; i < ssBases.length; i++)\n            ssBases[i].value = newBasisValue;\n        for (let i = 0; i < asBases.length; i++)\n            asBases[i].value = newBasisValue;\n        updateSvgScheme();\n    }\n    function updateInputExamples() {\n        ssInputExample.value = generateExample(ssLength.value, sequenceBase.value);\n        if (createAsStrand.value)\n            asInputExample.value = generateExample(asLength.value, sequenceBase.value);\n    }\n    function updateOutputExamples() {\n        ssOutputExample.value = translateSequence(ssInputExample.value, ssBases, ssPtoLinkages, ssFiveModification, ssThreeModification, firstSsPto.value);\n        if (createAsStrand.value) {\n            asOutputExample.value = translateSequence(asInputExample.value, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstAsPto.value);\n        }\n    }\n    function updateSvgScheme() {\n        svgDiv.innerHTML = '';\n        svgDiv.append(ui.span([\n            drawAxolabsPattern(getShortName(saveAs.value), createAsStrand.value, ssBases.slice(0, ssLength.value).map((e) => e.value), asBases.slice(0, asLength.value).map((e) => e.value), [firstSsPto.value].concat(ssPtoLinkages.slice(0, ssLength.value).map((e) => e.value)), [firstAsPto.value].concat(asPtoLinkages.slice(0, asLength.value).map((e) => e.value)), ssThreeModification.value, ssFiveModification.value, asThreeModification.value, asFiveModification.value, comment.value, enumerateModifications),\n        ]));\n    }\n    function detectDefaultBasis(array) {\n        const modeMap = {};\n        let maxEl = array[0];\n        let maxCount = 1;\n        for (let i = 0; i < array.length; i++) {\n            const el = array[i];\n            if (modeMap[el] == null)\n                modeMap[el] = 1;\n            else\n                modeMap[el]++;\n            if (modeMap[el] > maxCount) {\n                maxEl = el;\n                maxCount = modeMap[el];\n            }\n        }\n        return maxEl;\n    }\n    function parsePatternAndUpdateUi(newName) {\n        return __awaiter(this, void 0, void 0, function* () {\n            const pi = DG.TaskBarProgressIndicator.create('Loading pattern...');\n            yield grok.dapi.userDataStorage.get(userStorageKey, false).then((entities) => {\n                const obj = JSON.parse(entities[newName]);\n                sequenceBase.value = detectDefaultBasis(obj['asBases'].concat(obj['ssBases']));\n                createAsStrand.value = (obj['asBases'].length > 0);\n                saveAs.value = newName;\n                ssBases = [];\n                for (let i = 0; i < obj['ssBases'].length; i++)\n                    ssBases.push(ui.choiceInput('', obj['ssBases'][i], baseChoices));\n                asBases = [];\n                for (let i = 0; i < obj['asBases'].length; i++)\n                    asBases.push(ui.choiceInput('', obj['asBases'][i], baseChoices));\n                firstSsPto.value = obj['ssPtoLinkages'][0];\n                ssPtoLinkages = [];\n                for (let i = 1; i < obj['ssPtoLinkages'].length; i++)\n                    ssPtoLinkages.push(ui.boolInput('', obj['ssPtoLinkages'][i]));\n                firstAsPto.value = obj['asPtoLinkages'][0];\n                asPtoLinkages = [];\n                for (let i = 1; i < obj['asPtoLinkages'].length; i++)\n                    asPtoLinkages.push(ui.boolInput('', obj['asPtoLinkages'][i]));\n                ssLength.value = obj['ssBases'].length;\n                asLength.value = obj['asBases'].length;\n                ssThreeModification.value = obj['ssThreeModification'];\n                ssFiveModification.value = obj['ssFiveModification'];\n                asThreeModification.value = obj['asThreeModification'];\n                asFiveModification.value = obj['asFiveModification'];\n                comment.value = obj['comment'];\n            });\n            pi.close();\n        });\n    }\n    function checkWhetherAllValuesInColumnHaveTheSameLength(colName) {\n        const col = tables.value.columns.byName(colName);\n        let allLengthsAreTheSame = true;\n        for (let i = 1; i < col.length; i++) {\n            if (col.get(i - 1).length != col.get(i).length && col.get(i).length != 0) {\n                allLengthsAreTheSame = false;\n                break;\n            }\n        }\n        if (!allLengthsAreTheSame) {\n            const dialog = ui.dialog('Sequences lengths mismatch');\n            $(dialog.getButton('OK')).hide();\n            dialog\n                .add(ui.divText('The sequence length should match the number of Raw sequences in the input file'))\n                .add(ui.divText('\\'ADD COLUMN\\' to see sequences lengths'))\n                .addButton('ADD COLUMN', () => {\n                tables.value.columns.addNewInt('Sequences lengths in ' + colName).init((j) => col.get(j).length);\n                grok.shell.info('Column with lengths added to \\'' + tables.value.name + '\\'');\n                dialog.close();\n                grok.shell.v = grok.shell.getTableView(tables.value.name);\n            })\n                .show();\n        }\n        return allLengthsAreTheSame;\n    }\n    function getCurrentUserName() {\n        return __awaiter(this, void 0, void 0, function* () {\n            return yield grok.dapi.users.current().then((user) => {\n                return ' (created by ' + user.firstName + ' ' + user.lastName + ')';\n            });\n        });\n    }\n    function postPatternToUserStorage() {\n        return __awaiter(this, void 0, void 0, function* () {\n            const currUserName = yield getCurrentUserName();\n            saveAs.value = (saveAs.stringValue.includes('(created by ')) ?\n                getShortName(saveAs.value) + currUserName :\n                saveAs.stringValue + currUserName;\n            return grok.dapi.userDataStorage.postValue(userStorageKey, saveAs.value, JSON.stringify({\n                'ssBases': ssBases.slice(0, ssLength.value).map((e) => e.value),\n                'asBases': asBases.slice(0, asLength.value).map((e) => e.value),\n                'ssPtoLinkages': [firstSsPto.value].concat(ssPtoLinkages.slice(0, ssLength.value).map((e) => e.value)),\n                'asPtoLinkages': [firstAsPto.value].concat(asPtoLinkages.slice(0, asLength.value).map((e) => e.value)),\n                'ssThreeModification': ssThreeModification.value,\n                'ssFiveModification': ssFiveModification.value,\n                'asThreeModification': asThreeModification.value,\n                'asFiveModification': asFiveModification.value,\n                'comment': comment.value,\n            }), false).then(() => grok.shell.info('Pattern \\'' + saveAs.value + '\\' was successfully uploaded!'));\n        });\n    }\n    function updatePatternsList() {\n        return __awaiter(this, void 0, void 0, function* () {\n            grok.dapi.userDataStorage.get(userStorageKey, false).then((entities) => __awaiter(this, void 0, void 0, function* () {\n                const lstMy = [];\n                const lstOthers = [];\n                // TODO: display short name, but use long for querying userdataStorage\n                for (const ent of Object.keys(entities)) {\n                    if (yield isCurrentUserCreatedThisPattern(ent))\n                        lstOthers.push(ent);\n                    else\n                        lstMy.push(ent); //getShortName(ent));\n                }\n                let loadPattern = ui.choiceInput('Load Pattern', '', lstMy, (v) => parsePatternAndUpdateUi(v));\n                const myOrOthersPatternList = ui.choiceInput('', 'Mine', ['Mine', 'Others'], (v) => {\n                    const currentList = v == 'Mine' ? lstMy : lstOthers;\n                    loadPattern = ui.choiceInput('Load Pattern', '', currentList, (v) => parsePatternAndUpdateUi(v));\n                    loadPattern.root.append(myOrOthersPatternList.input);\n                    loadPattern.root.append(loadPattern.input);\n                    // @ts-ignore\n                    loadPattern.input.style.maxWidth = '100px';\n                    loadPattern.setTooltip('Apply Existing Pattern');\n                    loadPatternDiv.innerHTML = '';\n                    loadPatternDiv.append(loadPattern.root);\n                    loadPattern.root.append(ui.div([\n                        ui.button(ui.iconFA('trash-alt', () => { }), () => __awaiter(this, void 0, void 0, function* () {\n                            if (loadPattern.value == null)\n                                grok.shell.warning('Choose pattern to delete');\n                            else if (yield isCurrentUserCreatedThisPattern(saveAs.value))\n                                grok.shell.warning('Cannot delete pattern, created by other user');\n                            else {\n                                yield grok.dapi.userDataStorage.remove(userStorageKey, loadPattern.value, false)\n                                    .then(() => grok.shell.info('Pattern \\'' + loadPattern.value + '\\' deleted'));\n                            }\n                            yield updatePatternsList();\n                        })),\n                    ], 'ui-input-options'));\n                });\n                loadPattern.root.append(myOrOthersPatternList.input);\n                loadPattern.root.append(loadPattern.input);\n                // @ts-ignore\n                loadPattern.input.style.maxWidth = '100px';\n                loadPattern.setTooltip('Apply Existing Pattern');\n                loadPatternDiv.innerHTML = '';\n                loadPatternDiv.append(loadPattern.root);\n                loadPattern.root.append(ui.div([\n                    ui.button(ui.iconFA('trash-alt', () => { }), () => __awaiter(this, void 0, void 0, function* () {\n                        if (loadPattern.value == null)\n                            grok.shell.warning('Choose pattern to delete');\n                        else if (yield isCurrentUserCreatedThisPattern(saveAs.value))\n                            grok.shell.warning('Cannot delete pattern, created by other user');\n                        else {\n                            yield grok.dapi.userDataStorage.remove(userStorageKey, loadPattern.value, false)\n                                .then(() => grok.shell.info('Pattern \\'' + loadPattern.value + '\\' deleted'));\n                        }\n                        yield updatePatternsList();\n                    })),\n                ], 'ui-input-options'));\n            }));\n        });\n    }\n    function savePattern() {\n        return __awaiter(this, void 0, void 0, function* () {\n            yield grok.dapi.userDataStorage.get(userStorageKey, false)\n                .then((entities) => {\n                if (Object.keys(entities).includes(saveAs.value)) {\n                    const dialog = ui.dialog('Pattern already exists');\n                    $(dialog.getButton('OK')).hide();\n                    dialog\n                        .add(ui.divText('Pattern name \\'' + saveAs.value + '\\' already exists.'))\n                        .add(ui.divText('Replace pattern?'))\n                        .addButton('YES', () => __awaiter(this, void 0, void 0, function* () {\n                        yield grok.dapi.userDataStorage.remove(userStorageKey, saveAs.value, false)\n                            .then(() => postPatternToUserStorage());\n                        dialog.close();\n                    }))\n                        .show();\n                }\n                else\n                    postPatternToUserStorage();\n            });\n            yield updatePatternsList();\n        });\n    }\n    const inputSsColumnDiv = ui.div([]);\n    const inputAsColumnDiv = ui.div([]);\n    const inputIdColumnDiv = ui.div([]);\n    const ssModificationItems = ui.div([]);\n    const asModificationItems = ui.div([]);\n    const svgDiv = ui.div([]);\n    const asExampleDiv = ui.div([]);\n    const appAxolabsDescription = ui.div([]);\n    const loadPatternDiv = ui.div([]);\n    const asModificationDiv = ui.div([]);\n    const firstAsPtoDiv = ui.div([]);\n    const isEnumerateModificationsDiv = ui.divH([ui.boolInput(defaultBase, true, (v) => {\n            if (v) {\n                if (!enumerateModifications.includes(defaultBase))\n                    enumerateModifications.push(defaultBase);\n            }\n            else {\n                const index = enumerateModifications.indexOf(defaultBase, 0);\n                if (index > -1)\n                    enumerateModifications.splice(index, 1);\n            }\n            updateSvgScheme();\n            updateOutputExamples();\n        }).root]);\n    let ssBases = Array(defaultSequenceLength).fill(ui.choiceInput('', defaultBase, baseChoices));\n    let asBases = Array(defaultSequenceLength).fill(ui.choiceInput('', defaultBase, baseChoices));\n    let ssPtoLinkages = Array(defaultSequenceLength).fill(ui.boolInput('', defaultPto));\n    let asPtoLinkages = Array(defaultSequenceLength).fill(ui.boolInput('', defaultPto));\n    const ssLength = ui.intInput('SS Length', defaultSequenceLength, () => updateUiForNewSequenceLength());\n    const asLength = ui.intInput('AS Length', defaultSequenceLength, () => updateUiForNewSequenceLength());\n    const asLengthDiv = ui.div([asLength.root]);\n    function validateSsColumn(colName) {\n        const allLengthsAreTheSame = checkWhetherAllValuesInColumnHaveTheSameLength(colName);\n        const firstSequence = tables.value.columns.byName(colName).get(0);\n        if (allLengthsAreTheSame && firstSequence.length != ssLength.value)\n            ssLength.value = tables.value.columns.byName(colName).get(0).length;\n        ssInputExample.value = firstSequence;\n    }\n    function validateAsColumn(colName) {\n        const allLengthsAreTheSame = checkWhetherAllValuesInColumnHaveTheSameLength(colName);\n        const firstSequence = tables.value.columns.byName(colName).get(0);\n        if (allLengthsAreTheSame && firstSequence.length != asLength.value)\n            asLength.value = tables.value.columns.byName(colName).get(0).length;\n        asLengthDiv.innerHTML = '';\n        asLengthDiv.append(asLength.root);\n        asInputExample.value = firstSequence;\n    }\n    function validateIdsColumn(colName) {\n        const col = tables.value.columns.byName(colName);\n        if (col.type != DG.TYPE.INT)\n            grok.shell.error('Column should contain integers only');\n        else if (col.categories.filter((e) => e != '').length < col.toList().filter((e) => e != '').length) {\n            const duplicates = findDuplicates(col.getRawData());\n            ui.dialog('Non-unique IDs')\n                .add(ui.divText('Press \\'OK\\' to select rows with non-unique values'))\n                .onOK(() => {\n                const selection = tables.value.selection;\n                selection.init((i) => duplicates.indexOf(col.get(i)) > -1);\n                grok.shell.v = grok.shell.getTableView(tables.value.name);\n                grok.shell.info('Rows are selected in table \\'' + tables.value.name + '\\'');\n            })\n                .show();\n        }\n    }\n    const tables = ui.tableInput('Tables', grok.shell.tables[0], grok.shell.tables, (t) => {\n        const inputSsColumn = ui.choiceInput('SS Column', '', t.columns.names(), (colName) => {\n            validateSsColumn(colName);\n            ssVar = colName;\n        });\n        inputSsColumnDiv.innerHTML = '';\n        inputSsColumnDiv.append(inputSsColumn.root);\n        const inputAsColumn = ui.choiceInput('AS Column', '', t.columns.names(), (colName) => {\n            validateAsColumn(colName);\n            asVar = colName;\n        });\n        inputAsColumnDiv.innerHTML = '';\n        inputAsColumnDiv.append(inputAsColumn.root);\n        const inputIdColumn = ui.choiceInput('ID Column', '', t.columns.names(), (colName) => {\n            validateIdsColumn(colName);\n            idVar = colName;\n        });\n        inputIdColumnDiv.innerHTML = '';\n        inputIdColumnDiv.append(inputIdColumn.root);\n    });\n    let ssVar = '';\n    const inputSsColumn = ui.choiceInput('SS Column', '', [], (colName) => {\n        validateSsColumn(colName);\n        ssVar = colName;\n    });\n    inputSsColumnDiv.append(inputSsColumn.root);\n    let asVar = '';\n    const inputAsColumn = ui.choiceInput('AS Column', '', [], (colName) => {\n        validateAsColumn(colName);\n        asVar = colName;\n    });\n    inputAsColumnDiv.append(inputAsColumn.root);\n    let idVar = '';\n    const inputIdColumn = ui.choiceInput('ID Column', '', [], (colName) => {\n        validateIdsColumn(colName);\n        idVar = colName;\n    });\n    inputIdColumnDiv.append(inputIdColumn.root);\n    updatePatternsList();\n    const sequenceBase = ui.choiceInput('Sequence Basis', defaultBase, baseChoices, (v) => {\n        updateBases(v);\n        updateOutputExamples();\n    });\n    const fullyPto = ui.boolInput('Fully PTO', defaultPto, (v) => {\n        firstSsPto.value = v;\n        firstAsPto.value = v;\n        updatePto(v);\n        updateOutputExamples();\n    });\n    const firstSsPto = ui.boolInput('First SS PTO', fullyPto.value, () => updateSvgScheme());\n    const firstAsPto = ui.boolInput('First AS PTO', fullyPto.value, () => updateSvgScheme());\n    firstAsPtoDiv.append(firstAsPto.root);\n    const createAsStrand = ui.boolInput('Create AS Strand', true, (v) => {\n        asModificationSection.hidden = (!v);\n        inputAsColumnDiv.hidden = (!v);\n        asLengthDiv.hidden = (!v);\n        asModificationDiv.hidden = (!v);\n        asExampleDiv.hidden = (!v);\n        firstAsPtoDiv.hidden = (!v);\n        updateSvgScheme();\n    });\n    const saveAs = ui.textInput('Save As', 'Pattern Name', () => updateSvgScheme());\n    saveAs.setTooltip('Name Of New Pattern');\n    const ssThreeModification = ui.stringInput('SS 3\\' Modification', '', () => {\n        updateSvgScheme();\n        updateOutputExamples();\n    });\n    ssThreeModification.setTooltip('Additional SS 3\\' Modification');\n    const ssFiveModification = ui.stringInput('SS 5\\' Modification', '', () => {\n        updateSvgScheme();\n        updateOutputExamples();\n    });\n    ssFiveModification.setTooltip('Additional SS 5\\' Modification');\n    const asThreeModification = ui.stringInput('AS 3\\' Modification', '', () => {\n        updateSvgScheme();\n        updateOutputExamples();\n    });\n    asThreeModification.setTooltip('Additional AS 3\\' Modification');\n    const asFiveModification = ui.stringInput('AS 5\\' Modification', '', () => {\n        updateSvgScheme();\n        updateOutputExamples();\n    });\n    asFiveModification.setTooltip('Additional AS 5\\' Modification');\n    asModificationDiv.append(asThreeModification.root);\n    asModificationDiv.append(asFiveModification.root);\n    const comment = ui.textInput('Comment', '', () => updateSvgScheme());\n    const savePatternButton = ui.button('Save', () => {\n        if (saveAs.value != '')\n            savePattern().then((r) => grok.shell.info('Pattern saved'));\n        else {\n            const name = ui.stringInput('Enter Name', '');\n            ui.dialog('Pattern Name')\n                .add(name.root)\n                .onOK(() => {\n                saveAs.value = name.value;\n                savePattern().then((r) => grok.shell.info('Pattern saved'));\n            })\n                .show();\n        }\n    });\n    const convertSequenceButton = ui.button('Convert Sequences', () => {\n        if (ssVar == '' || (createAsStrand.value && asVar == ''))\n            grok.shell.info('Please select table and columns on which to apply pattern');\n        else if (ssLength.value != ssInputExample.value.length || asLength.value != asInputExample.value.length) {\n            const dialog = ui.dialog('Length Mismatch');\n            $(dialog.getButton('OK')).hide();\n            dialog\n                .add(ui.divText('Length of sequences in columns doesn\\'t match entered length. Update length value?'))\n                .addButton('YES', () => {\n                ssLength.value = tables.value.columns.byName(inputSsColumn.value).getString(0).length;\n                asLength.value = tables.value.columns.byName(inputAsColumn.value).getString(0).length;\n                dialog.close();\n            })\n                .show();\n        }\n        else {\n            if (idVar != '')\n                addColumnWithIds(tables.value.name, idVar, getShortName(saveAs.value));\n            addColumnWithTranslatedSequences(tables.value.name, ssVar, ssBases, ssPtoLinkages, ssFiveModification, ssThreeModification, firstSsPto.value);\n            if (createAsStrand.value) {\n                addColumnWithTranslatedSequences(tables.value.name, asVar, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstAsPto.value);\n            }\n            grok.shell.v = grok.shell.getTableView(tables.value.name);\n            grok.shell.info(((createAsStrand.value) ? 'Columns were' : 'Column was') +\n                ' added to table \\'' + tables.value.name + '\\'');\n        }\n    });\n    const ssInputExample = ui.textInput('Sense Strand', generateExample(ssLength.value, sequenceBase.value), () => {\n        ssOutputExample.value = translateSequence(ssInputExample.value, ssBases, ssPtoLinkages, ssFiveModification, ssThreeModification, firstSsPto.value);\n    });\n    const ssOutputExample = ui.textInput(' ', translateSequence(ssInputExample.value, ssBases, ssPtoLinkages, ssThreeModification, ssFiveModification, firstSsPto.value));\n    ssInputExample.input.style.resize = 'none';\n    ssInputExample.input.style.minWidth = exampleMinWidth;\n    ssOutputExample.input.style.resize = 'none';\n    ssOutputExample.input.style.minWidth = exampleMinWidth;\n    // @ts-ignore\n    ssOutputExample.input.disabled = 'true';\n    ssOutputExample.root.append(ui.div([\n        ui.button(ui.iconFA('copy', () => { }), () => {\n            navigator.clipboard.writeText(ssOutputExample.value).then(() => grok.shell.info('Sequence was copied to clipboard'));\n        }),\n    ], 'ui-input-options'));\n    const asInputExample = ui.textInput('Antisense Strand', generateExample(asLength.value, sequenceBase.value), () => {\n        asOutputExample.value = translateSequence(asInputExample.value, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstSsPto.value);\n    });\n    const asOutputExample = ui.textInput(' ', translateSequence(asInputExample.value, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstSsPto.value));\n    asInputExample.input.style.resize = 'none';\n    asInputExample.input.style.minWidth = exampleMinWidth;\n    asOutputExample.input.style.resize = 'none';\n    asOutputExample.input.style.minWidth = exampleMinWidth;\n    // @ts-ignore\n    asOutputExample.input.disabled = 'true';\n    asOutputExample.root.append(ui.div([\n        ui.button(ui.iconFA('copy', () => { }), () => {\n            navigator.clipboard.writeText(asOutputExample.value).then(() => grok.shell.info('Sequence was copied to clipboard'));\n        }),\n    ], 'ui-input-options'));\n    asExampleDiv.append(asInputExample.root);\n    asExampleDiv.append(asOutputExample.root);\n    updateUiForNewSequenceLength();\n    const exampleSection = ui.div([\n        ui.h1('Example'),\n        ssInputExample.root,\n        ssOutputExample.root,\n        asExampleDiv,\n    ], 'ui-form');\n    const inputsSection = ui.div([\n        ui.h1('Inputs'),\n        ui.divH([\n            tables.root,\n            inputSsColumnDiv,\n        ]),\n        ui.divH([\n            inputAsColumnDiv,\n            inputIdColumnDiv,\n        ]),\n        ui.buttonsInput([\n            convertSequenceButton,\n        ]),\n    ], 'ui-form');\n    const mainSection = ui.panel([\n        ui.block([\n            svgDiv,\n        ], { style: { overflowX: 'scroll' } }),\n        ui.button('Download', () => svg.saveSvgAsPng(document.getElementById('mySvg'), saveAs.value)),\n        isEnumerateModificationsDiv,\n        ui.div([\n            ui.div([\n                ui.divH([\n                    ui.h1('Pattern'),\n                    ui.div([\n                        ui.iconFA('question-circle', () => {\n                            appAxolabsDescription.innerHTML = '';\n                            appAxolabsDescription.append(info);\n                        }),\n                    ], { style: { padding: '2px' } }),\n                ]),\n                ui.divH([\n                    ui.div([\n                        ssLength.root,\n                        asLengthDiv,\n                        sequenceBase.root,\n                        comment.root,\n                        loadPatternDiv,\n                        saveAs.root,\n                        ui.buttonsInput([\n                            savePatternButton,\n                        ]),\n                    ], 'ui-form'),\n                    ui.div([\n                        createAsStrand.root,\n                        fullyPto.root,\n                        firstSsPto.root,\n                        firstAsPtoDiv,\n                        ssFiveModification.root,\n                        ssThreeModification.root,\n                        asModificationDiv,\n                    ], 'ui-form'),\n                ], 'ui-form'),\n            ], 'ui-form'),\n            inputsSection,\n            exampleSection,\n        ], { style: { flexWrap: 'wrap' } }),\n    ]);\n    const ssModificationSection = ui.panel([\n        ui.h1('Sense Strand'),\n        ui.divH([\n            ui.div([ui.divText('#')], { style: { width: '20px' } }),\n            ui.block75([ui.divText('Modification')]),\n            ui.div([ui.divText('PTO')], { style: { paddingRight: '8px' } }),\n        ]),\n        ssModificationItems,\n    ]);\n    const asModificationSection = ui.panel([\n        ui.h1('Antisense Strand'),\n        ui.divH([\n            ui.div([ui.divText('#')], { style: { width: '20px' } }),\n            ui.block75([ui.divText('Modification')]),\n            ui.div([ui.divText('PTO')], { style: { paddingRight: '8px' } }),\n        ]),\n        asModificationItems,\n    ]);\n    const info = ui.info([\n        ui.divText('\\n How to define new pattern:', { style: { 'font-weight': 'bolder' } }),\n        ui.divText('1. Choose table and columns with sense and antisense strands'),\n        ui.divText('2. Choose lengths of both strands by editing checkboxes below'),\n        ui.divText('3. Choose basis and PTO status for each nucleotide'),\n        ui.divText('4. Set additional modifications for sequence edges'),\n        ui.divText('5. Press \\'Convert Sequences\\' button'),\n        ui.divText('This will add the result column(s) to the right of the table'),\n    ], 'Create and apply Axolabs translation patterns.');\n    return ui.splitH([\n        ui.div([\n            appAxolabsDescription,\n            mainSection,\n        ]),\n        ui.box(ui.divH([\n            ssModificationSection,\n            asModificationSection,\n        ]), { style: { maxWidth: '360px' } }),\n    ]);\n}\n","import { axolabsMap } from './axolabsMap';\n// https://uxdesign.cc/star-rating-make-svg-great-again-d4ce4731347e\nfunction getPointsToDrawStar(centerX, centerY) {\n    const innerCirclePoints = 5; // a 5 point star\n    const innerRadius = 15 / innerCirclePoints;\n    const innerOuterRadiusRatio = 2; // outter circle is x2 the inner\n    const outerRadius = innerRadius * innerOuterRadiusRatio;\n    const angle = Math.PI / innerCirclePoints;\n    const angleOffsetToCenterStar = 60;\n    const totalNumberOfPoints = innerCirclePoints * 2; // 10 in a 5-points star\n    let points = '';\n    for (let i = 0; i < totalNumberOfPoints; i++) {\n        const r = (i % 2 == 0) ? outerRadius : innerRadius;\n        const currentX = centerX + Math.cos(i * angle + angleOffsetToCenterStar) * r;\n        const currentY = centerY + Math.sin(i * angle + angleOffsetToCenterStar) * r;\n        points += currentX + ',' + currentY + ' ';\n    }\n    return points;\n}\nfunction countOverhangsOnTheRightEdge(modifications) {\n    let i = 0;\n    while (i < modifications.length && modifications[i].slice(-3) == '(o)')\n        i++;\n    return (i == modifications.length - 1) ? 0 : i;\n}\nfunction getTextWidth(text, font) {\n    const context = document.createElement('canvas').getContext('2d');\n    // @ts-ignore\n    context.font = String(font);\n    // @ts-ignore\n    return 2 * context.measureText(text).width;\n}\nfunction getTextInsideCircle(bases, index, nucleotideCounter, numberOfNucleotides, enumerateModifications) {\n    return (bases[index].slice(-3) == '(o)') || !enumerateModifications.includes(bases[index]) ? '' :\n        ['A', 'G', 'C', 'U', 'T'].includes(bases[index]) ? bases[index] : String(numberOfNucleotides - nucleotideCounter);\n}\nfunction getFontColorVisibleOnBackground(rgbString) {\n    const rgbIntList = rgbString.match(/\\d+/g).map((e) => Number(e));\n    return (rgbIntList[0] * 0.299 + rgbIntList[1] * 0.587 + rgbIntList[2] * 0.114) > 186 ? '#33333' : '#ffffff';\n}\nfunction getBaseColor(base) {\n    return axolabsMap[base]['color'];\n}\nexport function drawAxolabsPattern(patternName, asExists, ssBases, asBases, ssPtoStatuses, asPtoStatuses, ssThreeModification, ssFiveModification, asThreeModification, asFiveModification, comment, enumerateModifications) {\n    function getEquidistantXForLegend(index) {\n        return Math.round((index + startFrom) * width / (uniqueBases.length + startFrom) + legendRadius);\n    }\n    function getXOfBaseCircles(index, rightOverhangs) {\n        return widthOfRightModification +\n            (resultingNumberOfNucleotidesInStrands - index + rightOverhangs + 1) * baseDiameter;\n    }\n    function getShiftToAlignNumberInsideCircle(bases, generalIndex, nucleotideIndex) {\n        return (nucleotideIndex < 10 || ['A', 'G', 'C', 'U', 'T'].\n            includes(bases[generalIndex])) ? shiftToAlignOneDigitNumberInsideCircle : shiftToAlignTwoDigitNumberInsideCircle;\n    }\n    const svg = {\n        xmlns: 'http://www.w3.org/2000/svg',\n        render: function (width, height) {\n            const e = document.createElementNS(this.xmlns, 'svg');\n            e.setAttribute('id', 'mySvg');\n            e.setAttribute('width', String(width));\n            e.setAttribute('height', String(height));\n            return e;\n        },\n        circle: function (x, y, radius, color) {\n            const e = document.createElementNS(this.xmlns, 'circle');\n            e.setAttribute('cx', String(x));\n            e.setAttribute('cy', String(y));\n            e.setAttribute('r', String(radius));\n            e.setAttribute('fill', color);\n            return e;\n        },\n        text: function (text, x, y, fontSize, color) {\n            const e = document.createElementNS(this.xmlns, 'text');\n            e.setAttribute('x', String(x));\n            e.setAttribute('y', String(y));\n            e.setAttribute('font-size', String(fontSize));\n            e.setAttribute('font-weight', 'normal');\n            e.setAttribute('font-family', 'Arial');\n            e.setAttribute('fill', color);\n            e.innerHTML = text;\n            return e;\n        },\n        star: function (x, y, fill) {\n            const e = document.createElementNS(this.xmlns, 'polygon');\n            e.setAttribute('points', getPointsToDrawStar(x, y));\n            e.setAttribute('fill', fill);\n            return e;\n        },\n    };\n    ssBases = ssBases.reverse();\n    ssPtoStatuses = ssPtoStatuses.reverse();\n    const baseRadius = 15;\n    const shiftToAlignTwoDigitNumberInsideCircle = -10;\n    const shiftToAlignOneDigitNumberInsideCircle = -5;\n    const legendRadius = 6;\n    const psLinkageRadius = 5;\n    const baseFontSize = 17;\n    const legendFontSize = 14;\n    const psLinkageColor = 'red';\n    const fontColor = 'var(--grey-6)';\n    const titleFontColor = 'black';\n    const modificationsColor = 'red';\n    const ssLeftText = 'SS: 5\\'';\n    const asLeftText = 'AS: 3\\'';\n    const ssRightText = '3\\'';\n    const asRightText = '5\\'';\n    const ssRightOverhangs = countOverhangsOnTheRightEdge(ssBases);\n    const asRightOverhangs = countOverhangsOnTheRightEdge(asBases);\n    const resultingNumberOfNucleotidesInStrands = Math.max(ssBases.length - ssRightOverhangs, asBases.length - asRightOverhangs);\n    const baseDiameter = 2 * baseRadius;\n    const widthOfBases = baseDiameter * (resultingNumberOfNucleotidesInStrands + Math.max(ssRightOverhangs, asRightOverhangs));\n    const widthOfLeftModification = Math.max(getTextWidth(ssThreeModification, baseFontSize), getTextWidth(asFiveModification, baseFontSize));\n    const widthOfRightModification = Math.max(getTextWidth(ssFiveModification, baseFontSize), getTextWidth(asThreeModification, baseFontSize));\n    const widthOfLeftText = Math.max(getTextWidth(ssLeftText, baseFontSize), getTextWidth(asLeftText, baseFontSize));\n    const widthOfRightText = Math.max(getTextWidth(ssRightText, baseFontSize), getTextWidth(asRightText, baseFontSize));\n    const width = widthOfLeftText + widthOfLeftModification + widthOfBases +\n        widthOfRightModification + widthOfRightText + baseDiameter;\n    const height = asExists ? 11 * baseRadius : 9 * baseRadius;\n    const xOfTitle = baseRadius; // Math.round(width / 4),\n    const uniqueBases = asExists ? [...new Set(ssBases.concat(asBases))] : [...new Set(ssBases)];\n    const isPtoExist = asExists ? [...new Set(ssPtoStatuses.concat(asPtoStatuses))].includes(true) :\n        [...new Set(ssPtoStatuses)].includes(true);\n    const startFrom = isPtoExist ? 1 : 0;\n    const xOfLeftTexts = 0;\n    const xOfLeftModifications = xOfLeftTexts + widthOfLeftText - 5;\n    const xOfSsRightModifications = ssRightOverhangs * baseDiameter + getXOfBaseCircles(-0.5, 0);\n    const xOfAsRightModifications = asRightOverhangs * baseDiameter + getXOfBaseCircles(-0.5, 0);\n    const xOfRightTexts = Math.max(xOfSsRightModifications, xOfAsRightModifications) +\n        widthOfLeftModification + baseDiameter * (Math.max(ssRightOverhangs, asRightOverhangs));\n    const yOfTitle = baseRadius;\n    const yOfSsTexts = 4 * baseRadius;\n    const yOfAsTexts = 7 * baseRadius;\n    const yOfComment = asExists ? 11 * baseRadius : 8.5 * baseRadius;\n    const yOfSsCircles = 3.5 * baseRadius;\n    const yOfAsCircles = 6.5 * baseRadius;\n    const yOfCirclesInLegends = asExists ? 9 * baseRadius : 6 * baseRadius;\n    const yOfTextLegend = asExists ? 9.5 * baseRadius - 3 : yOfAsCircles - 3;\n    const image = svg.render(width, height);\n    image.append(svg.text(ssLeftText, xOfLeftTexts, yOfSsTexts, baseFontSize, fontColor), asExists ? svg.text(asLeftText, xOfLeftTexts, yOfAsTexts, baseFontSize, fontColor) : '', svg.text(ssRightText, xOfRightTexts, yOfSsTexts, baseFontSize, fontColor), asExists ? svg.text(asRightText, xOfRightTexts, yOfAsTexts, baseFontSize, fontColor) : '', svg.text(ssFiveModification, xOfLeftModifications, yOfSsTexts, baseFontSize, modificationsColor), asExists ? svg.text(asThreeModification, xOfLeftModifications, yOfAsTexts, baseFontSize, modificationsColor) : '', svg.text(ssThreeModification, xOfSsRightModifications, yOfSsTexts, baseFontSize, modificationsColor), asExists ? svg.text(asFiveModification, xOfAsRightModifications, yOfAsTexts, baseFontSize, modificationsColor) : '', svg.text(comment, xOfLeftTexts, yOfComment, legendFontSize, fontColor), isPtoExist ? svg.star(baseRadius, yOfCirclesInLegends, psLinkageColor) : '', isPtoExist ? svg.text('ps linkage', 2 * baseRadius - 8, yOfTextLegend, legendFontSize, fontColor) : '');\n    let numberOfSsNucleotides = 0;\n    for (let i = 0; i < ssBases.length; i++) {\n        if (ssBases[i].slice(-3) != '(o)')\n            numberOfSsNucleotides++;\n    }\n    let nucleotideCounter = numberOfSsNucleotides;\n    for (let i = ssBases.length - 1; i > -1; i--) {\n        if (ssBases[i].slice(-3) != '(o)')\n            nucleotideCounter--;\n        image.append(svg.circle(getXOfBaseCircles(i, ssRightOverhangs), yOfSsCircles, baseRadius, getBaseColor(ssBases[i])), svg.text(getTextInsideCircle(ssBases, i, nucleotideCounter, numberOfSsNucleotides, enumerateModifications), getXOfBaseCircles(i, ssRightOverhangs) +\n            getShiftToAlignNumberInsideCircle(ssBases, ssBases.length - i, numberOfSsNucleotides - nucleotideCounter), yOfSsTexts, baseFontSize, getFontColorVisibleOnBackground(axolabsMap[ssBases[i]]['color'])), ssPtoStatuses[i] ?\n            svg.star(getXOfBaseCircles(i, ssRightOverhangs) + baseRadius, yOfSsTexts + psLinkageRadius, psLinkageColor) :\n            '');\n    }\n    image.append(ssPtoStatuses[ssBases.length] ?\n        svg.star(getXOfBaseCircles(ssBases.length, ssRightOverhangs) +\n            baseRadius, yOfSsTexts + psLinkageRadius, psLinkageColor) : '');\n    let numberOfAsNucleotides = 0;\n    for (let i = 0; i < asBases.length; i++) {\n        if (asBases[i].slice(-3) != '(o)')\n            numberOfAsNucleotides++;\n    }\n    if (asExists) {\n        let nucleotideCounter = numberOfAsNucleotides;\n        for (let i = asBases.length - 1; i > -1; i--) {\n            if (asBases[i].slice(-3) != '(o)')\n                nucleotideCounter--;\n            image.append(svg.circle(getXOfBaseCircles(i, asRightOverhangs), yOfAsCircles, baseRadius, getBaseColor(asBases[i])), svg.text(getTextInsideCircle(asBases, i, numberOfAsNucleotides - nucleotideCounter - 1, numberOfAsNucleotides, enumerateModifications), getXOfBaseCircles(i, asRightOverhangs) +\n                getShiftToAlignNumberInsideCircle(asBases, i, nucleotideCounter + 1), yOfAsTexts, baseFontSize, getFontColorVisibleOnBackground(axolabsMap[asBases[i]]['color'])), asPtoStatuses[i] ? svg.star(getXOfBaseCircles(i, asRightOverhangs) +\n                baseRadius, yOfAsTexts + psLinkageRadius, psLinkageColor) : '');\n        }\n        image.append(asPtoStatuses[asBases.length] ?\n            svg.star(getXOfBaseCircles(asBases.length, asRightOverhangs) +\n                baseRadius, yOfAsTexts + psLinkageRadius, psLinkageColor) : '');\n    }\n    const title = patternName + ' for ' +\n        String(numberOfSsNucleotides) + (asExists ? '/' + String(numberOfAsNucleotides) : '') + 'mer';\n    image.append(svg.text(title, xOfTitle, yOfTitle, baseFontSize, titleFontColor));\n    for (let i = 0; i < uniqueBases.length; i++) {\n        image.append(svg.circle(getEquidistantXForLegend(i), yOfCirclesInLegends, legendRadius, getBaseColor(uniqueBases[i])), svg.text(uniqueBases[i], getEquidistantXForLegend(i) +\n            legendRadius + 4, yOfTextLegend, legendFontSize, fontColor));\n    }\n    return image;\n}\n","export const SALTS_CSV = `DISPLAY,MOLWEIGHT\nno Data Added,100`;\n","export const SOURCES = `DISPLAY\nNO DATA\n`;\n","import { lcmsToGcrs } from './map';\nimport * as DG from 'datagrok-api/dg';\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    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    return sequence.replace(regExp, function (code) { return obj[code]; });\n}\n//name: asoGapmersNucleotidesToBioSpring\n//input: string nucleotides {semType: DNA nucleotides}\n//output: string result {semType: BioSpring / Gapmers}\nexport function asoGapmersNucleotidesToBioSpring(nucleotides) {\n    let count = -1;\n    const objForEdges = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': '5*', 'A': '6*', 'C': '7*', 'G': '8*'\n    };\n    const objForCenter = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'T*', 'A': 'A*', 'C': '9*', 'G': 'G*'\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|T|C|G)/g, function (x) {\n        count++;\n        return (count > 4 && count < 15) ? objForCenter[x] : objForEdges[x];\n    }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?\n        nucleotides.length : 2 * count + 1);\n}\n//name: asoGapmersNucleotidesToGcrs\n//input: string nucleotides {semType: DNA nucleotides}\n//output: string result {semType: GCRS / Gapmers}\nexport function asoGapmersNucleotidesToGcrs(nucleotides) {\n    let count = -1;\n    const objForEdges = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'moeUnps',\n        'A': 'moeAnps', 'C': 'moe5mCnps', 'G': 'moeGnps'\n    };\n    const objForCenter = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'C': '5mCps', 'A': 'Aps', 'T': 'Tps', 'G': 'Gps' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|T|C|G)/g, function (x) {\n        count++;\n        if (count < 5)\n            return (count == 4) ? objForEdges[x].slice(0, -3) + 'ps' : objForEdges[x];\n        if (count < 15)\n            return (count == 14) ? objForCenter[x].slice(0, -2) + 'nps' : objForCenter[x];\n        return objForEdges[x];\n    }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?\n        nucleotides.length : -3);\n}\n//name: asoGapmersBioSpringToNucleotides\n//input: string nucleotides {semType: BioSpring / Gapmers}\n//output: string result {semType: DNA nucleotides}\nexport function asoGapmersBioSpringToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '*': '', '5': 'T', '6': 'A', '7': 'C', '8': 'G', '9': 'C' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|\\*|5|6|7|8|9)/g, function (x) { return obj[x]; });\n}\n//name: asoGapmersBioSpringToGcrs\n//input: string nucleotides {semType: BioSpring / Gapmers}\n//output: string result {semType: GCRS / Gapmers}\nexport function asoGapmersBioSpringToGcrs(nucleotides) {\n    let count = -1;\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '5*': 'moeUnps', '6*': 'moeAnps', '7*': 'moe5mCnps', '8*': 'moeGnps', '9*': '5mCps', 'A*': 'Aps', 'T*': 'Tps',\n        'G*': 'Gps', 'C*': 'Cps', '5': 'moeU', '6': 'moeA', '7': 'moe5mC', '8': 'moeG',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|5\\*|6\\*|7\\*|8\\*|9\\*|A\\*|T\\*|G\\*|C\\*|5|6|7|8)/g, function (x) {\n        count++;\n        return (count == 4) ? obj[x].slice(0, -3) + 'ps' : (count == 14) ? obj[x].slice(0, -2) + 'nps' : obj[x];\n    });\n}\n//name: asoGapmersGcrsToBioSpring\n//input: string nucleotides {semType: GCRS / Gapmers}\n//output: string result {semType: BioSpring / Gapmers}\nexport function asoGapmersGcrsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'moeT': '5', 'moeA': '6', 'moe5mC': '7', 'moeG': '8', 'moeU': '5', '5mC': '9', 'nps': '*', 'ps': '*', 'U': 'T',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|moeT|moeA|moe5mC|moeG|moeU|5mC|nps|ps|U)/g, function (x) { return obj[x]; });\n}\n//name: asoGapmersGcrsToNucleotides\n//input: string nucleotides {semType: GCRS / Gapmers}\n//output: string result {semType: DNA nucleotides}\nexport function asoGapmersGcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'moe': '', '5m': '', 'n': '', 'ps': '', 'U': 'T' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|moe|5m|n|ps|U)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToNucleotides\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaBioSpringToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'U', '2': 'A', '3': 'C', '4': 'G', '5': 'U', '6': 'A', '7': 'C', '8': 'G', '*': '' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToAxolabs\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: Axolabs / siRNA}\nexport function siRnaBioSpringToAxolabs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'Uf', '2': 'Af', '3': 'Cf', '4': 'Gf', '5': 'u', '6': 'a', '7': 'c', '8': 'g', '*': 's' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToGcrs\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: GCRS}\nexport function siRnaBioSpringToGcrs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'fU', '2': 'fA', '3': 'fC', '4': 'fG', '5': 'mU', '6': 'mA', '7': 'mC', '8': 'mG', '*': 'ps' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToGcrs\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: GCRS}\nexport function siRnaAxolabsToGcrs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': 'fU', 'Af': 'fA', 'Cf': 'fC', 'Gf': 'fG', 'u': 'mU', 'a': 'mA', 'c': 'mC', 'g': 'mG', 's': 'ps',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToBioSpring\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaAxolabsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': '1', 'Af': '2', 'Cf': '3', 'Gf': '4', 'u': '5', 'a': '6', 'c': '7', 'g': '8', 's': '*',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToNucleotides\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaAxolabsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': 'U', 'Af': 'A', 'Cf': 'C', 'Gf': 'G', 'u': 'U', 'a': 'A', 'c': 'C', 'g': 'G', 's': '',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToNucleotides\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaGcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G', 'ps': '',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToBioSpring\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaGcrsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': '1', 'fA': '2', 'fC': '3', 'fG': '4', 'mU': '5', 'mA': '6', 'mC': '7', 'mG': '8', 'ps': '*',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToAxolabs\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: Axolabs / siRNA}\nexport function siRnaGcrsToAxolabs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': 'Uf', 'fA': 'Af', 'fC': 'Cf', 'fG': 'Gf', 'mU': 'u', 'mA': 'a', 'mC': 'c', 'mG': 'g', 'ps': 's',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaNucleotideToBioSpringSenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaNucleotideToBioSpringSenseStrand(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '6*', 'U': '5*', 'G': '8*', 'C': '7*' };\n    const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '*6', 'U': '*5', 'G': '*8', 'C': '*7' };\n    const objForOddIndices = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '6', 'U': '5', 'G': '8', 'C': '7' };\n    const objForEvenIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': '2', 'U': '1', 'G': '4', 'C': '3' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count > nucleotides.length - 3)\n            return objForRightEdge[x];\n        return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];\n    });\n}\n//name: siRnaNucleotidesToGcrs\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: GCRS}\nexport function siRnaNucleotidesToGcrs(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'mAps', 'U': 'mUps', 'G': 'mGps', 'C': 'mCps' };\n    const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'psmA', 'U': 'psmU', 'G': 'psmG', 'C': 'psmC' };\n    const objForEvenIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'fA', 'U': 'fU', 'G': 'fG', 'C': 'fC' };\n    const objForOddIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'mA', 'U': 'mU', 'G': 'mG', 'C': 'mC' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count > nucleotides.length - 3)\n            return objForRightEdge[x];\n        return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];\n    });\n}\n//name: siRnaNucleotideToAxolabsSenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: Axolabs}\nexport function siRnaNucleotideToAxolabsSenseStrand(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };\n    const objForSomeIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count == 6 || (count > 7 && count < 11))\n            return objForSomeIndices[x];\n        if (count == nucleotides.length - 1)\n            return 'a';\n        return obj[x];\n    });\n}\n//name: siRnaNucleotideToAxolabsAntisenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: Axolabs}\nexport function siRnaNucleotideToAxolabsAntisenseStrand(nucleotides) {\n    let count = -1;\n    const objForSmallLinkages = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };\n    const objForBigLinkages = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Afs', 'U': 'Ufs', 'G': 'Gfs', 'C': 'Cfs' };\n    const objForSomeIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };\n    const obj = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count > 19 && count < 22)\n            return objForSmallLinkages[x];\n        if (count == 0)\n            return 'us';\n        if (count == 1)\n            return objForBigLinkages[x];\n        return (count == 5 || count == 7 || count == 8 || count == 13 || count == 15) ? objForSomeIndices[x] : obj[x];\n    });\n}\n//name: gcrsToNucleotides\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: RNA nucleotides}\nexport function gcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'mAps': 'A', 'mUps': 'U', 'mGps': 'G', 'mCps': 'C', 'fAps': 'A', 'fUps': 'U', 'fGps': 'G', 'fCps': 'C',\n        'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });\n}\n//name: gcrsToMermade12\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: Mermade 12 / siRNA}\nexport function gcrsToMermade12(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'mAps': 'e', 'mUps': 'h', 'mGps': 'g', 'mCps': 'f', 'fAps': 'i', 'fUps': 'l', 'fGps': 'k', 'fCps': 'j', 'fU': 'L',\n        'fA': 'I', 'fC': 'J', 'fG': 'K', 'mU': 'H', 'mA': 'E', 'mC': 'F', 'mG': 'G',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });\n}\n","import { map, stadardPhosphateLinkSmiles, SYNTHESIZERS, TECHNOLOGIES, MODIFICATIONS } from './map';\nimport { isValidSequence } from './sequence-codes-tools';\nimport { getNucleotidesMol } from './mol-transformations';\nexport function sequenceToMolV3000(sequence, inverted = false, oclRender = false, 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);\n    while (i < sequence.length) {\n        const code = codes.find((s) => s == sequence.slice(i, i + s.length));\n        i += code.length;\n        inverted ? codesList.unshift(code) : codesList.push(code);\n    }\n    for (let i = 0; i < codesList.length; i++) {\n        if (dropdowns.includes(codesList[i])) {\n            smilesCodes.push((i >= codesList.length / 2) ?\n                MODIFICATIONS[codesList[i]].right : MODIFICATIONS[codesList[i]].left);\n            smilesCodes.push(stadardPhosphateLinkSmiles);\n        }\n        else {\n            if (links.includes(codesList[i]) ||\n                includesStandardLinkAlready.includes(codesList[i]) ||\n                (i < codesList.length - 1 && links.includes(codesList[i + 1])))\n                smilesCodes.push(obj[codesList[i]]);\n            else {\n                smilesCodes.push(obj[codesList[i]]);\n                smilesCodes.push(stadardPhosphateLinkSmiles);\n            }\n        }\n    }\n    return getNucleotidesMol(smilesCodes, oclRender);\n}\nexport function sequenceToSmiles(sequence, inverted = false, 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);\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    // 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 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_MASS: 'Salt mass',\n    BATCH_MW: 'Batch MW',\n    SOURCE: 'Source',\n    ICD: 'ICD',\n    OWNER: 'Owner',\n};\n// interface CODES {\n// }\nexport const MODIFICATIONS = {\n    '(invabasic)': {\n        molecularWeight: 118.13,\n        left: 'O[C@@H]1C[C@@H]O[C@H]1CO',\n        right: 'O[C@@H]1C[C@@H]O[C@H]1CO',\n    },\n    '(GalNAc-2-JNJ)': {\n        molecularWeight: 1273.3,\n        left: 'C(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)NC(=O)CCCC(=O)NCC(O)CO',\n        right: 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)',\n    },\n};\nexport const stadardPhosphateLinkSmiles = 'OP(=O)(O)O';\nexport const map = {\n    'Raw Nucleotides': {\n        'DNA': {\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n        },\n        'RNA': {\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'U': {\n                'name': 'Uracil',\n                'weight': 306.17,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n        },\n    },\n    'BioSpring Codes': {\n        'For ASO Gapmers': {\n            '5': {\n                'name': '2\\'MOE-5Me-rU',\n                'weight': 378.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '6': {\n                'name': '2\\'MOE-rA',\n                'weight': 387.29,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '7': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '8': {\n                'name': '2\\'MOE-rG',\n                'weight': 403.28,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '9': {\n                'name': '5-Methyl-dC',\n                'weight': 303.21,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            '*': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n        },\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            '1': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            '2': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            '3': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            '4': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            '5': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            '6': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            '7': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            '8': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            '*': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n        },\n    },\n    'Axolabs Codes': {\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'Uf': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'Af': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'Cf': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'Gf': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'u': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'a': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'c': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'g': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            's': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n        },\n    },\n    'Janssen GCRS Codes': {\n        'For ASO Gapmers': {\n            'moeT': {\n                'name': '2\\'MOE-5Me-rU',\n                'weight': 378.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            'moeA': {\n                'name': '2\\'MOE-rA',\n                'weight': 387.29,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            'moe5mC': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '(5m)moeC': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            'moeG': {\n                'name': '2\\'MOE-rG',\n                'weight': 403.28,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '5mC': {\n                'name': '5-Methyl-dC',\n                'weight': 303.28,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            '(5m)C': {\n                'name': '5-Methyl-dC',\n                'weight': 303.28,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            'ps': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'dA': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'dC': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'dG': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'dT': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'rA': {\n                'name': 'Adenine',\n                'weight': 329.21,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](O)[C@@H]1O',\n            },\n            'rC': {\n                'name': 'Cytosine',\n                'weight': 305.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](O)[C@@H]1O',\n            },\n            'rG': {\n                'name': 'Guanine',\n                'weight': 345.21,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](O)[C@@H]1O',\n            },\n            'rU': {\n                'name': 'Uracil',\n                'weight': 306.17,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',\n            },\n        },\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'fU': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'fA': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'fC': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'fG': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'mU': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'mA': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'mC': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'mG': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n        },\n        '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, oclRender = false) {\n    const molBlocks = [];\n    for (let i = 0; i < smilesCodes.length - 1; i++) {\n        smilesCodes[i] == 'OP(=O)(O)O' ? molBlocks.push(PHOSHATE) :\n            smilesCodes[i] == 'OP(=O)(S)O' ? molBlocks.push(THIOPHOSHATE) :\n                smilesCodes[i] == 'O[C@@H]1C[C@@H]O[C@H]1CO' ? molBlocks.push(rotateNucleotidesV3000(INVABASIC)) :\n                    molBlocks.push(rotateNucleotidesV3000(smilesCodes[i]));\n    }\n    return linkV3000(molBlocks, false, oclRender);\n}\nexport function linkV3000(molBlocks, twoChains = false, oclRender = false) {\n    let macroMolBlock = '\\nDatagrok macromolecule handler\\n\\n';\n    macroMolBlock += '  0  0  0  0  0  0            999 V3000\\n';\n    macroMolBlock += 'M  V30 BEGIN CTAB\\n';\n    let atomBlock = '';\n    let bondBlock = '';\n    let collectionBlock = '';\n    const collection = [];\n    let natom = 0;\n    let nbond = 0;\n    let 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    }\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    macroMolBlock += 'M  V30 BEGIN COLLECTION\\n';\n    macroMolBlock += collectionBlock;\n    macroMolBlock += 'M  V30 END COLLECTION\\n';\n    macroMolBlock += 'M  V30 END CTAB\\n';\n    macroMolBlock += 'M  END\\n';\n    return macroMolBlock;\n}\nfunction rotateNucleotidesV3000(molecule) {\n    // @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 * as ui from 'datagrok-api/ui';\nimport { sequenceToMolV3000 } from '../structures-works/from-monomers';\nimport { linkV3000 } from '../structures-works/mol-transformations';\nimport { getFormat } from '../structures-works/sequence-codes-tools';\nexport function saveSdf(as, ss, oneEntity, fit3dx) {\n    const formatAs = getFormat(as);\n    const formatSs = getFormat(ss);\n    const molSS = sequenceToMolV3000(ss, false, false, formatSs);\n    const molAS = sequenceToMolV3000(as, true, false, formatAs);\n    let result;\n    if (oneEntity)\n        result = linkV3000([molSS, molAS], true, !fit3dx) + '\\n\\n$$$$\\n';\n    else {\n        result =\n            molSS + '\\n' +\n                `>  <Sequence>\\nSense Strand\\n\\n$$$$\\n` +\n                molAS + '\\n' +\n                `>  <Sequence>\\nAnti Sense\\n\\n$$$$\\n`;\n    }\n    const element = document.createElement('a');\n    element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(result));\n    element.setAttribute('download', ss.replace(/\\s/g, '') + '.sdf');\n    element.click();\n}\nexport function saveSenseAntiSense() {\n    const moleculeSvgDiv = ui.block([]);\n    const ssInput = ui.textInput('Sense Strand 5\\' ->3\\'', '');\n    const asInput = ui.textInput('Anti Sense 3\\' ->5\\'', '');\n    const saveOption = ui.switchInput('Save as one entity', true);\n    const save3dx = ui.switchInput('Save 3dx', true);\n    const saveBtn = ui.button('Save SDF', () => saveSdf(asInput.value, ssInput.value, saveOption.value, save3dx.value));\n    const saveSection = ui.panel([\n        ui.div([\n            ui.div([\n                ui.divH([ui.h1('Inputs')]),\n                ui.divV([\n                    ui.div([ssInput.root]),\n                    ui.div([asInput.root]),\n                    saveOption,\n                    save3dx,\n                    ui.buttonsInput([saveBtn]),\n                ], 'ui-form'),\n            ], 'ui-form'),\n        ], 'ui-form'),\n        moleculeSvgDiv,\n    ]);\n    return saveSection;\n}\n","import { map, SYNTHESIZERS, TECHNOLOGIES, MODIFICATIONS } from './map';\nimport { asoGapmersNucleotidesToBioSpring, asoGapmersNucleotidesToGcrs, asoGapmersBioSpringToNucleotides, asoGapmersBioSpringToGcrs, asoGapmersGcrsToNucleotides, asoGapmersGcrsToBioSpring, gcrsToMermade12, siRnaNucleotideToBioSpringSenseStrand, siRnaNucleotideToAxolabsSenseStrand, siRnaNucleotidesToGcrs, siRnaBioSpringToNucleotides, siRnaBioSpringToAxolabs, siRnaBioSpringToGcrs, siRnaAxolabsToNucleotides, siRnaAxolabsToBioSpring, siRnaAxolabsToGcrs, siRnaGcrsToNucleotides, siRnaGcrsToBioSpring, siRnaGcrsToAxolabs, gcrsToNucleotides, 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}\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 = 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: null, technology: null };\n    outputIndex = 0;\n    possibleTechnologies.forEach((technology) => {\n        const codes = Object.keys(map[possibleSynthesizers[0]][technology]);\n        while (outputIndex < sequence.length) {\n            const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));\n            if (matchedCode == null)\n                break;\n            if ( // for mistake pattern 'rAA'\n            outputIndex > 1 &&\n                nucleotides.includes(sequence[outputIndex]) &&\n                firstUniqueCharacters.includes(sequence[outputIndex - 2]))\n                break;\n            if ( // for mistake pattern 'ArA'\n            firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&\n                nucleotides.includes(sequence[outputIndex])) {\n                outputIndex++;\n                break;\n            }\n            outputIndex += matchedCode.length;\n        }\n    });\n    return {\n        indexOfFirstNotValidChar: indexOfFirstNotValidChar,\n        synthesizer: possibleSynthesizers,\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(',');\n}\nfunction getListOfPossibleSynthesizersByFirstMatchedCode(sequence) {\n    const synthesizers = [];\n    Object.keys(map).forEach((synthesizer) => {\n        const codes = getAllCodesOfSynthesizer(synthesizer);\n        //TODO: get first non-dropdown code when there are two modifications\n        let start = 0;\n        for (let i = 0; i < sequence.length; i++) {\n            if (sequence[i] == ')' && i != sequence.length - 1) {\n                start = i + 1;\n                break;\n            }\n        }\n        if (codes.some((s) => s == sequence.slice(start, start + s.length)))\n            synthesizers.push(synthesizer);\n    });\n    return synthesizers;\n}\nfunction getListOfPossibleTechnologiesByFirstMatchedCode(sequence, synthesizer) {\n    const technologies = [];\n    Object.keys(map[synthesizer]).forEach((technology) => {\n        const codes = Object.keys(map[synthesizer][technology]).concat(Object.keys(MODIFICATIONS));\n        if (codes.some((s) => s == sequence.slice(0, s.length)))\n            technologies.push(technology);\n    });\n    return technologies;\n}\nexport function convertSequence(sequence, output) {\n    if (output.indexOfFirstNotValidChar != -1) {\n        return {\n            // type: '',\n            indexOfFirstNotValidChar: JSON.stringify(output),\n            Error: undefinedInputSequence,\n        };\n    }\n    if (output.synthesizer.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","export const USERS_CSV = `DISPLAY\nNO DATA\n`;\n","module.exports = DG;","module.exports = grok;","module.exports = ui;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nvar _a;\n/* Do not change these import lines. Datagrok will import API library in exactly the same manner */\nimport * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\nimport $ from 'cash-dom';\nimport { defineAxolabsPattern } from './defineAxolabsPattern';\nimport { saveSenseAntiSense } from './structures-works/save-sense-antisense';\nimport { sequenceToSmiles, sequenceToMolV3000 } from './structures-works/from-monomers';\nimport { convertSequence, undefinedInputSequence, isValidSequence, getFormat } from './structures-works/sequence-codes-tools';\nimport { map, COL_NAMES, MODIFICATIONS } from './structures-works/map';\nimport { siRnaAxolabsToGcrs, gcrsToNucleotides, asoGapmersBioSpringToGcrs, gcrsToMermade12, } from './structures-works/converters';\nimport { SALTS_CSV } from './salts';\nimport { USERS_CSV } from './users';\nimport { ICDS } from './ICDs';\nimport { SOURCES } from './sources';\nimport { IDPS } from './IDPs';\nexport const _package = new DG.Package();\nconst defaultInput = 'fAmCmGmAmCpsmU';\nconst sequenceWasCopied = 'Copied';\nconst tooltipSequence = 'Copy sequence';\n//name: Sequence Translator\n//tags: app\nexport function sequenceTranslator() {\n    const windows = grok.shell.windows;\n    windows.showProperties = false;\n    windows.showToolbox = false;\n    windows.showHelp = false;\n    function updateTableAndMolecule(sequence, inputFormat, isSet) {\n        moleculeSvgDiv.innerHTML = '';\n        outputTableDiv.innerHTML = '';\n        const pi = DG.TaskBarProgressIndicator.create('Rendering table and molecule...');\n        let errorsExist = false;\n        try {\n            sequence = sequence.replace(/\\s/g, '');\n            const output = isValidSequence(sequence, null);\n            if (isSet)\n                output.synthesizer = [inputFormat];\n            inputFormatChoiceInput.value = output.synthesizer[0];\n            const outputSequenceObj = convertSequence(sequence, output);\n            const tableRows = [];\n            for (const key of Object.keys(outputSequenceObj).slice(1)) {\n                const indexOfFirstNotValidChar = ('indexOfFirstNotValidChar' in outputSequenceObj) ?\n                    JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).indexOfFirstNotValidChar :\n                    -1;\n                if ('indexOfFirstNotValidChar' in outputSequenceObj) {\n                    const indexOfFirstNotValidChar = ('indexOfFirstNotValidChar' in outputSequenceObj) ?\n                        JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).indexOfFirstNotValidChar :\n                        -1;\n                    if (indexOfFirstNotValidChar != -1)\n                        errorsExist = true;\n                }\n                tableRows.push({\n                    'key': key,\n                    'value': ('indexOfFirstNotValidChar' in outputSequenceObj) ?\n                        ui.divH([\n                            ui.divText(sequence.slice(0, indexOfFirstNotValidChar), { style: { color: 'grey' } }),\n                            ui.tooltip.bind(ui.divText(sequence.slice(indexOfFirstNotValidChar), { style: { color: 'red' } }), 'Expected format: ' + JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).synthesizer +\n                                '. See tables with valid codes on the right'),\n                        ]) : //@ts-ignore\n                        ui.link(outputSequenceObj[key], () => navigator.clipboard.writeText(outputSequenceObj[key])\n                            .then(() => grok.shell.info(sequenceWasCopied)), tooltipSequence, ''),\n                });\n            }\n            if (errorsExist) {\n                const synthesizer = JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).synthesizer.slice(0, -6);\n                asoGapmersGrid.onCellPrepare(function (gc) {\n                    gc.style.backColor = (gc.gridColumn.name == synthesizer) ? 0xFFF00000 : 0xFFFFFFFF;\n                });\n                omeAndFluoroGrid.onCellPrepare(function (gc) {\n                    gc.style.backColor = (gc.gridColumn.name == synthesizer) ? 0xFFF00000 : 0xFFFFFFFF;\n                });\n                switchInput.enabled = true;\n            }\n            else {\n                asoGapmersGrid.onCellPrepare(function (gc) { gc.style.backColor = 0xFFFFFFFF; });\n                omeAndFluoroGrid.onCellPrepare(function (gc) { gc.style.backColor = 0xFFFFFFFF; });\n            }\n            outputTableDiv.append(ui.div([\n                DG.HtmlTable.create(tableRows, (item) => [item.key, item.value], ['Code', 'Sequence']).root,\n            ]));\n            if (outputSequenceObj.type != undefinedInputSequence && outputSequenceObj.Error != undefinedInputSequence) {\n                const canvas = ui.canvas(300, 170);\n                canvas.addEventListener('click', () => {\n                    const canv = ui.canvas($(window).width(), $(window).height());\n                    const mol = sequenceToMolV3000(inputSequenceField.value.replace(/\\s/g, ''), false, true, output.synthesizer[0]);\n                    // @ts-ignore\n                    OCL.StructureView.drawMolecule(canv, OCL.Molecule.fromMolfile(mol), { suppressChiralText: true });\n                    ui.dialog('Molecule: ' + inputSequenceField.value)\n                        .add(canv)\n                        .showModal(true);\n                });\n                $(canvas).on('mouseover', () => $(canvas).css('cursor', 'zoom-in'));\n                $(canvas).on('mouseout', () => $(canvas).css('cursor', 'default'));\n                const mol = sequenceToMolV3000(inputSequenceField.value.replace(/\\s/g, ''), false, true, output.synthesizer[0]);\n                // @ts-ignore\n                OCL.StructureView.drawMolecule(canvas, OCL.Molecule.fromMolfile(mol), { suppressChiralText: true });\n                moleculeSvgDiv.append(canvas);\n            }\n            else\n                moleculeSvgDiv.innerHTML = '';\n        }\n        finally {\n            pi.close();\n        }\n    }\n    const inputFormatChoiceInput = ui.choiceInput('Input format: ', 'Janssen GCRS Codes', Object.keys(map), (format) => {\n        updateTableAndMolecule(inputSequenceField.value.replace(/\\s/g, ''), format, true);\n    });\n    const moleculeSvgDiv = ui.block([]);\n    const outputTableDiv = ui.div([]);\n    const inputSequenceField = ui.textInput('', defaultInput, (sequence) => updateTableAndMolecule(sequence, inputFormatChoiceInput.value, false));\n    const asoDf = DG.DataFrame.fromObjects([\n        { 'Name': '2\\'MOE-5Me-rU', 'BioSpring': '5', 'Janssen GCRS': 'moeT' },\n        { 'Name': '2\\'MOE-rA', 'BioSpring': '6', 'Janssen GCRS': 'moeA' },\n        { 'Name': '2\\'MOE-5Me-rC', 'BioSpring': '7', 'Janssen GCRS': 'moe5mC' },\n        { 'Name': '2\\'MOE-rG', 'BioSpring': '8', 'Janssen GCRS': 'moeG' },\n        { 'Name': '5-Methyl-dC', 'BioSpring': '9', 'Janssen GCRS': '5mC' },\n        { 'Name': 'ps linkage', 'BioSpring': '*', 'Janssen GCRS': 'ps' },\n        { 'Name': 'dA', 'BioSpring': 'A', 'Janssen GCRS': 'A, dA' },\n        { 'Name': 'dC', 'BioSpring': 'C', 'Janssen GCRS': 'C, dC' },\n        { 'Name': 'dG', 'BioSpring': 'G', 'Janssen GCRS': 'G, dG' },\n        { 'Name': 'dT', 'BioSpring': 'T', 'Janssen GCRS': 'T, dT' },\n        { 'Name': 'rA', 'BioSpring': '', 'Janssen GCRS': 'rA' },\n        { 'Name': 'rC', 'BioSpring': '', 'Janssen GCRS': 'rC' },\n        { 'Name': 'rG', 'BioSpring': '', 'Janssen GCRS': 'rG' },\n        { 'Name': 'rU', 'BioSpring': '', 'Janssen GCRS': 'rU' },\n    ]);\n    const asoGapmersGrid = DG.Viewer.grid(asoDf, { showRowHeader: false, showCellTooltip: false });\n    asoDf.onCurrentCellChanged.subscribe((_) => {\n        navigator.clipboard.writeText(asoDf.currentCell.value).then(() => grok.shell.info('Copied'));\n    });\n    const omeAndFluoroGrid = DG.Viewer.grid(DG.DataFrame.fromObjects([\n        { 'Name': '2\\'-fluoro-U', 'BioSpring': '1', 'Axolabs': 'Uf', 'Janssen GCRS': 'fU' },\n        { 'Name': '2\\'-fluoro-A', 'BioSpring': '2', 'Axolabs': 'Af', 'Janssen GCRS': 'fA' },\n        { 'Name': '2\\'-fluoro-C', 'BioSpring': '3', 'Axolabs': 'Cf', 'Janssen GCRS': 'fC' },\n        { 'Name': '2\\'-fluoro-G', 'BioSpring': '4', 'Axolabs': 'Gf', 'Janssen GCRS': 'fG' },\n        { 'Name': '2\\'OMe-rU', 'BioSpring': '5', 'Axolabs': 'u', 'Janssen GCRS': 'mU' },\n        { 'Name': '2\\'OMe-rA', 'BioSpring': '6', 'Axolabs': 'a', 'Janssen GCRS': 'mA' },\n        { 'Name': '2\\'OMe-rC', 'BioSpring': '7', 'Axolabs': 'c', 'Janssen GCRS': 'mC' },\n        { 'Name': '2\\'OMe-rG', 'BioSpring': '8', 'Axolabs': 'g', 'Janssen GCRS': 'mG' },\n        { 'Name': 'ps linkage', 'BioSpring': '*', 'Axolabs': 's', 'Janssen GCRS': 'ps' },\n    ]), { showRowHeader: false, showCellTooltip: false });\n    const overhangModificationsGrid = DG.Viewer.grid(DG.DataFrame.fromColumns([\n        DG.Column.fromStrings('Name', Object.keys(MODIFICATIONS)),\n    ]), { showRowHeader: false, showCellTooltip: false });\n    updateTableAndMolecule(defaultInput, inputFormatChoiceInput.value, true);\n    const appMainDescription = ui.info([\n        ui.divText('How to convert one sequence:', { style: { 'font-weight': 'bolder' } }),\n        ui.divText('Paste sequence into the text field below'),\n        ui.divText('\\n How to convert many sequences:', { style: { 'font-weight': 'bolder' } }),\n        ui.divText('1. Drag & drop an Excel or CSV file with sequences into Datagrok'),\n        ui.divText('2. Right-click on the column header, then see the \\'Convert\\' menu'),\n        ui.divText('This will add the result column to the right of the table'),\n    ], 'Convert oligonucleotide sequences between Nucleotides, BioSpring, Axolabs, Mermade 12 and GCRS representations.');\n    const codesTablesDiv = ui.splitV([\n        ui.box(ui.h2('ASO Gapmers'), { style: { maxHeight: '40px' } }),\n        asoGapmersGrid.root,\n        ui.box(ui.h2('2\\'-OMe and 2\\'-F siRNA'), { style: { maxHeight: '40px' } }),\n        omeAndFluoroGrid.root,\n        ui.box(ui.h2('Overhang modifications'), { style: { maxHeight: '40px' } }),\n        overhangModificationsGrid.root,\n    ], { style: { maxWidth: '350px' } });\n    const tabControl = ui.tabControl({\n        'MAIN': ui.box(ui.splitH([\n            ui.splitV([\n                ui.panel([\n                    appMainDescription,\n                    ui.div([\n                        ui.h1('Input sequence'),\n                        ui.div([\n                            inputSequenceField.root,\n                        ], 'input-base'),\n                    ], 'inputSequence'),\n                    ui.div([inputFormatChoiceInput], { style: { padding: '5px 0' } }),\n                    ui.block([\n                        ui.h1('Output'),\n                        outputTableDiv,\n                    ]),\n                    moleculeSvgDiv,\n                ], 'sequence'),\n            ]),\n            codesTablesDiv,\n        ], { style: { height: '100%', width: '100%' } })),\n        'AXOLABS': defineAxolabsPattern(),\n        'SDF': saveSenseAntiSense(),\n    });\n    $(codesTablesDiv).hide();\n    const v = grok.shell.newView('Sequence Translator', [tabControl]);\n    v.box = true;\n    const switchInput = ui.switchInput('Codes', false, (v) => (v) ?\n        $(codesTablesDiv).show() :\n        $(codesTablesDiv).hide());\n    const topPanel = [\n        ui.iconFA('download', () => {\n            const result = sequenceToMolV3000(inputSequenceField.value.replace(/\\s/g, ''), false, false, inputFormatChoiceInput.value);\n            const element = document.createElement('a');\n            element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(result));\n            element.setAttribute('download', inputSequenceField.value.replace(/\\s/g, '') + '.mol');\n            element.click();\n        }, 'Save .mol file'),\n        ui.iconFA('copy', () => {\n            navigator.clipboard.writeText(sequenceToSmiles(inputSequenceField.value.replace(/\\s/g, ''), false, inputFormatChoiceInput.value))\n                .then(() => grok.shell.info(sequenceWasCopied));\n        }, 'Copy SMILES'),\n        switchInput.root,\n    ];\n    tabControl.onTabChanged.subscribe((_) => v.setRibbonPanels([(tabControl.currentPane.name == 'MAIN') ? topPanel : []]));\n    v.setRibbonPanels([topPanel]);\n}\nfunction saveTableAsSdFile(table) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (!table.columns.contains('Compound Name')) {\n            grok.shell.warning('File saved without columns \\'' +\n                [COL_NAMES.COMPOUND_NAME, COL_NAMES.COMPOUND_COMMENTS, COL_NAMES.CPD_MW,\n                    COL_NAMES.SALT_MASS, COL_NAMES.BATCH_MW].join('\\', \\''));\n        }\n        const structureColumn = table.col(COL_NAMES.SEQUENCE);\n        const typeColumn = table.col(COL_NAMES.TYPE);\n        let result = '';\n        for (let i = 0; i < table.rowCount; i++) {\n            const format = getFormat(structureColumn.get(i));\n            result += (typeColumn.get(i) == 'SS') ?\n                sequenceToMolV3000(structureColumn.get(i), false, true, format) + '\\n' + `>  <Sequence>\\nSense Strand\\n\\n` :\n                sequenceToMolV3000(structureColumn.get(i), true, true, format) + '\\n' + `>  <Sequence>\\nAnti Sense\\n\\n`;\n            for (const col of table.columns) {\n                if (col.name != COL_NAMES.SEQUENCE)\n                    result += `>  <${col.name}>\\n${col.get(i)}\\n\\n`;\n            }\n            result += '$$$$\\n\\n';\n        }\n        const element = document.createElement('a');\n        element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(result));\n        element.setAttribute('download', table.name + '.sdf');\n        element.click();\n    });\n}\nconst weightsObj = {};\nfor (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            (_a = weightsObj[code]) !== null && _a !== void 0 ? _a : map[synthesizer][technology][code].weight;\n    }\n}\nfor (const [key, value] of Object.entries(MODIFICATIONS))\n    weightsObj[key] = value.molecularWeight;\nfunction sortByStringLengthInDescendingOrder(array) {\n    return array.sort(function (a, b) { return b.length - a.length; });\n}\nfunction stringifyItems(items) {\n    return '[\"' + items.join('\", \"') + '\"]';\n}\nfunction molecularWeight(sequence, weightsObj) {\n    const codes = sortByStringLengthInDescendingOrder(Object.keys(weightsObj)).concat(Object.keys(MODIFICATIONS));\n    let weight = 0;\n    let i = 0;\n    while (i < sequence.length) {\n        const matchedCode = codes.find((s) => s == sequence.slice(i, i + s.length));\n        weight += weightsObj[sequence.slice(i, i + matchedCode.length)];\n        i += matchedCode.length;\n    }\n    return weight - 61.97;\n}\n//tags: autostart\nexport function autostartOligoSdFileSubscription() {\n    grok.events.onViewAdded.subscribe((v) => {\n        if (v.type == 'TableView') {\n            if (v.dataFrame.columns.contains(COL_NAMES.TYPE))\n                oligoSdFile(v.dataFrame);\n            grok.events.onContextMenu.subscribe((args) => {\n                const seqCol = args.args.context.table.currentCol;\n                if (DG.Detector.sampleCategories(seqCol, (s) => /^[fsACGUacgu]{6,}$/.test(s))) {\n                    args.args.menu.item('Convert Axolabs to GCRS', () => {\n                        args.args.context.table.columns.addNewString(seqCol.name + ' to GCRS').init((i) => {\n                            return siRnaAxolabsToGcrs(seqCol.get(i));\n                        });\n                    });\n                }\n                else if (DG.Detector.sampleCategories(seqCol, (s) => /^[fmpsACGU]{6,}$/.test(s)) ||\n                    DG.Detector.sampleCategories(seqCol, (s) => /^(?=.*moe)(?=.*5mC)(?=.*ps){6,}/.test(s))) {\n                    args.args.menu.item('Convert GCRS to raw', () => {\n                        args.args.context.table.columns.addNewString(seqCol.name + ' to raw').init((i) => {\n                            return gcrsToNucleotides(seqCol.get(i));\n                        });\n                    });\n                    args.args.menu.item('Convert GCRS to MM12', () => {\n                        args.args.context.table.columns.addNewString(seqCol.name + ' to MM12').init((i) => {\n                            return gcrsToMermade12(seqCol.get(i));\n                        });\n                    });\n                }\n                else if (DG.Detector.sampleCategories(seqCol, (s) => /^[*56789ATGC]{6,}$/.test(s))) {\n                    args.args.menu.item('Convert Biospring to GCRS', () => {\n                        const seqCol = args.args.context.table.currentCol;\n                        args.args.context.table.columns.addNewString(seqCol.name + ' to GCRS').init((i) => {\n                            return asoGapmersBioSpringToGcrs(seqCol.get(i));\n                        });\n                    });\n                }\n                else if (DG.Detector.sampleCategories(seqCol, (s) => /^[*1-8]{6,}$/.test(s))) {\n                    args.args.menu.item('Convert Biospring to GCRS', () => {\n                        args.args.context.table.columns.addNewString(seqCol.name + ' to GCRS').init((i) => {\n                            return siRnaAxolabsToGcrs(seqCol.get(i));\n                        });\n                    });\n                }\n            });\n        }\n    });\n}\nexport function oligoSdFile(table) {\n    const saltsDf = DG.DataFrame.fromCsv(SALTS_CSV);\n    const usersDf = DG.DataFrame.fromCsv(USERS_CSV);\n    const sourcesDf = DG.DataFrame.fromCsv(SOURCES);\n    const icdsDf = DG.DataFrame.fromCsv(ICDS);\n    const idpsDf = DG.DataFrame.fromCsv(IDPS);\n    function addColumns(t, saltsDf) {\n        if (t.columns.contains(COL_NAMES.COMPOUND_NAME))\n            return grok.shell.error('Columns already exist!');\n        const sequence = t.col(COL_NAMES.SEQUENCE);\n        const salt = t.col(COL_NAMES.SALT);\n        const equivalents = t.col(COL_NAMES.EQUIVALENTS);\n        t.columns.addNewString(COL_NAMES.COMPOUND_NAME).init((i) => sequence.get(i));\n        t.columns.addNewString(COL_NAMES.COMPOUND_COMMENTS).init((i) => (i > 0 && i % 2 == 0) ?\n            sequence.getString(i) + '; duplex of SS: ' + sequence.getString(i - 2) + ' and AS: ' + sequence.getString(i - 1) :\n            sequence.getString(i));\n        const molWeightCol = saltsDf.col('MOLWEIGHT');\n        const saltNamesList = saltsDf.col('DISPLAY').toList();\n        t.columns.addNewFloat(COL_NAMES.CPD_MW)\n            .init((i) => molecularWeight(sequence.get(i), weightsObj));\n        t.columns.addNewFloat(COL_NAMES.SALT_MASS).init((i) => {\n            const saltRowIndex = saltNamesList.indexOf(salt.get(i));\n            const mw = molWeightCol.get(saltRowIndex);\n            return mw * equivalents.get(i);\n        });\n        t.columns.addNewCalculated(COL_NAMES.BATCH_MW, '${' + COL_NAMES.CPD_MW + '} + ${' + COL_NAMES.SALT_MASS + '}', DG.COLUMN_TYPE.FLOAT, false);\n        addColumnsPressed = true;\n        return newDf = t;\n    }\n    let newDf;\n    let addColumnsPressed = false;\n    const d = ui.div([\n        ui.icons.edit(() => {\n            d.innerHTML = '';\n            if (table.col(COL_NAMES.IDP).type != DG.COLUMN_TYPE.STRING)\n                table.changeColumnType(COL_NAMES.IDP, DG.COLUMN_TYPE.STRING);\n            d.append(ui.link('Add Columns', () => {\n                addColumns(table, saltsDf);\n                grok.shell.tableView(table.name).grid.columns.setOrder(Object.values(COL_NAMES));\n            }, 'Add columns: \\'' + [COL_NAMES.COMPOUND_NAME, COL_NAMES.COMPOUND_COMMENTS, COL_NAMES.CPD_MW,\n                COL_NAMES.SALT_MASS, COL_NAMES.BATCH_MW].join('\\', \\''), ''), ui.button('Save SD file', () => saveTableAsSdFile(addColumnsPressed ? newDf : table)));\n            const view = grok.shell.getTableView(table.name);\n            view.table.col(COL_NAMES.TYPE).setTag(DG.TAGS.CHOICES, '[\"AS\", \"SS\", \"Duplex\"]');\n            view.table.col(COL_NAMES.OWNER).setTag(DG.TAGS.CHOICES, stringifyItems(usersDf.columns.byIndex(0).toList()));\n            view.table.col(COL_NAMES.SALT).setTag(DG.TAGS.CHOICES, stringifyItems(saltsDf.columns.byIndex(0).toList()));\n            view.table.col(COL_NAMES.SOURCE).setTag(DG.TAGS.CHOICES, stringifyItems(sourcesDf.columns.byIndex(0).toList()));\n            view.table.col(COL_NAMES.ICD).setTag(DG.TAGS.CHOICES, stringifyItems(icdsDf.columns.byIndex(0).toList()));\n            view.table.col(COL_NAMES.IDP).setTag(DG.TAGS.CHOICES, stringifyItems(idpsDf.columns.byIndex(0).toList()));\n            grok.events.onContextMenu.subscribe((args) => {\n                if ([COL_NAMES.TYPE, COL_NAMES.OWNER, COL_NAMES.SALT, COL_NAMES.SOURCE, COL_NAMES.ICD, COL_NAMES.IDP]\n                    .includes(args.args.context.table.currentCol.name)) {\n                    args.args.menu.item('Fill Column With Value', () => {\n                        const v = args.args.context.table.currentCell.value;\n                        args.args.context.table.currentCell.column.init(v);\n                    });\n                }\n            });\n        }),\n    ]);\n    grok.shell.v.setRibbonPanels([[d]]);\n}\n"],"names":[],"sourceRoot":""}
|