@datagrok/sequence-translator 1.0.5 → 1.0.6
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 +10 -8
- package/dist/package-test.js +46 -31
- package/dist/package.js +116 -85
- package/package.json +8 -4
- package/src/__jest__/remote.test.ts +4 -4
- package/src/__jest__/test-node.ts +3 -2
- package/src/autostart/registration.ts +49 -37
- package/src/structures-works/converters.ts +3 -3
- package/src/structures-works/from-monomers.ts +1 -1
- package/src/structures-works/map.ts +6 -0
- package/src/structures-works/mol-transformations.ts +17 -15
- package/src/structures-works/save-sense-antisense.ts +24 -11
- package/src/structures-works/sequence-codes-tools.ts +12 -4
- package/test-SequenceTranslator-d3cbf13cf137-2cb8277f.html +276 -0
- package/test-SequenceTranslator-4f0c8bae6479-6545fe31.html +0 -276
package/dist/package.js
CHANGED
|
@@ -1910,7 +1910,6 @@ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _argume
|
|
|
1910
1910
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
1911
1911
|
});
|
|
1912
1912
|
};
|
|
1913
|
-
var _a;
|
|
1914
1913
|
|
|
1915
1914
|
|
|
1916
1915
|
|
|
@@ -1923,15 +1922,6 @@ var _a;
|
|
|
1923
1922
|
|
|
1924
1923
|
|
|
1925
1924
|
|
|
1926
|
-
const weightsObj = {};
|
|
1927
|
-
for (const synthesizer of Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.map)) {
|
|
1928
|
-
for (const technology of Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.map[synthesizer])) {
|
|
1929
|
-
for (const code of Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.map[synthesizer][technology]))
|
|
1930
|
-
(_a = weightsObj[code]) !== null && _a !== void 0 ? _a : _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.map[synthesizer][technology][code].weight;
|
|
1931
|
-
}
|
|
1932
|
-
}
|
|
1933
|
-
for (const [key, value] of Object.entries(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.MODIFICATIONS))
|
|
1934
|
-
weightsObj[key] = value.molecularWeight;
|
|
1935
1925
|
function sortByStringLengthInDescendingOrder(array) {
|
|
1936
1926
|
return array.sort(function (a, b) { return b.length - a.length; });
|
|
1937
1927
|
}
|
|
@@ -1960,7 +1950,7 @@ function saveTableAsSdFile(table) {
|
|
|
1960
1950
|
const typeColumn = table.getCol(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.TYPE);
|
|
1961
1951
|
let result = '';
|
|
1962
1952
|
for (let i = 0; i < table.rowCount; i++) {
|
|
1963
|
-
const format =
|
|
1953
|
+
const format = 'Janssen GCRS Codes'; //getFormat(structureColumn.get(i))!;
|
|
1964
1954
|
result += (typeColumn.get(i) == 'SS') ?
|
|
1965
1955
|
(0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_6__.sequenceToMolV3000)(structureColumn.get(i), false, true, format) + '\n' + `> <Sequence>\nSense Strand\n\n` :
|
|
1966
1956
|
(0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_6__.sequenceToMolV3000)(structureColumn.get(i), true, true, format) + '\n' + `> <Sequence>\nAnti Sense\n\n`;
|
|
@@ -1982,15 +1972,15 @@ function autostartOligoSdFileSubscription() {
|
|
|
1982
1972
|
if (v.dataFrame.columns.contains(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.TYPE))
|
|
1983
1973
|
oligoSdFile(v.dataFrame);
|
|
1984
1974
|
datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.events.onContextMenu.subscribe((args) => {
|
|
1985
|
-
const seqCol = args.args.context.table.currentCol;
|
|
1986
|
-
if (datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) =>
|
|
1975
|
+
const seqCol = args.args.context.table.currentCol; // /^[fsACGUacgu]{6,}$/
|
|
1976
|
+
if (datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) => /(\(invabasic\)|\(GalNAc-2-JNJ\)|f|s|A|C|G|U|a|c|g|u){6,}$/.test(s))) {
|
|
1987
1977
|
args.args.menu.item('Convert Axolabs to GCRS', () => {
|
|
1988
1978
|
args.args.context.table.columns.addNewString(seqCol.name + ' to GCRS').init((i) => {
|
|
1989
1979
|
return (0,_structures_works_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaAxolabsToGcrs)(seqCol.get(i));
|
|
1990
1980
|
});
|
|
1991
|
-
});
|
|
1981
|
+
}); // /^[fmpsACGU]{6,}$/
|
|
1992
1982
|
}
|
|
1993
|
-
else if (datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) =>
|
|
1983
|
+
else if (datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) => /(\(invabasic\)|\(GalNAc-2-JNJ\)|f|m|ps|A|C|G|U){6,}$/.test(s)) ||
|
|
1994
1984
|
datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) => /^(?=.*moe)(?=.*5mC)(?=.*ps){6,}/.test(s))) {
|
|
1995
1985
|
args.args.menu.item('Convert GCRS to raw', () => {
|
|
1996
1986
|
args.args.context.table.columns.addNewString(seqCol.name + ' to raw').init((i) => {
|
|
@@ -2001,17 +1991,17 @@ function autostartOligoSdFileSubscription() {
|
|
|
2001
1991
|
args.args.context.table.columns.addNewString(seqCol.name + ' to MM12').init((i) => {
|
|
2002
1992
|
return (0,_structures_works_converters__WEBPACK_IMPORTED_MODULE_3__.gcrsToMermade12)(seqCol.get(i));
|
|
2003
1993
|
});
|
|
2004
|
-
});
|
|
1994
|
+
}); // /^[*56789ATGC]{6,}$/
|
|
2005
1995
|
}
|
|
2006
|
-
else if (datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) =>
|
|
1996
|
+
else if (datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) => /(\(invabasic\)|\(GalNAc-2-JNJ\)|\*|5|6|7|8|9|A|T|G|C){6,}$/.test(s))) {
|
|
2007
1997
|
args.args.menu.item('Convert Biospring to GCRS', () => {
|
|
2008
1998
|
const seqCol = args.args.context.table.currentCol;
|
|
2009
1999
|
args.args.context.table.columns.addNewString(seqCol.name + ' to GCRS').init((i) => {
|
|
2010
2000
|
return (0,_structures_works_converters__WEBPACK_IMPORTED_MODULE_3__.asoGapmersBioSpringToGcrs)(seqCol.get(i));
|
|
2011
2001
|
});
|
|
2012
|
-
});
|
|
2002
|
+
}); // /^[*1-8]{6,}$/
|
|
2013
2003
|
}
|
|
2014
|
-
else if (datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) =>
|
|
2004
|
+
else if (datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) => /(\(invabasic\)|\(GalNAc-2-JNJ\)|\*|1|2|3|4|5|6|7|8){6,}$/.test(s))) {
|
|
2015
2005
|
args.args.menu.item('Convert Biospring to GCRS', () => {
|
|
2016
2006
|
args.args.context.table.columns.addNewString(seqCol.name + ' to GCRS').init((i) => {
|
|
2017
2007
|
return (0,_structures_works_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaAxolabsToGcrs)(seqCol.get(i));
|
|
@@ -2029,27 +2019,42 @@ function oligoSdFile(table) {
|
|
|
2029
2019
|
const icdsDf = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromCsv(_ICDs__WEBPACK_IMPORTED_MODULE_9__.ICDS);
|
|
2030
2020
|
const idpsDf = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromCsv(_IDPs__WEBPACK_IMPORTED_MODULE_11__.IDPS);
|
|
2031
2021
|
function addColumns(t, saltsDf) {
|
|
2032
|
-
|
|
2033
|
-
|
|
2034
|
-
|
|
2035
|
-
|
|
2036
|
-
|
|
2037
|
-
|
|
2038
|
-
|
|
2039
|
-
|
|
2040
|
-
|
|
2041
|
-
|
|
2042
|
-
|
|
2043
|
-
|
|
2044
|
-
|
|
2045
|
-
|
|
2046
|
-
|
|
2047
|
-
|
|
2048
|
-
|
|
2022
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
2023
|
+
if (t.columns.contains(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.COMPOUND_NAME))
|
|
2024
|
+
return datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.error('Columns already exist');
|
|
2025
|
+
const sequenceCol = t.getCol(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.SEQUENCE);
|
|
2026
|
+
const saltCol = t.getCol(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.SALT);
|
|
2027
|
+
const equivalentsCol = t.getCol(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.EQUIVALENTS);
|
|
2028
|
+
t.columns.addNewString(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.COMPOUND_NAME).init((i) => sequenceCol.get(i));
|
|
2029
|
+
t.columns.addNewString(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.COMPOUND_COMMENTS).init((i) => (i > 0 && i % 2 == 0) ?
|
|
2030
|
+
sequenceCol.get(i) + '; duplex of SS: ' + sequenceCol.get(i - 2) + ' and AS: ' + sequenceCol.get(i - 1) :
|
|
2031
|
+
sequenceCol.get(i));
|
|
2032
|
+
const molWeightCol = saltsDf.getCol('MOLWEIGHT');
|
|
2033
|
+
const saltNamesList = saltsDf.getCol('DISPLAY').toList();
|
|
2034
|
+
const weightsObj = {};
|
|
2035
|
+
for (const synthesizer of Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.map)) {
|
|
2036
|
+
for (const technology of Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.map[synthesizer])) {
|
|
2037
|
+
for (const code of Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.map[synthesizer][technology]))
|
|
2038
|
+
weightsObj[code] = _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.map[synthesizer][technology][code].weight;
|
|
2039
|
+
}
|
|
2040
|
+
}
|
|
2041
|
+
for (const [key, value] of Object.entries(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.MODIFICATIONS))
|
|
2042
|
+
weightsObj[key] = value.molecularWeight;
|
|
2043
|
+
t.columns.addNewFloat(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.CPD_MW).init((i) => {
|
|
2044
|
+
return ((0,_structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_5__.isValidSequence)(sequenceCol.get(i), null).indexOfFirstNotValidChar == -1) ?
|
|
2045
|
+
molecularWeight(sequenceCol.get(i), weightsObj) :
|
|
2046
|
+
datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.FLOAT_NULL;
|
|
2047
|
+
});
|
|
2048
|
+
t.columns.addNewFloat(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.SALT_MASS).init((i) => {
|
|
2049
|
+
const saltRowIndex = saltNamesList.indexOf(saltCol.get(i));
|
|
2050
|
+
return (saltRowIndex == -1) ?
|
|
2051
|
+
datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.FLOAT_NULL :
|
|
2052
|
+
molWeightCol.get(saltRowIndex) * equivalentsCol.get(i);
|
|
2053
|
+
});
|
|
2054
|
+
yield t.columns.addNewCalculated(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.BATCH_MW, '${' + _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.CPD_MW + '} + ${' + _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.SALT_MASS + '}', datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.COLUMN_TYPE.FLOAT, false);
|
|
2055
|
+
addColumnsPressed = true;
|
|
2056
|
+
return newDf = t;
|
|
2049
2057
|
});
|
|
2050
|
-
t.columns.addNewCalculated(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.BATCH_MW, '${' + _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.CPD_MW + '} + ${' + _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.SALT_MASS + '}', datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.COLUMN_TYPE.FLOAT, false);
|
|
2051
|
-
addColumnsPressed = true;
|
|
2052
|
-
return newDf = t;
|
|
2053
2058
|
}
|
|
2054
2059
|
let newDf;
|
|
2055
2060
|
let addColumnsPressed = false;
|
|
@@ -2058,10 +2063,10 @@ function oligoSdFile(table) {
|
|
|
2058
2063
|
d.innerHTML = '';
|
|
2059
2064
|
if (table.getCol(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.IDP).type != datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.COLUMN_TYPE.STRING)
|
|
2060
2065
|
table.changeColumnType(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.IDP, datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.COLUMN_TYPE.STRING);
|
|
2061
|
-
d.append(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.link('Add Columns', () => {
|
|
2062
|
-
addColumns(table, saltsDf);
|
|
2063
|
-
|
|
2064
|
-
}, 'Add columns: \'' + [_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.COMPOUND_NAME, _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.COMPOUND_COMMENTS, _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.CPD_MW,
|
|
2066
|
+
d.append(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.link('Add Columns', () => __awaiter(this, void 0, void 0, function* () {
|
|
2067
|
+
yield addColumns(table, saltsDf);
|
|
2068
|
+
view.grid.columns.setOrder(Object.values(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES));
|
|
2069
|
+
}), 'Add columns: \'' + [_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.COMPOUND_NAME, _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.COMPOUND_COMMENTS, _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.CPD_MW,
|
|
2065
2070
|
_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.SALT_MASS, _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.BATCH_MW].join('\', \''), ''), datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.button('Save SD file', () => saveTableAsSdFile(addColumnsPressed ? newDf : table)));
|
|
2066
2071
|
const view = datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.getTableView(table.name);
|
|
2067
2072
|
view.dataFrame.getCol(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.TYPE).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, '["AS", "SS", "Duplex"]');
|
|
@@ -3470,9 +3475,9 @@ function gcrsToLcms(sequence) {
|
|
|
3470
3475
|
}
|
|
3471
3476
|
const regExp = new RegExp('(' + arr1.join('|') + ')', 'g');
|
|
3472
3477
|
let r1 = sequence.replace(regExp, function (code) { return obj[code]; });
|
|
3473
|
-
|
|
3474
|
-
|
|
3475
|
-
return r1
|
|
3478
|
+
while (r1.indexOf('//') != -1)
|
|
3479
|
+
r1 = r1.replace('//', '/');
|
|
3480
|
+
return r1;
|
|
3476
3481
|
}
|
|
3477
3482
|
//name: asoGapmersNucleotidesToBioSpring
|
|
3478
3483
|
//input: string nucleotides {semType: DNA nucleotides}
|
|
@@ -3793,7 +3798,7 @@ function sequenceToMolV3000(sequence, inverted = false, oclRender = false, forma
|
|
|
3793
3798
|
}
|
|
3794
3799
|
}
|
|
3795
3800
|
}
|
|
3796
|
-
return (0,_mol_transformations__WEBPACK_IMPORTED_MODULE_2__.getNucleotidesMol)(smilesCodes
|
|
3801
|
+
return (0,_mol_transformations__WEBPACK_IMPORTED_MODULE_2__.getNucleotidesMol)(smilesCodes);
|
|
3797
3802
|
}
|
|
3798
3803
|
function sequenceToSmiles(sequence, inverted = false, format) {
|
|
3799
3804
|
const obj = getObjectWithCodesAndSmiles(sequence, format);
|
|
@@ -4227,6 +4232,12 @@ const map = {
|
|
|
4227
4232
|
'normalized': '',
|
|
4228
4233
|
'SMILES': 'OP(=O)(S)O',
|
|
4229
4234
|
},
|
|
4235
|
+
's': {
|
|
4236
|
+
'name': 'ps linkage',
|
|
4237
|
+
'weight': 16.07,
|
|
4238
|
+
'normalized': '',
|
|
4239
|
+
'SMILES': 'OP(=O)(S)O',
|
|
4240
|
+
},
|
|
4230
4241
|
'A': {
|
|
4231
4242
|
'name': 'Adenine',
|
|
4232
4243
|
'weight': 313.21,
|
|
@@ -4703,7 +4714,7 @@ M V30 MDLV30/STEABS ATOMS=(2 2 6)
|
|
|
4703
4714
|
M V30 END COLLECTION
|
|
4704
4715
|
M V30 END CTAB
|
|
4705
4716
|
M END`;
|
|
4706
|
-
function getNucleotidesMol(smilesCodes
|
|
4717
|
+
function getNucleotidesMol(smilesCodes) {
|
|
4707
4718
|
const molBlocks = [];
|
|
4708
4719
|
for (let i = 0; i < smilesCodes.length - 1; i++) {
|
|
4709
4720
|
smilesCodes[i] == 'OP(=O)(O)O' ? molBlocks.push(PHOSHATE) :
|
|
@@ -4711,9 +4722,9 @@ function getNucleotidesMol(smilesCodes, oclRender = false) {
|
|
|
4711
4722
|
smilesCodes[i] == 'O[C@@H]1C[C@@H]O[C@H]1CO' ? molBlocks.push(rotateNucleotidesV3000(INVABASIC)) :
|
|
4712
4723
|
molBlocks.push(rotateNucleotidesV3000(smilesCodes[i]));
|
|
4713
4724
|
}
|
|
4714
|
-
return linkV3000(molBlocks, false
|
|
4725
|
+
return linkV3000(molBlocks, false);
|
|
4715
4726
|
}
|
|
4716
|
-
function linkV3000(molBlocks, twoChains = false,
|
|
4727
|
+
function linkV3000(molBlocks, twoChains = false, useChirality = true) {
|
|
4717
4728
|
let macroMolBlock = '\nDatagrok macromolecule handler\n\n';
|
|
4718
4729
|
macroMolBlock += ' 0 0 0 0 0 0 999 V3000\n';
|
|
4719
4730
|
macroMolBlock += 'M V30 BEGIN CTAB\n';
|
|
@@ -4816,24 +4827,23 @@ function linkV3000(molBlocks, twoChains = false, oclRender = false) {
|
|
|
4816
4827
|
}
|
|
4817
4828
|
const entries = 4;
|
|
4818
4829
|
const collNumber = Math.ceil(collection.length / entries);
|
|
4819
|
-
if (oclRender) {
|
|
4820
|
-
|
|
4821
|
-
|
|
4822
|
-
|
|
4823
|
-
|
|
4824
|
-
}
|
|
4825
|
-
|
|
4826
|
-
|
|
4827
|
-
|
|
4828
|
-
|
|
4829
|
-
|
|
4830
|
-
|
|
4831
|
-
|
|
4832
|
-
|
|
4833
|
-
collection[entries * i + j] + ' ';
|
|
4834
|
-
}
|
|
4830
|
+
//if (oclRender) {
|
|
4831
|
+
// collectionBlock += 'M V30 MDLV30/STEABS ATOMS=(' + collection.length;
|
|
4832
|
+
// for (let j = 0; j < collection.length; j++)
|
|
4833
|
+
// collectionBlock += ' ' + collection[j];
|
|
4834
|
+
// collectionBlock += ')\n';
|
|
4835
|
+
//} else {
|
|
4836
|
+
collectionBlock += 'M V30 MDLV30/STEABS ATOMS=(' + collection.length + ' -\n';
|
|
4837
|
+
for (let i = 0; i < collNumber; i++) {
|
|
4838
|
+
collectionBlock += 'M V30 ';
|
|
4839
|
+
const entriesCurrent = i + 1 == collNumber ? collection.length - (collNumber - 1) * entries : entries;
|
|
4840
|
+
for (let j = 0; j < entriesCurrent; j++) {
|
|
4841
|
+
collectionBlock += (j + 1 == entriesCurrent) ?
|
|
4842
|
+
(i == collNumber - 1 ? collection[entries * i + j] + ')\n' : collection[entries * i + j] + ' -\n') :
|
|
4843
|
+
collection[entries * i + j] + ' ';
|
|
4835
4844
|
}
|
|
4836
4845
|
}
|
|
4846
|
+
//}
|
|
4837
4847
|
//generate file
|
|
4838
4848
|
twoChains ? natom : natom++;
|
|
4839
4849
|
macroMolBlock += 'M V30 COUNTS ' + natom + ' ' + nbond + ' 0 0 0\n';
|
|
@@ -4843,12 +4853,15 @@ function linkV3000(molBlocks, twoChains = false, oclRender = false) {
|
|
|
4843
4853
|
macroMolBlock += 'M V30 BEGIN BOND\n';
|
|
4844
4854
|
macroMolBlock += bondBlock;
|
|
4845
4855
|
macroMolBlock += 'M V30 END BOND\n';
|
|
4846
|
-
|
|
4847
|
-
|
|
4848
|
-
|
|
4856
|
+
if (useChirality) {
|
|
4857
|
+
macroMolBlock += 'M V30 BEGIN COLLECTION\n';
|
|
4858
|
+
macroMolBlock += collectionBlock;
|
|
4859
|
+
macroMolBlock += 'M V30 END COLLECTION\n';
|
|
4860
|
+
}
|
|
4861
|
+
else
|
|
4862
|
+
macroMolBlock = macroMolBlock.replace(/ CFG=\d/g, ' ');
|
|
4849
4863
|
macroMolBlock += 'M V30 END CTAB\n';
|
|
4850
4864
|
macroMolBlock += 'M END\n';
|
|
4851
|
-
macroMolBlock = macroMolBlock.replaceAll('CFG=1', '').replaceAll('CFG=2', '').replaceAll('CFG=3', '').replaceAll('CFG=4', '');
|
|
4852
4865
|
return macroMolBlock;
|
|
4853
4866
|
}
|
|
4854
4867
|
function rotateNucleotidesV3000(molecule) {
|
|
@@ -5028,14 +5041,14 @@ __webpack_require__.r(__webpack_exports__);
|
|
|
5028
5041
|
|
|
5029
5042
|
|
|
5030
5043
|
|
|
5031
|
-
function saveSdf(as, ss, oneEntity,
|
|
5044
|
+
function saveSdf(as, ss, oneEntity, useChirality, invertSS, invertAS) {
|
|
5032
5045
|
const formatAs = (0,_structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_3__.getFormat)(as);
|
|
5033
5046
|
const formatSs = (0,_structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_3__.getFormat)(ss);
|
|
5034
|
-
const molSS = (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToMolV3000)(ss,
|
|
5035
|
-
const molAS = (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToMolV3000)(as,
|
|
5047
|
+
const molSS = (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToMolV3000)(ss, invertSS, false, formatSs);
|
|
5048
|
+
const molAS = (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToMolV3000)(as, invertAS, false, formatAs);
|
|
5036
5049
|
let result;
|
|
5037
5050
|
if (oneEntity)
|
|
5038
|
-
result = (0,_structures_works_mol_transformations__WEBPACK_IMPORTED_MODULE_2__.linkV3000)([molSS, molAS], true,
|
|
5051
|
+
result = (0,_structures_works_mol_transformations__WEBPACK_IMPORTED_MODULE_2__.linkV3000)([molSS, molAS], true, useChirality) + '\n\n$$$$\n';
|
|
5039
5052
|
else {
|
|
5040
5053
|
result =
|
|
5041
5054
|
molSS + '\n' +
|
|
@@ -5050,20 +5063,31 @@ function saveSdf(as, ss, oneEntity, fit3dx) {
|
|
|
5050
5063
|
}
|
|
5051
5064
|
function saveSenseAntiSense() {
|
|
5052
5065
|
const moleculeSvgDiv = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.block([]);
|
|
5053
|
-
const ssInput = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.textInput('Sense Strand
|
|
5054
|
-
const asInput = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.textInput('Anti Sense
|
|
5066
|
+
const ssInput = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.textInput('Sense Strand', '');
|
|
5067
|
+
const asInput = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.textInput('Anti Sense', '');
|
|
5068
|
+
const straight = '5\' ->3\'';
|
|
5069
|
+
const inverse = '3\' ->5\'';
|
|
5070
|
+
let ssInverse = false;
|
|
5071
|
+
let asInverse = false;
|
|
5072
|
+
const changeSense = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.choiceInput('SS direction', straight, [straight, inverse]);
|
|
5073
|
+
changeSense.onChanged(() => { ssInverse = changeSense.value == inverse; });
|
|
5074
|
+
const changeAntiSense = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.choiceInput('AS direction', straight, [straight, inverse]);
|
|
5075
|
+
changeAntiSense.onChanged(() => { asInverse = changeAntiSense.value == inverse; });
|
|
5055
5076
|
const saveOption = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.switchInput('Save as one entity', true);
|
|
5056
|
-
const
|
|
5057
|
-
const saveBtn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.button('Save SDF', () => saveSdf(asInput.value, ssInput.value, saveOption.value,
|
|
5077
|
+
const chirality = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.switchInput('Use chiral', true);
|
|
5078
|
+
const saveBtn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.button('Save SDF', () => saveSdf(asInput.value, ssInput.value, saveOption.value, chirality.value, ssInverse, asInverse));
|
|
5058
5079
|
const saveSection = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.panel([
|
|
5059
5080
|
datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.div([
|
|
5060
5081
|
datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.div([
|
|
5061
5082
|
datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.divH([datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.h1('Inputs')]),
|
|
5062
5083
|
datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.divV([
|
|
5063
|
-
|
|
5064
|
-
|
|
5084
|
+
ssInput,
|
|
5085
|
+
asInput,
|
|
5086
|
+
datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.div([changeSense], { style: { width: '40' } }),
|
|
5087
|
+
changeSense,
|
|
5088
|
+
changeAntiSense,
|
|
5065
5089
|
saveOption,
|
|
5066
|
-
|
|
5090
|
+
chirality,
|
|
5067
5091
|
datagrok_api_ui__WEBPACK_IMPORTED_MODULE_0__.buttonsInput([saveBtn]),
|
|
5068
5092
|
], 'ui-form'),
|
|
5069
5093
|
], 'ui-form'),
|
|
@@ -5153,6 +5177,9 @@ function getFormat(sequence) {
|
|
|
5153
5177
|
});
|
|
5154
5178
|
return possibleSynthesizers[0];
|
|
5155
5179
|
}
|
|
5180
|
+
function sortByStringLengthInDescendingOrder(array) {
|
|
5181
|
+
return array.sort(function (a, b) { return b.length - a.length; });
|
|
5182
|
+
}
|
|
5156
5183
|
function isValidSequence(sequence, format) {
|
|
5157
5184
|
const possibleSynthesizers = format == null ?
|
|
5158
5185
|
getListOfPossibleSynthesizersByFirstMatchedCode(sequence) :
|
|
@@ -5175,7 +5202,7 @@ function isValidSequence(sequence, format) {
|
|
|
5175
5202
|
const firstUniqueCharacters = ['r', 'd'];
|
|
5176
5203
|
const nucleotides = ['A', 'U', 'T', 'C', 'G'];
|
|
5177
5204
|
possibleSynthesizers.forEach((synthesizer) => {
|
|
5178
|
-
const codes = getAllCodesOfSynthesizer(synthesizer);
|
|
5205
|
+
const codes = sortByStringLengthInDescendingOrder(getAllCodesOfSynthesizer(synthesizer));
|
|
5179
5206
|
while (outputIndex < sequence.length) {
|
|
5180
5207
|
const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));
|
|
5181
5208
|
if (matchedCode == null)
|
|
@@ -5252,9 +5279,11 @@ function getAllCodesOfSynthesizer(synthesizer) {
|
|
|
5252
5279
|
return codes.concat(Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS)).concat(_map__WEBPACK_IMPORTED_MODULE_0__.delimiter);
|
|
5253
5280
|
}
|
|
5254
5281
|
function getListOfPossibleSynthesizersByFirstMatchedCode(sequence) {
|
|
5255
|
-
|
|
5282
|
+
let synthesizers = [];
|
|
5256
5283
|
Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map).forEach((synthesizer) => {
|
|
5257
|
-
|
|
5284
|
+
let codes = sortByStringLengthInDescendingOrder(getAllCodesOfSynthesizer(synthesizer));
|
|
5285
|
+
if (synthesizer == 'Janssen GCRS Codes')
|
|
5286
|
+
codes = codes.concat(_map__WEBPACK_IMPORTED_MODULE_0__.gcrsCodesWithoutSmiles);
|
|
5258
5287
|
//TODO: get first non-dropdown code when there are two modifications
|
|
5259
5288
|
let start = 0;
|
|
5260
5289
|
for (let i = 0; i < sequence.length; i++) {
|
|
@@ -5263,6 +5292,8 @@ function getListOfPossibleSynthesizersByFirstMatchedCode(sequence) {
|
|
|
5263
5292
|
break;
|
|
5264
5293
|
}
|
|
5265
5294
|
}
|
|
5295
|
+
if (_map__WEBPACK_IMPORTED_MODULE_0__.gcrsCodesWithoutSmiles.some((s) => s == sequence.slice(start, start + s.length)))
|
|
5296
|
+
synthesizers = ['Janssen GCRS Codes'];
|
|
5266
5297
|
if (codes.some((s) => s == sequence.slice(start, start + s.length)))
|
|
5267
5298
|
synthesizers.push(synthesizer);
|
|
5268
5299
|
});
|
|
@@ -5548,4 +5579,4 @@ function sequenceTranslator() {
|
|
|
5548
5579
|
sequencetranslator = __webpack_exports__;
|
|
5549
5580
|
/******/ })()
|
|
5550
5581
|
;
|
|
5551
|
-
//# 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,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;AAC8F;AAC5D;AACH;AACE;AAClC;AACA;AACN;AACM;AACN;AAC/B;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;AACA;AACA;AACA,YAAY,4DAAkB;AAC9B,iBAAiB,0EAAuB,EAAE,8EAA2B,EAAE,mEAAgB;AACvF,oBAAoB,sEAAmB,EAAE,qEAAkB;AAC3D;AACA,6CAA6C,qEAAkB;AAC/D,wCAAwC,iEAAc;AACtD;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;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,6CAAS;AAClD,oBAAoB,8DAAoB,CAAC,6CAAS;AAClD,sBAAsB,8DAAoB,CAAC,8CAAO;AAClD,mBAAmB,8DAAoB,CAAC,uCAAI;AAC5C,mBAAmB,8DAAoB,CAAC,wCAAI;AAC5C;AACA,+BAA+B,0EAAuB;AACtD,mBAAmB,0DAAgB;AACnC,kCAAkC,qEAAkB;AACpD,8BAA8B,iEAAc;AAC5C,qCAAqC,wEAAqB;AAC1D,+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,6BAA6B,gEAAa,UAAU,+DAAqB;AACzE,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,kCAAkC,iEAAc,SAAS,yDAAe;AACxE,kCAAkC,kEAAe,SAAS,yDAAe;AACzE,kCAAkC,iEAAc,SAAS,yDAAe;AACxE,kCAAkC,mEAAgB,SAAS,yDAAe;AAC1E,kCAAkC,gEAAa,SAAS,yDAAe;AACvE,kCAAkC,gEAAa,SAAS,yDAAe;AACvE,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;;;;;;;;;;;;;;;;ACrLA;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;AAC0C;AACJ;AACA;AACtC;AACuC;AACd;AACuB;AACP;AACzC,gCAAgC,kDAAU;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,kDAAU;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,sEAAoC;AAClE,qBAAqB,kDAAU;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA,sBAAsB,iDAAO;AAC7B,YAAY,6DAAkB;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,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,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,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,2BAA2B,mDAAS,mBAAmB,yDAAgB,mDAAmD,0BAA0B;AACpJ,wBAAwB,kDAAQ;AAChC,QAAQ,kDAAQ;AAChB;AACA,aAAa,SAAS,uBAAuB;AAC7C;AACA;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;;;;;;;;;;;;;;;;;ACnuByC;AACzC;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,kDAAU;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,kDAAU;AAC3L;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,oBAAoB;AACxC;AACA;AACA;AACA;AACA;AACA,yCAAyC,QAAQ;AACjD;AACA;AACA;AACA,gJAAgJ,kDAAU;AAC1J;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,wBAAwB;AAC5C;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;ACvL0C;AACJ;AACA;AAC8E;AACvD;AAC4B;AAChE;AACzB;AACA;AACA;AACO;AACP;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,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,+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,IAAI,+CAAC;AACL,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,cAAc,sDAAY;AAC1B,uBAAuB,4DAAkB;AACzC;AACA;AACA,WAAW,gDAAM,CAAC,mDAAS;AAC3B,QAAQ,mDAAS;AACjB,YAAY,kDAAQ;AACpB;AACA,gBAAgB,gDAAM;AACtB,oBAAoB,+CAAK;AACzB,oBAAoB,gDAAM;AAC1B;AACA;AACA;AACA,gBAAgB,gDAAM,6BAA6B,SAAS,oBAAoB;AAChF,gBAAgB,kDAAQ;AACxB,oBAAoB,+CAAK;AACzB;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,SAAS,iCAAiC;AACnD;;;;;;;;;;;;;;;;AC5LO;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,wDAAwD,mBAAmB;AAC3E;AACA;AACA;AACA;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA;AACA;AACA;AACA;AACA,2BAA2B;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,gGAAgG,gBAAgB;AAChH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,2HAA2H,gBAAgB;AAC3I;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,iGAAiG,gBAAgB;AACjH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,8BAA8B;AAC9B;AACA,+BAA+B;AAC/B;AACA,gCAAgC;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,8BAA8B;AAC9B;AACA,gCAAgC;AAChC;AACA,+BAA+B;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,gCAAgC;AAChC;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,kCAAkC;AAClC;AACA,gCAAgC;AAChC;AACA,gCAAgC;AAChC;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA;AACA,mJAAmJ,gBAAgB;AACnK;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA;AACA,mJAAmJ,gBAAgB;AACnK;;;;;;;;;;;;;;;;;;;;AC7R8G;AACrD;AACC;AACnD;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,+CAAa;AAC/C,2CAA2C,2CAAS;AACpD;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA,gBAAgB,+CAAa,uBAAuB,+CAAa;AACjE,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,2CAA2C,2CAAS;AACpD;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA,gBAAgB,+CAAa,uBAAuB,4DAA0B;AAC9E,gBAAgB,+CAAa,sBAAsB,4DAA0B;AAC7E;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,4DAA0B;AACxE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,mEAAiC;AACzE;AACA;AACA;AACA;AACA,8CAA8C,qCAAG;AACjD,iDAAiD,qCAAG;AACpD,+CAA+C,qCAAG;AAClD,gCAAgC,qCAAG;AACnC;AACA;AACA;AACA;AACA,6CAA6C,qCAAG;AAChD,2CAA2C,qCAAG;AAC9C,4BAA4B,qCAAG;AAC/B;AACA;AACA,QAAQ,2CAAS;AACjB;AACA,mBAAmB,sEAAe;AAClC,oCAAoC,yDAAuB;AAC3D,mBAAmB,qCAAG,CAAC,yDAAuB,EAAE,qDAAmB;AACnE,yCAAyC,sDAAoB;AAC7D,mBAAmB,qCAAG,CAAC,sDAAoB,EAAE,qDAAmB;AAChE;AACA;AACA;AACA,wCAAwC,6BAA6B;AACrE;;;;;;;;;;;;;;;;;;;;;;;;;;;ACvGsC;AAC4B;AAC3D,oBAAoB;AACpB;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;;;;;;;;;;;;;;;;ACjtB5C;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;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;;;;;;;;;;;;;;;;;;;;;;ACxXsC;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/CkF;AAC0e;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,yCAAyC,qCAAG;AAC5C,yCAAyC,qCAAG;AAC5C,oCAAoC,+CAAa,UAAU,2CAAS;AACpE;AACA;AACA;AACA,gBAAgB,qCAAG;AACnB;AACA;AACA;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;;;;;;;;;;;;;;;;ACrRO;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;;;;;;;;;;;;;;;;;;;;;;;;;;ACN0C;AACJ;AACA;AACsC;AACZ;AACa;AACjC;AACrC,qBAAqB,oDAAU;AACtC;AACA;AACO;AACP,oBAAoB,4DAAkB;AACtC;AACA;AACA;AACA,cAAc,4DAAkB;AAChC,QAAQ,uDAAa;AACrB,oBAAoB,yDAAQ;AAC5B,uBAAuB,6EAAoB;AAC3C,mBAAmB,0FAAkB;AACrC,SAAS;AACT;AACA;AACA;AACA;AACA,yFAAgC","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/autostart/registration.ts","webpack://sequencetranslator/./src/axolabs/constants.ts","webpack://sequencetranslator/./src/axolabs/define-pattern.ts","webpack://sequencetranslator/./src/axolabs/draw-svg.ts","webpack://sequencetranslator/./src/main/main-view.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","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;\nimport * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\nimport { siRnaAxolabsToGcrs, gcrsToNucleotides, asoGapmersBioSpringToGcrs, gcrsToMermade12, } from '../structures-works/converters';\nimport { map, COL_NAMES, MODIFICATIONS } from '../structures-works/map';\nimport { getFormat } from '../structures-works/sequence-codes-tools';\nimport { sequenceToMolV3000 } from '../structures-works/from-monomers';\nimport { SALTS_CSV } from '../salts';\nimport { USERS_CSV } from '../users';\nimport { ICDS } from '../ICDs';\nimport { SOURCES } from '../sources';\nimport { IDPS } from '../IDPs';\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 stringify(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}\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.getCol(COL_NAMES.SEQUENCE);\n        const typeColumn = table.getCol(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}\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.getCol(COL_NAMES.SEQUENCE);\n        const salt = t.getCol(COL_NAMES.SALT);\n        const equivalents = t.getCol(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.getCol('MOLWEIGHT');\n        const saltNamesList = saltsDf.getCol('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.getCol(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.dataFrame.getCol(COL_NAMES.TYPE).setTag(DG.TAGS.CHOICES, '[\"AS\", \"SS\", \"Duplex\"]');\n            view.dataFrame.getCol(COL_NAMES.OWNER).setTag(DG.TAGS.CHOICES, stringify(usersDf.columns.byIndex(0).toList()));\n            view.dataFrame.getCol(COL_NAMES.SALT).setTag(DG.TAGS.CHOICES, stringify(saltsDf.columns.byIndex(0).toList()));\n            view.dataFrame.getCol(COL_NAMES.SOURCE).setTag(DG.TAGS.CHOICES, stringify(sourcesDf.columns.byIndex(0).toList()));\n            view.dataFrame.getCol(COL_NAMES.ICD).setTag(DG.TAGS.CHOICES, stringify(icdsDf.columns.byIndex(0).toList()));\n            view.dataFrame.getCol(COL_NAMES.IDP).setTag(DG.TAGS.CHOICES, stringify(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","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};\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 './draw-svg';\nimport { axolabsMap } from './constants';\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 i = -1;\n    let mainSequence = sequence.replace(/[AUGC]/g, function (x) {\n        i++;\n        const indexOfSymbol = axolabsMap['RNA']['symbols'].indexOf(x);\n        let symbol = axolabsMap[bases[i].value]['symbols'][indexOfSymbol];\n        if (bases[i].value.slice(-3) == '(o)') {\n            if (i < sequence.length / 2 && bases[i + 1].value.slice(-3) != '(o)')\n                symbol = symbol + x + 'f';\n            else if (i > sequence.length / 2 && bases[i - 1].value.slice(-3) != '(o)')\n                symbol = x + 'f' + symbol;\n        }\n        return (ptoLinkages[i].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        if (inputSsColumn.value == '')\n            ssInputExample.value = generateExample(ssLength.value, sequenceBase.value);\n        if (createAsStrand.value && inputAsColumn.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.getCol(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.getCol(colName).get(0);\n        if (allLengthsAreTheSame && firstSequence.length != ssLength.value)\n            ssLength.value = tables.value.getCol(colName).get(0).length;\n        ssInputExample.value = firstSequence;\n    }\n    function validateAsColumn(colName) {\n        const allLengthsAreTheSame = checkWhetherAllValuesInColumnHaveTheSameLength(colName);\n        const firstSequence = tables.value.getCol(colName).get(0);\n        if (allLengthsAreTheSame && firstSequence.length != asLength.value)\n            asLength.value = tables.value.getCol(colName).get(0).length;\n        asInputExample.value = firstSequence;\n    }\n    function validateIdsColumn(colName) {\n        const col = tables.value.getCol(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.getCol(inputSsColumn.value).getString(0).length;\n                asLength.value = tables.value.getCol(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    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    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 downloadButton = ui.button('Download', () => svg.saveSvgAsPng(document.getElementById('mySvg'), saveAs.value, { backgroundColor: 'white' }));\n    const mainSection = ui.panel([\n        ui.block([\n            svgDiv,\n        ], { style: { overflowX: 'scroll' } }),\n        downloadButton,\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 './constants';\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","import * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\nimport { convertSequence, undefinedInputSequence, isValidSequence } from '../structures-works/sequence-codes-tools';\nimport { map, MODIFICATIONS } from '../structures-works/map';\nimport { sequenceToSmiles, sequenceToMolV3000 } from '../structures-works/from-monomers';\nimport $ from 'cash-dom';\nconst defaultInput = 'fAmCmGmAmCpsmU';\nconst sequenceWasCopied = 'Copied';\nconst tooltipSequence = 'Copy sequence';\nexport function mainView() {\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 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 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    $(codesTablesDiv).hide();\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    const v = grok.shell.v;\n    const tabControl = grok.shell.sidebar;\n    tabControl.onTabChanged.subscribe((_) => v.setRibbonPanels([(tabControl.currentPane.name == 'MAIN') ? topPanel : []]));\n    v.setRibbonPanels([topPanel]);\n    return 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}\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    let r1 = sequence.replace(regExp, function (code) { return obj[code]; });\n    r1 = r1.replace('//', '/');\n    r1 = r1.replace('//', '/');\n    return r1.replace('//', '/');\n}\n//name: asoGapmersNucleotidesToBioSpring\n//input: string nucleotides {semType: DNA nucleotides}\n//output: string result {semType: BioSpring / Gapmers}\nexport function asoGapmersNucleotidesToBioSpring(nucleotides) {\n    let count = -1;\n    const objForEdges = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': '5*', 'A': '6*', 'C': '7*', 'G': '8*'\n    };\n    const objForCenter = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'T*', 'A': 'A*', 'C': '9*', 'G': 'G*'\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|T|C|G)/g, function (x) {\n        count++;\n        return (count > 4 && count < 15) ? objForCenter[x] : objForEdges[x];\n    }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?\n        nucleotides.length : 2 * count + 1);\n}\n//name: asoGapmersNucleotidesToGcrs\n//input: string nucleotides {semType: DNA nucleotides}\n//output: string result {semType: GCRS / Gapmers}\nexport function asoGapmersNucleotidesToGcrs(nucleotides) {\n    let count = -1;\n    const objForEdges = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'moeUnps',\n        'A': 'moeAnps', 'C': 'moe5mCnps', 'G': 'moeGnps'\n    };\n    const objForCenter = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'C': '5mCps', 'A': 'Aps', 'T': 'Tps', 'G': 'Gps' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|T|C|G)/g, function (x) {\n        count++;\n        if (count < 5)\n            return (count == 4) ? objForEdges[x].slice(0, -3) + 'ps' : objForEdges[x];\n        if (count < 15)\n            return (count == 14) ? objForCenter[x].slice(0, -2) + 'nps' : objForCenter[x];\n        return objForEdges[x];\n    }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?\n        nucleotides.length : -3);\n}\n//name: asoGapmersBioSpringToNucleotides\n//input: string nucleotides {semType: BioSpring / Gapmers}\n//output: string result {semType: DNA nucleotides}\nexport function asoGapmersBioSpringToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '*': '', '5': 'T', '6': 'A', '7': 'C', '8': 'G', '9': 'C' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|\\*|5|6|7|8|9)/g, function (x) { return obj[x]; });\n}\n//name: asoGapmersBioSpringToGcrs\n//input: string nucleotides {semType: BioSpring / Gapmers}\n//output: string result {semType: GCRS / Gapmers}\nexport function asoGapmersBioSpringToGcrs(nucleotides) {\n    let count = -1;\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '5*': 'moeUnps', '6*': 'moeAnps', '7*': 'moe5mCnps', '8*': 'moeGnps', '9*': '5mCps', 'A*': 'Aps', 'T*': 'Tps',\n        'G*': 'Gps', 'C*': 'Cps', '5': 'moeU', '6': 'moeA', '7': 'moe5mC', '8': 'moeG',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|5\\*|6\\*|7\\*|8\\*|9\\*|A\\*|T\\*|G\\*|C\\*|5|6|7|8)/g, function (x) {\n        count++;\n        return (count == 4) ? obj[x].slice(0, -3) + 'ps' : (count == 14) ? obj[x].slice(0, -2) + 'nps' : obj[x];\n    });\n}\n//name: asoGapmersGcrsToBioSpring\n//input: string nucleotides {semType: GCRS / Gapmers}\n//output: string result {semType: BioSpring / Gapmers}\nexport function asoGapmersGcrsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'moeT': '5', 'moeA': '6', 'moe5mC': '7', 'moeG': '8', 'moeU': '5', '5mC': '9', 'nps': '*', 'ps': '*', 'U': 'T',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|moeT|moeA|moe5mC|moeG|moeU|5mC|nps|ps|U)/g, function (x) { return obj[x]; });\n}\n//name: asoGapmersGcrsToNucleotides\n//input: string nucleotides {semType: GCRS / Gapmers}\n//output: string result {semType: DNA nucleotides}\nexport function asoGapmersGcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'moe': '', '5m': '', 'n': '', 'ps': '', 'U': 'T' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|moe|5m|n|ps|U)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToNucleotides\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaBioSpringToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'U', '2': 'A', '3': 'C', '4': 'G', '5': 'U', '6': 'A', '7': 'C', '8': 'G', '*': '' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToAxolabs\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: Axolabs / siRNA}\nexport function siRnaBioSpringToAxolabs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'Uf', '2': 'Af', '3': 'Cf', '4': 'Gf', '5': 'u', '6': 'a', '7': 'c', '8': 'g', '*': 's' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToGcrs\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: GCRS}\nexport function siRnaBioSpringToGcrs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'fU', '2': 'fA', '3': 'fC', '4': 'fG', '5': 'mU', '6': 'mA', '7': 'mC', '8': 'mG', '*': 'ps' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToGcrs\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: GCRS}\nexport function siRnaAxolabsToGcrs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': 'fU', 'Af': 'fA', 'Cf': 'fC', 'Gf': 'fG', 'u': 'mU', 'a': 'mA', 'c': 'mC', 'g': 'mG', 's': 'ps',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToBioSpring\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaAxolabsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': '1', 'Af': '2', 'Cf': '3', 'Gf': '4', 'u': '5', 'a': '6', 'c': '7', 'g': '8', 's': '*',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToNucleotides\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaAxolabsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': 'U', 'Af': 'A', 'Cf': 'C', 'Gf': 'G', 'u': 'U', 'a': 'A', 'c': 'C', 'g': 'G', 's': '',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToNucleotides\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaGcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G', 'ps': '',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToBioSpring\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaGcrsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': '1', 'fA': '2', 'fC': '3', 'fG': '4', 'mU': '5', 'mA': '6', 'mC': '7', 'mG': '8', 'ps': '*',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToAxolabs\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: Axolabs / siRNA}\nexport function siRnaGcrsToAxolabs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': 'Uf', 'fA': 'Af', 'fC': 'Cf', 'fG': 'Gf', 'mU': 'u', 'mA': 'a', 'mC': 'c', 'mG': 'g', 'ps': 's',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaNucleotideToBioSpringSenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaNucleotideToBioSpringSenseStrand(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '6*', 'U': '5*', 'G': '8*', 'C': '7*' };\n    const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '*6', 'U': '*5', 'G': '*8', 'C': '*7' };\n    const objForOddIndices = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '6', 'U': '5', 'G': '8', 'C': '7' };\n    const objForEvenIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': '2', 'U': '1', 'G': '4', 'C': '3' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count > nucleotides.length - 3)\n            return objForRightEdge[x];\n        return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];\n    });\n}\n//name: siRnaNucleotidesToGcrs\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: GCRS}\nexport function siRnaNucleotidesToGcrs(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'mAps', 'U': 'mUps', 'G': 'mGps', 'C': 'mCps' };\n    const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'psmA', 'U': 'psmU', 'G': 'psmG', 'C': 'psmC' };\n    const objForEvenIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'fA', 'U': 'fU', 'G': 'fG', 'C': 'fC' };\n    const objForOddIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'mA', 'U': 'mU', 'G': 'mG', 'C': 'mC' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count > nucleotides.length - 3)\n            return objForRightEdge[x];\n        return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];\n    });\n}\n//name: siRnaNucleotideToAxolabsSenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: Axolabs}\nexport function siRnaNucleotideToAxolabsSenseStrand(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };\n    const objForSomeIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count == 6 || (count > 7 && count < 11))\n            return objForSomeIndices[x];\n        if (count == nucleotides.length - 1)\n            return 'a';\n        return obj[x];\n    });\n}\n//name: siRnaNucleotideToAxolabsAntisenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: Axolabs}\nexport function siRnaNucleotideToAxolabsAntisenseStrand(nucleotides) {\n    let count = -1;\n    const objForSmallLinkages = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };\n    const objForBigLinkages = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Afs', 'U': 'Ufs', 'G': 'Gfs', 'C': 'Cfs' };\n    const objForSomeIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };\n    const obj = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count > 19 && count < 22)\n            return objForSmallLinkages[x];\n        if (count == 0)\n            return 'us';\n        if (count == 1)\n            return objForBigLinkages[x];\n        return (count == 5 || count == 7 || count == 8 || count == 13 || count == 15) ? objForSomeIndices[x] : obj[x];\n    });\n}\n//name: gcrsToNucleotides\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: RNA nucleotides}\nexport function gcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'mAps': 'A', 'mUps': 'U', 'mGps': 'G', 'mCps': 'C', 'fAps': 'A', 'fUps': 'U', 'fGps': 'G', 'fCps': 'C',\n        'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });\n}\n//name: gcrsToMermade12\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: Mermade 12 / siRNA}\nexport function gcrsToMermade12(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'mAps': 'e', 'mUps': 'h', 'mGps': 'g', 'mCps': 'f', 'fAps': 'i', 'fUps': 'l', 'fGps': 'k', 'fCps': 'j', 'fU': 'L',\n        'fA': 'I', 'fC': 'J', 'fG': 'K', 'mU': 'H', 'mA': 'E', 'mC': 'F', 'mG': 'G',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });\n}\n","import { map, stadardPhosphateLinkSmiles, SYNTHESIZERS, TECHNOLOGIES, MODIFICATIONS, delimiter } from './map';\nimport { isValidSequence } from './sequence-codes-tools';\nimport { getNucleotidesMol } from './mol-transformations';\nexport function sequenceToMolV3000(sequence, inverted = false, oclRender = false, format) {\n    const obj = getObjectWithCodesAndSmiles(sequence, format);\n    let codes = sortByStringLengthInDescendingOrder(Object.keys(obj));\n    let i = 0;\n    const smilesCodes = [];\n    const codesList = [];\n    const links = ['s', 'ps', '*'];\n    const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];\n    const dropdowns = Object.keys(MODIFICATIONS);\n    codes = codes.concat(dropdowns).concat(delimiter);\n    while (i < sequence.length) {\n        const code = codes.find((s) => s == sequence.slice(i, i + s.length));\n        i += code.length;\n        inverted ? codesList.unshift(code) : codesList.push(code);\n    }\n    for (let i = 0; i < codesList.length; i++) {\n        if (dropdowns.includes(codesList[i])) {\n            smilesCodes.push((i >= codesList.length / 2) ?\n                MODIFICATIONS[codesList[i]].right : MODIFICATIONS[codesList[i]].left);\n            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).concat(delimiter);\n    while (i < sequence.length) {\n        const code = codes.find((s) => s == sequence.slice(i, i + s.length));\n        i += code.length;\n        inverted ? codesList.unshift(code) : codesList.push(code);\n    }\n    for (let i = 0; i < codesList.length; i++) {\n        if (dropdowns.includes(codesList[i])) {\n            smiles += (i >= codesList.length / 2) ?\n                MODIFICATIONS[codesList[i]].right + stadardPhosphateLinkSmiles :\n                MODIFICATIONS[codesList[i]].left + stadardPhosphateLinkSmiles;\n        }\n        else {\n            if (links.includes(codesList[i]) ||\n                includesStandardLinkAlready.includes(codesList[i]) ||\n                (i < codesList.length - 1 && links.includes(codesList[i + 1])))\n                smiles += obj[codesList[i]];\n            else\n                smiles += obj[codesList[i]] + stadardPhosphateLinkSmiles;\n        }\n    }\n    smiles = smiles.replace(/OO/g, 'O');\n    return ((links.includes(codesList[codesList.length - 1]) &&\n        codesList.length > 1 &&\n        !includesStandardLinkAlready.includes(codesList[codesList.length - 2])) ||\n        dropdowns.includes(codesList[codesList.length - 1]) ||\n        includesStandardLinkAlready.includes(codesList[codesList.length - 1])) ?\n        smiles :\n        smiles.slice(0, smiles.length - stadardPhosphateLinkSmiles.length + 1);\n}\nfunction getObjectWithCodesAndSmiles(sequence, format) {\n    const obj = {};\n    if (format == null) {\n        for (const synthesizer of Object.keys(map)) {\n            for (const technology of Object.keys(map[synthesizer])) {\n                for (const code of Object.keys(map[synthesizer][technology]))\n                    obj[code] = map[synthesizer][technology][code].SMILES;\n            }\n        }\n    }\n    else {\n        for (const technology of Object.keys(map[format])) {\n            for (const code of Object.keys(map[format][technology]))\n                obj[code] = map[format][technology][code].SMILES;\n        }\n    }\n    obj[delimiter] = '';\n    // TODO: create object based from synthesizer type to avoid key(codes) duplicates\n    const output = isValidSequence(sequence, format);\n    if (output.synthesizer.includes(SYNTHESIZERS.MERMADE_12))\n        obj['g'] = map[SYNTHESIZERS.MERMADE_12][TECHNOLOGIES.SI_RNA]['g'].SMILES;\n    else if (output.synthesizer.includes(SYNTHESIZERS.AXOLABS))\n        obj['g'] = map[SYNTHESIZERS.AXOLABS][TECHNOLOGIES.SI_RNA]['g'].SMILES;\n    return obj;\n}\nfunction sortByStringLengthInDescendingOrder(array) {\n    return array.sort(function (a, b) { return b.length - a.length; });\n}\n","import * as DG from 'datagrok-api/dg';\nimport { getAllCodesOfSynthesizer } from './sequence-codes-tools';\nexport const delimiter = ';';\nexport const SYNTHESIZERS = {\n    RAW_NUCLEOTIDES: 'Raw Nucleotides',\n    BIOSPRING: 'BioSpring Codes',\n    GCRS: 'Janssen GCRS Codes',\n    AXOLABS: 'Axolabs Codes',\n    MERMADE_12: 'Mermade 12',\n    LCMS: 'LCMS',\n};\nexport const TECHNOLOGIES = {\n    DNA: 'DNA',\n    RNA: 'RNA',\n    ASO_GAPMERS: 'For ASO Gapmers',\n    SI_RNA: 'For 2\\'-OMe and 2\\'-F modified siRNA',\n};\nexport const COL_NAMES = {\n    CHEMISTRY: 'Chemistry',\n    NUMBER: 'Number',\n    TYPE: 'Type',\n    CHEMISTRY_NAME: 'Chemistry Name',\n    INTERNAL_COMPOUND_ID: 'Internal compound ID',\n    IDP: 'IDP',\n    SEQUENCE: 'Sequence',\n    COMPOUND_NAME: 'Compound Name',\n    COMPOUND_COMMENTS: 'Compound Comments',\n    SALT: 'Salt',\n    EQUIVALENTS: 'Equivalents',\n    PURITY: 'Purity',\n    CPD_MW: 'Cpd MW',\n    SALT_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    macroMolBlock = macroMolBlock.replaceAll('CFG=1', '').replaceAll('CFG=2', '').replaceAll('CFG=3', '').replaceAll('CFG=4', '');\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, delimiter } 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: [possibleSynthesizers[3]], technology: null };\n    outputIndex = 0;\n    // possibleTechnologies.forEach((technology: string) => {\n    //   const codes = Object.keys(map[possibleSynthesizers[0]][technology]);\n    //   while (outputIndex < sequence.length) {\n    //     const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));\n    //     if (matchedCode == null)\n    //       break;\n    //     if ( // for mistake pattern 'rAA'\n    //       outputIndex > 1 &&\n    //       nucleotides.includes(sequence[outputIndex]) &&\n    //       firstUniqueCharacters.includes(sequence[outputIndex - 2])\n    //     ) break;\n    //     if ( // for mistake pattern 'ArA'\n    //       firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&\n    //       nucleotides.includes(sequence[outputIndex])\n    //     ) {\n    //       outputIndex++;\n    //       break;\n    //     }\n    //     outputIndex += matchedCode.length;\n    //   }\n    // });\n    return {\n        indexOfFirstNotValidChar: indexOfFirstNotValidChar,\n        synthesizer: possibleSynthesizers,\n        technology: [possibleTechnologies[outputIndex]],\n    };\n}\nexport function getAllCodesOfSynthesizer(synthesizer) {\n    let codes = [];\n    for (const technology of Object.keys(map[synthesizer]))\n        codes = codes.concat(Object.keys(map[synthesizer][technology]));\n    return codes.concat(Object.keys(MODIFICATIONS)).concat(delimiter);\n}\nfunction getListOfPossibleSynthesizersByFirstMatchedCode(sequence) {\n    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};","import * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\nimport { autostartOligoSdFileSubscription } from './autostart/registration';\nimport { defineAxolabsPattern } from './axolabs/define-pattern';\nimport { saveSenseAntiSense } from './structures-works/save-sense-antisense';\nimport { mainView } from './main/main-view';\nexport const _package = new DG.Package();\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    const v = grok.shell.newView('Sequence Translator', [\n        ui.tabControl({\n            'MAIN': mainView(),\n            'AXOLABS': defineAxolabsPattern(),\n            'SDF': saveSenseAntiSense(),\n        }),\n    ]);\n    v.box = true;\n}\n//tags: autostart\nautostartOligoSdFileSubscription();\n"],"names":[],"sourceRoot":""}
|
|
5582
|
+
//# 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,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AAC0C;AACJ;AACA;AAC8F;AAC5D;AACG;AACJ;AAClC;AACA;AACN;AACM;AACN;AAC/B;AACA,wCAAwC,6BAA6B;AACrE;AACA;AACA;AACA;AACA;AACA,kGAAkG,gEAAa;AAC/G;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,4DAAkB;AAC9B,iBAAiB,0EAAuB,EAAE,8EAA2B,EAAE,mEAAgB;AACvF,oBAAoB,sEAAmB,EAAE,qEAAkB;AAC3D;AACA,6CAA6C,qEAAkB;AAC/D,wCAAwC,iEAAc;AACtD;AACA,wBAAwB,oBAAoB;AAC5C,iDAAiD;AACjD;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;AACO;AACP,IAAI,2EAAiC;AACrC;AACA,6CAA6C,iEAAc;AAC3D;AACA,YAAY,6EAAmC;AAC/C,mEAAmE,kBAAkB,GAAG;AACxF,oBAAoB,sEAA4B,sEAAsE,GAAG;AACzH;AACA;AACA,mCAAmC,gFAAkB;AACrD,yBAAyB;AACzB,qBAAqB,GAAG,gBAAgB,GAAG;AAC3C;AACA,yBAAyB,sEAA4B,iEAAiE,GAAG;AACzH,oBAAoB,sEAA4B,6CAA6C,GAAG;AAChG;AACA;AACA,mCAAmC,+EAAiB;AACpD,yBAAyB;AACzB,qBAAqB;AACrB;AACA;AACA,mCAAmC,6EAAe;AAClD,yBAAyB;AACzB,qBAAqB,GAAG,kBAAkB,GAAG;AAC7C;AACA,yBAAyB,sEAA4B,uEAAuE,GAAG;AAC/H;AACA;AACA;AACA,mCAAmC,uFAAyB;AAC5D,yBAAyB;AACzB,qBAAqB,GAAG,YAAY,GAAG;AACvC;AACA,yBAAyB,sEAA4B,qEAAqE,GAAG;AAC7H;AACA;AACA,mCAAmC,gFAAkB;AACrD,yBAAyB;AACzB,qBAAqB;AACrB;AACA,aAAa;AACb;AACA,KAAK;AACL;AACO;AACP,oBAAoB,8DAAoB,CAAC,6CAAS;AAClD,oBAAoB,8DAAoB,CAAC,6CAAS;AAClD,sBAAsB,8DAAoB,CAAC,8CAAO;AAClD,mBAAmB,8DAAoB,CAAC,uCAAI;AAC5C,mBAAmB,8DAAoB,CAAC,wCAAI;AAC5C;AACA;AACA,mCAAmC,0EAAuB;AAC1D,uBAAuB,0DAAgB;AACvC,yCAAyC,qEAAkB;AAC3D,qCAAqC,iEAAc;AACnD,4CAA4C,wEAAqB;AACjE,mCAAmC,0EAAuB;AAC1D,mCAAmC,8EAA2B;AAC9D,wCAAwC;AACxC;AACA;AACA;AACA;AACA,kDAAkD,sDAAG;AACrD,qDAAqD,sDAAG;AACxD,mDAAmD,sDAAG;AACtD,2CAA2C,sDAAG;AAC9C;AACA;AACA,sDAAsD,gEAAa;AACnE;AACA,kCAAkC,mEAAgB;AAClD,wBAAwB,uFAAe;AACvC;AACA,oBAAoB,uDAAa;AACjC,aAAa;AACb,kCAAkC,sEAAmB;AACrD;AACA;AACA,oBAAoB,uDAAa;AACjC;AACA,aAAa;AACb,6CAA6C,qEAAkB,KAAK,IAAI,mEAAgB,MAAM,IAAI,IAAI,sEAAmB,KAAK,GAAG,8DAAoB;AACrJ;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,cAAc,gDAAM;AACpB,QAAQ,uDAAa;AACrB;AACA,6BAA6B,gEAAa,UAAU,+DAAqB;AACzE,uCAAuC,gEAAa,EAAE,+DAAqB;AAC3E,qBAAqB,iDAAO;AAC5B;AACA,yDAAyD,4DAAS;AAClE,aAAa,wBAAwB,0EAAuB,EAAE,8EAA2B,EAAE,mEAAgB;AAC3G,gBAAgB,sEAAmB,EAAE,qEAAkB,uBAAuB,mDAAS;AACvF,yBAAyB,iEAAuB;AAChD,kCAAkC,iEAAc,SAAS,yDAAe;AACxE,kCAAkC,kEAAe,SAAS,yDAAe;AACzE,kCAAkC,iEAAc,SAAS,yDAAe;AACxE,kCAAkC,mEAAgB,SAAS,yDAAe;AAC1E,kCAAkC,gEAAa,SAAS,yDAAe;AACvE,kCAAkC,gEAAa,SAAS,yDAAe;AACvE,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;;;;;;;;;;;;;;;;AC1LA;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;AAC0C;AACJ;AACA;AACtC;AACuC;AACd;AACuB;AACP;AACzC,gCAAgC,kDAAU;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,kDAAU;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,sEAAoC;AAClE,qBAAqB,kDAAU;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA,sBAAsB,iDAAO;AAC7B,YAAY,6DAAkB;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,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,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,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,2BAA2B,mDAAS,mBAAmB,yDAAgB,mDAAmD,0BAA0B;AACpJ,wBAAwB,kDAAQ;AAChC,QAAQ,kDAAQ;AAChB;AACA,aAAa,SAAS,uBAAuB;AAC7C;AACA;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;;;;;;;;;;;;;;;;;ACnuByC;AACzC;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,kDAAU;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,kDAAU;AAC3L;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,oBAAoB;AACxC;AACA;AACA;AACA;AACA;AACA,yCAAyC,QAAQ;AACjD;AACA;AACA;AACA,gJAAgJ,kDAAU;AAC1J;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,wBAAwB;AAC5C;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;ACvL0C;AACJ;AACA;AAC8E;AACvD;AAC4B;AAChE;AACzB;AACA;AACA;AACO;AACP;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,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,+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,IAAI,+CAAC;AACL,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,cAAc,sDAAY;AAC1B,uBAAuB,4DAAkB;AACzC;AACA;AACA,WAAW,gDAAM,CAAC,mDAAS;AAC3B,QAAQ,mDAAS;AACjB,YAAY,kDAAQ;AACpB;AACA,gBAAgB,gDAAM;AACtB,oBAAoB,+CAAK;AACzB,oBAAoB,gDAAM;AAC1B;AACA;AACA;AACA,gBAAgB,gDAAM,6BAA6B,SAAS,oBAAoB;AAChF,gBAAgB,kDAAQ;AACxB,oBAAoB,+CAAK;AACzB;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,SAAS,iCAAiC;AACnD;;;;;;;;;;;;;;;;AC5LO;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,wDAAwD,mBAAmB;AAC3E;AACA;AACA;AACA;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA;AACA;AACA;AACA;AACA,2BAA2B;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,gGAAgG,gBAAgB;AAChH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,2HAA2H,gBAAgB;AAC3I;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,iGAAiG,gBAAgB;AACjH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,8BAA8B;AAC9B;AACA,+BAA+B;AAC/B;AACA,gCAAgC;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,8BAA8B;AAC9B;AACA,gCAAgC;AAChC;AACA,+BAA+B;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,gCAAgC;AAChC;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,kCAAkC;AAClC;AACA,gCAAgC;AAChC;AACA,gCAAgC;AAChC;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA;AACA,mJAAmJ,gBAAgB;AACnK;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA;AACA,mJAAmJ,gBAAgB;AACnK;;;;;;;;;;;;;;;;;;;;AC7R8G;AACrD;AACC;AACnD;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,+CAAa;AAC/C,2CAA2C,2CAAS;AACpD;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA,gBAAgB,+CAAa,uBAAuB,+CAAa;AACjE,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,2CAA2C,2CAAS;AACpD;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA,gBAAgB,+CAAa,uBAAuB,4DAA0B;AAC9E,gBAAgB,+CAAa,sBAAsB,4DAA0B;AAC7E;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,4DAA0B;AACxE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,mEAAiC;AACzE;AACA;AACA;AACA;AACA,8CAA8C,qCAAG;AACjD,iDAAiD,qCAAG;AACpD,+CAA+C,qCAAG;AAClD,gCAAgC,qCAAG;AACnC;AACA;AACA;AACA;AACA,6CAA6C,qCAAG;AAChD,2CAA2C,qCAAG;AAC9C,4BAA4B,qCAAG;AAC/B;AACA;AACA,QAAQ,2CAAS;AACjB;AACA,mBAAmB,sEAAe;AAClC,oCAAoC,yDAAuB;AAC3D,mBAAmB,qCAAG,CAAC,yDAAuB,EAAE,qDAAmB;AACnE,yCAAyC,sDAAoB;AAC7D,mBAAmB,qCAAG,CAAC,sDAAoB,EAAE,qDAAmB;AAChE;AACA;AACA;AACA,wCAAwC,6BAA6B;AACrE;;;;;;;;;;;;;;;;;;;;;;;;;;;ACvGsC;AAC4B;AAC3D,oBAAoB;AACpB;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACO;AACA;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,oBAAoB;AACpB,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,+EAAwB;AAChD,qBAAqB,8DAAoB;AAClC;AACP;AACA,4CAA4C;;;;;;;;;;;;;;;;;ACvtB5C;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,oBAAoB,4BAA4B;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,0BAA0B;AACtD;AACA,4BAA4B,0BAA0B;AACtD;AACA;AACA,oEAAoE;AACpE;AACA;AACA;AACA,wBAAwB,mBAAmB;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oEAAoE;AACpE;AACA;AACA;AACA,wBAAwB,mBAAmB;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oFAAoF;AACpF;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,uBAAuB;AAC9C;AACA;AACA,QAAQ;AACR;AACA,oBAAoB,gBAAgB;AACpC;AACA;AACA,wBAAwB,oBAAoB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA,uDAAuD;AACvD;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA,uDAAuD;AACvD;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C;AAC9C,gDAAgD;AAChD;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,uDAAuD;AACvD;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;;;;;;;;;;;;;;;;;;;;;;AC1XsC;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;AACA;AACA;AACA;AACA,wBAAwB,wDAAc;AACtC,kCAAkC,2CAA2C;AAC7E,4BAA4B,wDAAc;AAC1C,sCAAsC,+CAA+C;AACrF,uBAAuB,wDAAc;AACrC,sBAAsB,wDAAc;AACpC,oBAAoB,mDAAS;AAC7B,wBAAwB,kDAAQ;AAChC,QAAQ,gDAAM;AACd,YAAY,gDAAM;AAClB,gBAAgB,iDAAO,EAAE,+CAAK;AAC9B,gBAAgB,iDAAO;AACvB;AACA;AACA,oBAAoB,gDAAM,kBAAkB,SAAS,eAAe;AACpE;AACA;AACA;AACA;AACA,oBAAoB,yDAAe;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;AC1D0G;AACkd;AAC5jB;AACO;AACA;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,qCAAG;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,wCAAwC,6BAA6B;AACrE;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,QAAQ,oBAAoB;AAC1E;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA,SAAS;AACT;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,QAAQ,oBAAoB;AACzE;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA,SAAS;AACT;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,yCAAyC,qCAAG;AAC5C,yCAAyC,qCAAG;AAC5C,oCAAoC,+CAAa,UAAU,2CAAS;AACpE;AACA;AACA;AACA,gBAAgB,qCAAG;AACnB;AACA;AACA,iCAAiC,wDAAsB;AACvD;AACA;AACA,wBAAwB,qBAAqB;AAC7C;AACA;AACA;AACA;AACA;AACA,YAAY,6DAA2B;AACvC;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,gBAAgB,qCAAG;AACnB,kCAAkC,qCAAG,8CAA8C,+CAAa;AAChG;AACA;AACA,KAAK;AACL;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,8DAA4B,KAAK;AACrE;AACA,kBAAkB,8DAA4B;AAC9C;AACA,uBAAuB,6EAAgC;AACvD,kBAAkB,wEAA2B;AAC7C;AACA;AACA,oCAAoC,wDAAsB,gCAAgC,0DAAwB;AAClH;AACA,kBAAkB,wDAAsB,SAAS,0DAAwB;AACzE,yBAAyB,6EAAgC;AACzD;AACA,kBAAkB,sEAAyB;AAC3C;AACA;AACA,oCAAoC,mDAAiB,gCAAgC,0DAAwB;AAC7G;AACA,kBAAkB,mDAAiB,SAAS,0DAAwB;AACpE,yBAAyB,wEAA2B;AACpD,uBAAuB,sEAAyB;AAChD,uBAAuB,4DAAe;AACtC;AACA,kBAAkB,uDAAU;AAC5B;AACA;AACA,oCAAoC,8DAA4B,gCAAgC,kDAAgB;AAChH;AACA,kBAAkB,8DAA4B,SAAS,kDAAgB;AACvE;AACA,uBAAuB,kFAAqC;AAC5D,qBAAqB,gFAAmC;AACxD,kBAAkB,mEAAsB;AACxC;AACA;AACA,oCAAoC,wDAAsB,gCAAgC,qDAAmB;AAC7G;AACA,kBAAkB,wDAAsB,SAAS,qDAAmB;AACpE,yBAAyB,wEAA2B;AACpD;AACA,qBAAqB,oEAAuB;AAC5C,kBAAkB,iEAAoB;AACtC;AACA;AACA,oCAAoC,sDAAoB;AACxD;AACA,kBAAkB,sDAAoB,SAAS,qDAAmB;AAClE,yBAAyB,sEAAyB;AAClD,uBAAuB,oEAAuB;AAC9C;AACA,kBAAkB,+DAAkB;AACpC;AACA;AACA,oCAAoC,mDAAiB,gCAAgC,qDAAmB;AACxG;AACA,kBAAkB,mDAAiB,SAAS,qDAAmB;AAC/D,yBAAyB,mEAAsB;AAC/C,uBAAuB,iEAAoB;AAC3C,qBAAqB,+DAAkB;AACvC,kBAAkB,4DAAe;AACjC;AACA,kBAAkB,uDAAU;AAC5B;AACA;AACA,oCAAoC,mDAAiB;AACrD;AACA,kBAAkB,mDAAiB;AACnC,yBAAyB,8DAAiB;AAC1C;AACA,uBAAuB,4DAAe;AACtC,kBAAkB,uDAAU;AAC5B;AACA;AACA,oCAAoC,yDAAuB;AAC3D;AACA,kBAAkB,yDAAuB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;AC5RO;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;;;;;;;;;;;;;;;;;;;;;;;;;;ACN0C;AACJ;AACA;AACsC;AACZ;AACa;AACjC;AACrC,qBAAqB,oDAAU;AACtC;AACA;AACO;AACP,oBAAoB,4DAAkB;AACtC;AACA;AACA;AACA,cAAc,4DAAkB;AAChC,QAAQ,uDAAa;AACrB,oBAAoB,yDAAQ;AAC5B,uBAAuB,6EAAoB;AAC3C,mBAAmB,0FAAkB;AACrC,SAAS;AACT;AACA;AACA;AACA;AACA,yFAAgC","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/autostart/registration.ts","webpack://sequencetranslator/./src/axolabs/constants.ts","webpack://sequencetranslator/./src/axolabs/define-pattern.ts","webpack://sequencetranslator/./src/axolabs/draw-svg.ts","webpack://sequencetranslator/./src/main/main-view.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","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\nimport { siRnaAxolabsToGcrs, gcrsToNucleotides, asoGapmersBioSpringToGcrs, gcrsToMermade12, } from '../structures-works/converters';\nimport { map, COL_NAMES, MODIFICATIONS } from '../structures-works/map';\nimport { isValidSequence } from '../structures-works/sequence-codes-tools';\nimport { sequenceToMolV3000 } from '../structures-works/from-monomers';\nimport { SALTS_CSV } from '../salts';\nimport { USERS_CSV } from '../users';\nimport { ICDS } from '../ICDs';\nimport { SOURCES } from '../sources';\nimport { IDPS } from '../IDPs';\nfunction sortByStringLengthInDescendingOrder(array) {\n    return array.sort(function (a, b) { return b.length - a.length; });\n}\nfunction stringify(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}\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.getCol(COL_NAMES.SEQUENCE);\n        const typeColumn = table.getCol(COL_NAMES.TYPE);\n        let result = '';\n        for (let i = 0; i < table.rowCount; i++) {\n            const format = 'Janssen GCRS Codes'; //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}\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; // /^[fsACGUacgu]{6,}$/\n                if (DG.Detector.sampleCategories(seqCol, (s) => /(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|f|s|A|C|G|U|a|c|g|u){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                    }); // /^[fmpsACGU]{6,}$/\n                }\n                else if (DG.Detector.sampleCategories(seqCol, (s) => /(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|f|m|ps|A|C|G|U){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                    }); // /^[*56789ATGC]{6,}$/\n                }\n                else if (DG.Detector.sampleCategories(seqCol, (s) => /(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|\\*|5|6|7|8|9|A|T|G|C){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                    }); // /^[*1-8]{6,}$/\n                }\n                else if (DG.Detector.sampleCategories(seqCol, (s) => /(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|\\*|1|2|3|4|5|6|7|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        return __awaiter(this, void 0, void 0, function* () {\n            if (t.columns.contains(COL_NAMES.COMPOUND_NAME))\n                return grok.shell.error('Columns already exist');\n            const sequenceCol = t.getCol(COL_NAMES.SEQUENCE);\n            const saltCol = t.getCol(COL_NAMES.SALT);\n            const equivalentsCol = t.getCol(COL_NAMES.EQUIVALENTS);\n            t.columns.addNewString(COL_NAMES.COMPOUND_NAME).init((i) => sequenceCol.get(i));\n            t.columns.addNewString(COL_NAMES.COMPOUND_COMMENTS).init((i) => (i > 0 && i % 2 == 0) ?\n                sequenceCol.get(i) + '; duplex of SS: ' + sequenceCol.get(i - 2) + ' and AS: ' + sequenceCol.get(i - 1) :\n                sequenceCol.get(i));\n            const molWeightCol = saltsDf.getCol('MOLWEIGHT');\n            const saltNamesList = saltsDf.getCol('DISPLAY').toList();\n            const weightsObj = {};\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                        weightsObj[code] = map[synthesizer][technology][code].weight;\n                }\n            }\n            for (const [key, value] of Object.entries(MODIFICATIONS))\n                weightsObj[key] = value.molecularWeight;\n            t.columns.addNewFloat(COL_NAMES.CPD_MW).init((i) => {\n                return (isValidSequence(sequenceCol.get(i), null).indexOfFirstNotValidChar == -1) ?\n                    molecularWeight(sequenceCol.get(i), weightsObj) :\n                    DG.FLOAT_NULL;\n            });\n            t.columns.addNewFloat(COL_NAMES.SALT_MASS).init((i) => {\n                const saltRowIndex = saltNamesList.indexOf(saltCol.get(i));\n                return (saltRowIndex == -1) ?\n                    DG.FLOAT_NULL :\n                    molWeightCol.get(saltRowIndex) * equivalentsCol.get(i);\n            });\n            yield 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    }\n    let newDf;\n    let addColumnsPressed = false;\n    const d = ui.div([\n        ui.icons.edit(() => {\n            d.innerHTML = '';\n            if (table.getCol(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', () => __awaiter(this, void 0, void 0, function* () {\n                yield addColumns(table, saltsDf);\n                view.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.dataFrame.getCol(COL_NAMES.TYPE).setTag(DG.TAGS.CHOICES, '[\"AS\", \"SS\", \"Duplex\"]');\n            view.dataFrame.getCol(COL_NAMES.OWNER).setTag(DG.TAGS.CHOICES, stringify(usersDf.columns.byIndex(0).toList()));\n            view.dataFrame.getCol(COL_NAMES.SALT).setTag(DG.TAGS.CHOICES, stringify(saltsDf.columns.byIndex(0).toList()));\n            view.dataFrame.getCol(COL_NAMES.SOURCE).setTag(DG.TAGS.CHOICES, stringify(sourcesDf.columns.byIndex(0).toList()));\n            view.dataFrame.getCol(COL_NAMES.ICD).setTag(DG.TAGS.CHOICES, stringify(icdsDf.columns.byIndex(0).toList()));\n            view.dataFrame.getCol(COL_NAMES.IDP).setTag(DG.TAGS.CHOICES, stringify(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","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};\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 './draw-svg';\nimport { axolabsMap } from './constants';\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 i = -1;\n    let mainSequence = sequence.replace(/[AUGC]/g, function (x) {\n        i++;\n        const indexOfSymbol = axolabsMap['RNA']['symbols'].indexOf(x);\n        let symbol = axolabsMap[bases[i].value]['symbols'][indexOfSymbol];\n        if (bases[i].value.slice(-3) == '(o)') {\n            if (i < sequence.length / 2 && bases[i + 1].value.slice(-3) != '(o)')\n                symbol = symbol + x + 'f';\n            else if (i > sequence.length / 2 && bases[i - 1].value.slice(-3) != '(o)')\n                symbol = x + 'f' + symbol;\n        }\n        return (ptoLinkages[i].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        if (inputSsColumn.value == '')\n            ssInputExample.value = generateExample(ssLength.value, sequenceBase.value);\n        if (createAsStrand.value && inputAsColumn.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.getCol(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.getCol(colName).get(0);\n        if (allLengthsAreTheSame && firstSequence.length != ssLength.value)\n            ssLength.value = tables.value.getCol(colName).get(0).length;\n        ssInputExample.value = firstSequence;\n    }\n    function validateAsColumn(colName) {\n        const allLengthsAreTheSame = checkWhetherAllValuesInColumnHaveTheSameLength(colName);\n        const firstSequence = tables.value.getCol(colName).get(0);\n        if (allLengthsAreTheSame && firstSequence.length != asLength.value)\n            asLength.value = tables.value.getCol(colName).get(0).length;\n        asInputExample.value = firstSequence;\n    }\n    function validateIdsColumn(colName) {\n        const col = tables.value.getCol(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.getCol(inputSsColumn.value).getString(0).length;\n                asLength.value = tables.value.getCol(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    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    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 downloadButton = ui.button('Download', () => svg.saveSvgAsPng(document.getElementById('mySvg'), saveAs.value, { backgroundColor: 'white' }));\n    const mainSection = ui.panel([\n        ui.block([\n            svgDiv,\n        ], { style: { overflowX: 'scroll' } }),\n        downloadButton,\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 './constants';\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","import * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\nimport { convertSequence, undefinedInputSequence, isValidSequence } from '../structures-works/sequence-codes-tools';\nimport { map, MODIFICATIONS } from '../structures-works/map';\nimport { sequenceToSmiles, sequenceToMolV3000 } from '../structures-works/from-monomers';\nimport $ from 'cash-dom';\nconst defaultInput = 'fAmCmGmAmCpsmU';\nconst sequenceWasCopied = 'Copied';\nconst tooltipSequence = 'Copy sequence';\nexport function mainView() {\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 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 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    $(codesTablesDiv).hide();\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    const v = grok.shell.v;\n    const tabControl = grok.shell.sidebar;\n    tabControl.onTabChanged.subscribe((_) => v.setRibbonPanels([(tabControl.currentPane.name == 'MAIN') ? topPanel : []]));\n    v.setRibbonPanels([topPanel]);\n    return 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}\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    let r1 = sequence.replace(regExp, function (code) { return obj[code]; });\n    while (r1.indexOf('//') != -1)\n        r1 = r1.replace('//', '/');\n    return r1;\n}\n//name: asoGapmersNucleotidesToBioSpring\n//input: string nucleotides {semType: DNA nucleotides}\n//output: string result {semType: BioSpring / Gapmers}\nexport function asoGapmersNucleotidesToBioSpring(nucleotides) {\n    let count = -1;\n    const objForEdges = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': '5*', 'A': '6*', 'C': '7*', 'G': '8*'\n    };\n    const objForCenter = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'T*', 'A': 'A*', 'C': '9*', 'G': 'G*'\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|T|C|G)/g, function (x) {\n        count++;\n        return (count > 4 && count < 15) ? objForCenter[x] : objForEdges[x];\n    }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?\n        nucleotides.length : 2 * count + 1);\n}\n//name: asoGapmersNucleotidesToGcrs\n//input: string nucleotides {semType: DNA nucleotides}\n//output: string result {semType: GCRS / Gapmers}\nexport function asoGapmersNucleotidesToGcrs(nucleotides) {\n    let count = -1;\n    const objForEdges = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'moeUnps',\n        'A': 'moeAnps', 'C': 'moe5mCnps', 'G': 'moeGnps'\n    };\n    const objForCenter = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'C': '5mCps', 'A': 'Aps', 'T': 'Tps', 'G': 'Gps' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|T|C|G)/g, function (x) {\n        count++;\n        if (count < 5)\n            return (count == 4) ? objForEdges[x].slice(0, -3) + 'ps' : objForEdges[x];\n        if (count < 15)\n            return (count == 14) ? objForCenter[x].slice(0, -2) + 'nps' : objForCenter[x];\n        return objForEdges[x];\n    }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?\n        nucleotides.length : -3);\n}\n//name: asoGapmersBioSpringToNucleotides\n//input: string nucleotides {semType: BioSpring / Gapmers}\n//output: string result {semType: DNA nucleotides}\nexport function asoGapmersBioSpringToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '*': '', '5': 'T', '6': 'A', '7': 'C', '8': 'G', '9': 'C' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|\\*|5|6|7|8|9)/g, function (x) { return obj[x]; });\n}\n//name: asoGapmersBioSpringToGcrs\n//input: string nucleotides {semType: BioSpring / Gapmers}\n//output: string result {semType: GCRS / Gapmers}\nexport function asoGapmersBioSpringToGcrs(nucleotides) {\n    let count = -1;\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '5*': 'moeUnps', '6*': 'moeAnps', '7*': 'moe5mCnps', '8*': 'moeGnps', '9*': '5mCps', 'A*': 'Aps', 'T*': 'Tps',\n        'G*': 'Gps', 'C*': 'Cps', '5': 'moeU', '6': 'moeA', '7': 'moe5mC', '8': 'moeG',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|5\\*|6\\*|7\\*|8\\*|9\\*|A\\*|T\\*|G\\*|C\\*|5|6|7|8)/g, function (x) {\n        count++;\n        return (count == 4) ? obj[x].slice(0, -3) + 'ps' : (count == 14) ? obj[x].slice(0, -2) + 'nps' : obj[x];\n    });\n}\n//name: asoGapmersGcrsToBioSpring\n//input: string nucleotides {semType: GCRS / Gapmers}\n//output: string result {semType: BioSpring / Gapmers}\nexport function asoGapmersGcrsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'moeT': '5', 'moeA': '6', 'moe5mC': '7', 'moeG': '8', 'moeU': '5', '5mC': '9', 'nps': '*', 'ps': '*', 'U': 'T',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|moeT|moeA|moe5mC|moeG|moeU|5mC|nps|ps|U)/g, function (x) { return obj[x]; });\n}\n//name: asoGapmersGcrsToNucleotides\n//input: string nucleotides {semType: GCRS / Gapmers}\n//output: string result {semType: DNA nucleotides}\nexport function asoGapmersGcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'moe': '', '5m': '', 'n': '', 'ps': '', 'U': 'T' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|moe|5m|n|ps|U)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToNucleotides\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaBioSpringToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'U', '2': 'A', '3': 'C', '4': 'G', '5': 'U', '6': 'A', '7': 'C', '8': 'G', '*': '' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToAxolabs\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: Axolabs / siRNA}\nexport function siRnaBioSpringToAxolabs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'Uf', '2': 'Af', '3': 'Cf', '4': 'Gf', '5': 'u', '6': 'a', '7': 'c', '8': 'g', '*': 's' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToGcrs\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: GCRS}\nexport function siRnaBioSpringToGcrs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'fU', '2': 'fA', '3': 'fC', '4': 'fG', '5': 'mU', '6': 'mA', '7': 'mC', '8': 'mG', '*': 'ps' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToGcrs\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: GCRS}\nexport function siRnaAxolabsToGcrs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': 'fU', 'Af': 'fA', 'Cf': 'fC', 'Gf': 'fG', 'u': 'mU', 'a': 'mA', 'c': 'mC', 'g': 'mG', 's': 'ps',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToBioSpring\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaAxolabsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': '1', 'Af': '2', 'Cf': '3', 'Gf': '4', 'u': '5', 'a': '6', 'c': '7', 'g': '8', 's': '*',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToNucleotides\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaAxolabsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': 'U', 'Af': 'A', 'Cf': 'C', 'Gf': 'G', 'u': 'U', 'a': 'A', 'c': 'C', 'g': 'G', 's': '',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToNucleotides\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaGcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G', 'ps': '',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToBioSpring\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaGcrsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': '1', 'fA': '2', 'fC': '3', 'fG': '4', 'mU': '5', 'mA': '6', 'mC': '7', 'mG': '8', 'ps': '*',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToAxolabs\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: Axolabs / siRNA}\nexport function siRnaGcrsToAxolabs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': 'Uf', 'fA': 'Af', 'fC': 'Cf', 'fG': 'Gf', 'mU': 'u', 'mA': 'a', 'mC': 'c', 'mG': 'g', 'ps': 's',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaNucleotideToBioSpringSenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaNucleotideToBioSpringSenseStrand(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '6*', 'U': '5*', 'G': '8*', 'C': '7*' };\n    const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '*6', 'U': '*5', 'G': '*8', 'C': '*7' };\n    const objForOddIndices = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '6', 'U': '5', 'G': '8', 'C': '7' };\n    const objForEvenIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': '2', 'U': '1', 'G': '4', 'C': '3' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count > nucleotides.length - 3)\n            return objForRightEdge[x];\n        return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];\n    });\n}\n//name: siRnaNucleotidesToGcrs\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: GCRS}\nexport function siRnaNucleotidesToGcrs(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'mAps', 'U': 'mUps', 'G': 'mGps', 'C': 'mCps' };\n    const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'psmA', 'U': 'psmU', 'G': 'psmG', 'C': 'psmC' };\n    const objForEvenIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'fA', 'U': 'fU', 'G': 'fG', 'C': 'fC' };\n    const objForOddIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'mA', 'U': 'mU', 'G': 'mG', 'C': 'mC' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count > nucleotides.length - 3)\n            return objForRightEdge[x];\n        return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];\n    });\n}\n//name: siRnaNucleotideToAxolabsSenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: Axolabs}\nexport function siRnaNucleotideToAxolabsSenseStrand(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };\n    const objForSomeIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count == 6 || (count > 7 && count < 11))\n            return objForSomeIndices[x];\n        if (count == nucleotides.length - 1)\n            return 'a';\n        return obj[x];\n    });\n}\n//name: siRnaNucleotideToAxolabsAntisenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: Axolabs}\nexport function siRnaNucleotideToAxolabsAntisenseStrand(nucleotides) {\n    let count = -1;\n    const objForSmallLinkages = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };\n    const objForBigLinkages = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Afs', 'U': 'Ufs', 'G': 'Gfs', 'C': 'Cfs' };\n    const objForSomeIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };\n    const obj = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count > 19 && count < 22)\n            return objForSmallLinkages[x];\n        if (count == 0)\n            return 'us';\n        if (count == 1)\n            return objForBigLinkages[x];\n        return (count == 5 || count == 7 || count == 8 || count == 13 || count == 15) ? objForSomeIndices[x] : obj[x];\n    });\n}\n//name: gcrsToNucleotides\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: RNA nucleotides}\nexport function gcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'mAps': 'A', 'mUps': 'U', 'mGps': 'G', 'mCps': 'C', 'fAps': 'A', 'fUps': 'U', 'fGps': 'G', 'fCps': 'C',\n        'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });\n}\n//name: gcrsToMermade12\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: Mermade 12 / siRNA}\nexport function gcrsToMermade12(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'mAps': 'e', 'mUps': 'h', 'mGps': 'g', 'mCps': 'f', 'fAps': 'i', 'fUps': 'l', 'fGps': 'k', 'fCps': 'j', 'fU': 'L',\n        'fA': 'I', 'fC': 'J', 'fG': 'K', 'mU': 'H', 'mA': 'E', 'mC': 'F', 'mG': 'G',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });\n}\n","import { map, stadardPhosphateLinkSmiles, SYNTHESIZERS, TECHNOLOGIES, MODIFICATIONS, delimiter } from './map';\nimport { isValidSequence } from './sequence-codes-tools';\nimport { getNucleotidesMol } from './mol-transformations';\nexport function sequenceToMolV3000(sequence, inverted = false, oclRender = false, format) {\n    const obj = getObjectWithCodesAndSmiles(sequence, format);\n    let codes = sortByStringLengthInDescendingOrder(Object.keys(obj));\n    let i = 0;\n    const smilesCodes = [];\n    const codesList = [];\n    const links = ['s', 'ps', '*'];\n    const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];\n    const dropdowns = Object.keys(MODIFICATIONS);\n    codes = codes.concat(dropdowns).concat(delimiter);\n    while (i < sequence.length) {\n        const code = codes.find((s) => s == sequence.slice(i, i + s.length));\n        i += code.length;\n        inverted ? codesList.unshift(code) : codesList.push(code);\n    }\n    for (let i = 0; i < codesList.length; i++) {\n        if (dropdowns.includes(codesList[i])) {\n            smilesCodes.push((i >= codesList.length / 2) ?\n                MODIFICATIONS[codesList[i]].right : MODIFICATIONS[codesList[i]].left);\n            smilesCodes.push(stadardPhosphateLinkSmiles);\n        }\n        else {\n            if (links.includes(codesList[i]) ||\n                includesStandardLinkAlready.includes(codesList[i]) ||\n                (i < codesList.length - 1 && links.includes(codesList[i + 1])))\n                smilesCodes.push(obj[codesList[i]]);\n            else {\n                smilesCodes.push(obj[codesList[i]]);\n                smilesCodes.push(stadardPhosphateLinkSmiles);\n            }\n        }\n    }\n    return getNucleotidesMol(smilesCodes);\n}\nexport function sequenceToSmiles(sequence, inverted = false, format) {\n    const obj = getObjectWithCodesAndSmiles(sequence, format);\n    let codes = sortByStringLengthInDescendingOrder(Object.keys(obj));\n    let i = 0;\n    let smiles = '';\n    const codesList = [];\n    const links = ['s', 'ps', '*'];\n    const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];\n    const dropdowns = Object.keys(MODIFICATIONS);\n    codes = codes.concat(dropdowns).concat(delimiter);\n    while (i < sequence.length) {\n        const code = codes.find((s) => s == sequence.slice(i, i + s.length));\n        i += code.length;\n        inverted ? codesList.unshift(code) : codesList.push(code);\n    }\n    for (let i = 0; i < codesList.length; i++) {\n        if (dropdowns.includes(codesList[i])) {\n            smiles += (i >= codesList.length / 2) ?\n                MODIFICATIONS[codesList[i]].right + stadardPhosphateLinkSmiles :\n                MODIFICATIONS[codesList[i]].left + stadardPhosphateLinkSmiles;\n        }\n        else {\n            if (links.includes(codesList[i]) ||\n                includesStandardLinkAlready.includes(codesList[i]) ||\n                (i < codesList.length - 1 && links.includes(codesList[i + 1])))\n                smiles += obj[codesList[i]];\n            else\n                smiles += obj[codesList[i]] + stadardPhosphateLinkSmiles;\n        }\n    }\n    smiles = smiles.replace(/OO/g, 'O');\n    return ((links.includes(codesList[codesList.length - 1]) &&\n        codesList.length > 1 &&\n        !includesStandardLinkAlready.includes(codesList[codesList.length - 2])) ||\n        dropdowns.includes(codesList[codesList.length - 1]) ||\n        includesStandardLinkAlready.includes(codesList[codesList.length - 1])) ?\n        smiles :\n        smiles.slice(0, smiles.length - stadardPhosphateLinkSmiles.length + 1);\n}\nfunction getObjectWithCodesAndSmiles(sequence, format) {\n    const obj = {};\n    if (format == null) {\n        for (const synthesizer of Object.keys(map)) {\n            for (const technology of Object.keys(map[synthesizer])) {\n                for (const code of Object.keys(map[synthesizer][technology]))\n                    obj[code] = map[synthesizer][technology][code].SMILES;\n            }\n        }\n    }\n    else {\n        for (const technology of Object.keys(map[format])) {\n            for (const code of Object.keys(map[format][technology]))\n                obj[code] = map[format][technology][code].SMILES;\n        }\n    }\n    obj[delimiter] = '';\n    // TODO: create object based from synthesizer type to avoid key(codes) duplicates\n    const output = isValidSequence(sequence, format);\n    if (output.synthesizer.includes(SYNTHESIZERS.MERMADE_12))\n        obj['g'] = map[SYNTHESIZERS.MERMADE_12][TECHNOLOGIES.SI_RNA]['g'].SMILES;\n    else if (output.synthesizer.includes(SYNTHESIZERS.AXOLABS))\n        obj['g'] = map[SYNTHESIZERS.AXOLABS][TECHNOLOGIES.SI_RNA]['g'].SMILES;\n    return obj;\n}\nfunction sortByStringLengthInDescendingOrder(array) {\n    return array.sort(function (a, b) { return b.length - a.length; });\n}\n","import * as DG from 'datagrok-api/dg';\nimport { getAllCodesOfSynthesizer } from './sequence-codes-tools';\nexport const delimiter = ';';\nexport const SYNTHESIZERS = {\n    RAW_NUCLEOTIDES: 'Raw Nucleotides',\n    BIOSPRING: 'BioSpring Codes',\n    GCRS: 'Janssen GCRS Codes',\n    AXOLABS: 'Axolabs Codes',\n    MERMADE_12: 'Mermade 12',\n    LCMS: 'LCMS',\n};\nexport const TECHNOLOGIES = {\n    DNA: 'DNA',\n    RNA: 'RNA',\n    ASO_GAPMERS: 'For ASO Gapmers',\n    SI_RNA: 'For 2\\'-OMe and 2\\'-F modified siRNA',\n};\nexport const COL_NAMES = {\n    CHEMISTRY: 'Chemistry',\n    NUMBER: 'Number',\n    TYPE: 'Type',\n    CHEMISTRY_NAME: 'Chemistry Name',\n    INTERNAL_COMPOUND_ID: 'Internal compound ID',\n    IDP: 'IDP',\n    SEQUENCE: 'Sequence',\n    COMPOUND_NAME: 'Compound Name',\n    COMPOUND_COMMENTS: 'Compound Comments',\n    SALT: 'Salt',\n    EQUIVALENTS: 'Equivalents',\n    PURITY: 'Purity',\n    CPD_MW: 'Cpd MW',\n    SALT_MASS: 'Salt mass',\n    BATCH_MW: 'Batch MW',\n    SOURCE: 'Source',\n    ICD: 'ICD',\n    OWNER: 'Owner',\n};\n// interface CODES {\n// }\nexport const MODIFICATIONS = {\n    '(invabasic)': {\n        molecularWeight: 118.13,\n        left: 'O[C@@H]1C[C@@H]O[C@H]1CO',\n        right: 'O[C@@H]1C[C@@H]O[C@H]1CO',\n    },\n    '(GalNAc-2-JNJ)': {\n        molecularWeight: 1273.3,\n        left: 'C(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)NC(=O)CCCC(=O)NCC(O)CO',\n        right: 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)',\n    },\n};\nexport const stadardPhosphateLinkSmiles = 'OP(=O)(O)O';\nexport const map = {\n    'Raw Nucleotides': {\n        'DNA': {\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n        },\n        'RNA': {\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'U': {\n                'name': 'Uracil',\n                'weight': 306.17,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n        },\n    },\n    'BioSpring Codes': {\n        'For ASO Gapmers': {\n            '5': {\n                'name': '2\\'MOE-5Me-rU',\n                'weight': 378.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '6': {\n                'name': '2\\'MOE-rA',\n                'weight': 387.29,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '7': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '8': {\n                'name': '2\\'MOE-rG',\n                'weight': 403.28,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '9': {\n                'name': '5-Methyl-dC',\n                'weight': 303.21,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            '*': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n        },\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            '1': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            '2': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            '3': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            '4': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            '5': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            '6': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            '7': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            '8': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            '*': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n        },\n    },\n    'Axolabs Codes': {\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'Uf': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'Af': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'Cf': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'Gf': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'u': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'a': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'c': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'g': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            's': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n        },\n    },\n    'Janssen GCRS Codes': {\n        'For ASO Gapmers': {\n            'moeT': {\n                'name': '2\\'MOE-5Me-rU',\n                'weight': 378.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            'moeA': {\n                'name': '2\\'MOE-rA',\n                'weight': 387.29,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            'moe5mC': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '(5m)moeC': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            'moeG': {\n                'name': '2\\'MOE-rG',\n                'weight': 403.28,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '5mC': {\n                'name': '5-Methyl-dC',\n                'weight': 303.28,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            '(5m)C': {\n                'name': '5-Methyl-dC',\n                'weight': 303.28,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            'ps': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n            's': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'dA': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'dC': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'dG': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'dT': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'rA': {\n                'name': 'Adenine',\n                'weight': 329.21,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](O)[C@@H]1O',\n            },\n            'rC': {\n                'name': 'Cytosine',\n                'weight': 305.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](O)[C@@H]1O',\n            },\n            'rG': {\n                'name': 'Guanine',\n                'weight': 345.21,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](O)[C@@H]1O',\n            },\n            'rU': {\n                'name': 'Uracil',\n                'weight': 306.17,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',\n            },\n        },\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'fU': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'fA': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'fC': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'fG': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'mU': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'mA': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'mC': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'mG': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n        },\n        'Others': {},\n    },\n    'Mermade 12': {\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'e': {\n                'name': '2\\'OMe-rA-ps',\n                'weight': 359.31,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'h': {\n                'name': '2\\'OMe-rU-ps',\n                'weight': 336.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'g': {\n                'name': '2\\'OMe-rG-ps',\n                'weight': 375.31,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'f': {\n                'name': '2\\'OMe-rC-ps',\n                'weight': 335.28,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'i': {\n                'name': '2\\'-fluoro-A-ps',\n                'weight': 347.27,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'l': {\n                'name': '2\\'-fluoro-U-ps',\n                'weight': 324.23,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'k': {\n                'name': '2\\'-fluoro-G-ps',\n                'weight': 363.26,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'j': {\n                'name': '2\\'-fluoro-C-ps',\n                'weight': 323.25,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'L': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'I': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'J': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'K': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'H': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'E': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'F': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'G': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n        },\n    },\n    // 'LCMS': {\n    //   'For 2\\'-OMe and 2\\'-F modified siRNA': {\n};\nexport const lcmsToGcrs = `LCMS, GCRS\nA, A\nC, C\n/5mC/, (5m)C\nG, G\nT, T\nrA, rA\nrC, rC\nrG, rG\nrU, rU\nmA, mA\nmC, mC\n/5mmC/, (5m)mC\nmG, mG\nmU, mU\nfA, fA\nfC, fC\n/5mfC/, (5m)fC\nfG, fG\nfU, fU\n/afA/, afA\n/afC/, afC\n/afG/, afG\n/afU/, afU\n+A, lna A\n+C, lna C\n+G, lna G\n+T, lna T\n/moeA/, moeA\n/moeC/, moeC\n/5mmoeC/, (5m)moeC\n/moeG/, moeG\n/moeT/, moeT\n/moeU/, moeU\n/xA/, Anp\n/xC/, Cnp\n/x5mC/, (5m)Cnp\n/xG/, Gnp\n/xT/, Tnp\n/xrA/, rAnp\n/xrC/, rCnp\n/xrG/, rGnp\n/xrU/, rUnp\n/xmA/, mAnp\n/xmC/, mCnp\n/x5mmC/, (5m)mCnp\n/xmG/, mGnp\n/xmU/, mUnp\n/xfA/, fAnp\n/xfC/, fCnp\n/xfG/, fGnp\n/xfT/, fTnp\n/xfU/, fUnp\n/xafA/, afAnp\n/xafC/, afCnp\n/xafG/, afGnp\n/xafU/, afUnp\n/xeA/, eAnp\n/xeC/, eCnp\n/xeG/, eGnp\n/xeU/, eUnp\n/xmoeA/, moeAnp\n/xmoeC/, moeCnp\n/x5mmoeC/, (5m)moeCnp\n/xmoeG/, moeGnp\n/xmoeU/, moeUnp\n/UNA-A/, (UNA-A)\n/UNA-C/, (UNA-C)\n/UNA-G/, (UNA-G)\n/UNA-T/, (UNA-T)\n/UNA-U/, (UNA-U)\n/GNA-A/, (GNA-A)\n/GNA-C/, (GNA-C)\n/GNA-G/, (GNA-G)\n/GNA-T/, (GNA-T)\n/GNA-U/, (GNA-U)\n/5CholTEG/, (5-CholTEG)\n/3CholTEG/, (TEGChol-3)\n/Toco/, Toco\n/Palm/, Palm\n/GalNAc/, GalNAc\n/GalNAc2/, GalNAc2\n/GalNAc3/, GalNAc3\n/GalNAc6/, GalNAc6\n/GalNAc7/, GalNAc7\n/GalNAc9/, GalNAc9\n/GalNAc14/, GalNAc14\n/NAG37/, NAG37\n/HEG/, (HEG)\n/TEG/, (TEG)\n/AmmC6/, (NHC6)\n/AmmC7/, (NHC7)\n/AmmC12/, (NHC12)\n/invAb/, (invabasic)\n/invdT/, (invdT)\n/VPmU/, (vinu)\n*, ps\n/2-C16U/, 2-C16U \n/2-C18w9U/, 2-C18w9U\n/JDi-Palm/, JDi-Palm\n/J2-CONC16U/, J2-CONC16U\n/J2-C3NC16U/, J2-C3NC16U\n/J-C15Ada/, J-C15Ada\n/J-2C15AdaU/, J-2C15AdaU\n/J-C16NC6/, J-C16NC6\n/R2-C6NH-U/, R2-C6NH-U\n/J-M1/, J-M1\n/J-B1/, J-B1\n/J-B2/, J-B2\n/J-M2/, J-M2\n/2-C16C/, 2-C16C\n/2-C16A/, 2-C16A\n/2-C16G/, 2-C16G\n/R2-C6NH-G/, R2-C6NH-G\n/R2-C6NH-C/, R2-C6NH-C\n/J2-CONC16A/, J2-CONC16A\n/J2-CONC16C/, J2-CONC16C\n/J2-CONC16G/, J2-CONC16G\n/J2-C15AdaC/, J2-C15AdaC\n/J2-M2U/, J2-M2U\n/J2-B2U/, J2-B2U\n/J2-C3NC16C/, J2-C3NC16C\n/J2-C3NC16G/, J2-C3NC16G\n/R2-C6NH-A/, R2-C6NH-A\n/J2-C15AdaA/, J2-C15AdaA\n/J2-C3NC16A/, J2-C3NC16A\n/J-C5-SER-1/, J-C5-SER-1\n/J-C16-SER-1/, J-C16-SER-1\n/J-A2/, J-A2\n/J-A1/, J-A1\n/J2-C15AdaG/, J2-C15AdaG\n/J-C16NAsp/, J-C16NAsp\n/J2-C16NC6U/, J2-C16NC6U\n/J-C5-REBO-1/, J-C5-REBO-1\n/J-C16-REBO-1/, J-C16-REBO-1\n/J-C16-IND-1/, J-C16-IND-1\n/J-C5-IND-1/, J-C5-IND-1\n/J-1C15Ada-2Man/, J-1C15Ada-2Man\n/JG-1C15Ada-23DiMan/, JG-1C15Ada-2,3DiMan\n/J-TriManPC/, J-TriManPC\n/J-triManPO/, J-triManPO\n/J-A4/, J-A4\n/J-Ara-1/, J-Ara-1\n/J-Ara-2/, J-Ara-2\n/J-AcCS/, J-AcCS\n/J-CbCS/, J-CbCS\n/J-MtCD/, J-MtCD`;\nfunction differenceOfTwoArrays(a, b) {\n    return a.filter((x) => !b.includes(x));\n}\nconst codesWithSmiles = getAllCodesOfSynthesizer(SYNTHESIZERS.GCRS);\nconst allGcrsCodes = DG.DataFrame.fromCsv(lcmsToGcrs).getCol('GCRS').toList();\nexport const gcrsCodesWithoutSmiles = differenceOfTwoArrays(allGcrsCodes, codesWithSmiles);\nfor (const e of gcrsCodesWithoutSmiles)\n    map[SYNTHESIZERS.GCRS]['Others'][e] = { 'SMILES': '' };\n","const PHOSHATE = `\nDatagrok monomer library Nucleotides\n\n  0  0  0  0  0  0              0 V3000\nM  V30 BEGIN CTAB\nM  V30 COUNTS 5 4 0 0 0\nM  V30 BEGIN ATOM\nM  V30 1 O -1.5 0 0 0\nM  V30 2 P 0 0 0 0\nM  V30 3 O 0 1 0 0\nM  V30 4 O 0 -1 0 0\nM  V30 5 O 1.5 0 0 0\nM  V30 END ATOM\nM  V30 BEGIN BOND\nM  V30 1 1 1 2\nM  V30 2 2 2 3\nM  V30 3 1 2 4\nM  V30 4 1 2 5\nM  V30 END BOND\nM  V30 END CTAB\nM  V30 BEGIN COLLECTION\nM  V30 END COLLECTION\nM  END`;\nconst THIOPHOSHATE = `\nDatagrok monomer library Nucleotides\n\n  0  0  0  0  0  0              0 V3000\nM  V30 BEGIN CTAB\nM  V30 COUNTS 5 4 0 0 0\nM  V30 BEGIN ATOM\nM  V30 1 O -1.5 0 0 0\nM  V30 2 P 0 0 0 0\nM  V30 3 O 0 1 0 0\nM  V30 4 S 0 -1 0 0\nM  V30 5 O 1.5 0 0 0\nM  V30 END ATOM\nM  V30 BEGIN BOND\nM  V30 1 1 1 2\nM  V30 2 2 2 3\nM  V30 3 1 2 4\nM  V30 4 1 2 5\nM  V30 END BOND\nM  V30 END CTAB\nM  V30 BEGIN COLLECTION\nM  V30 END COLLECTION\nM  END`;\nconst INVABASIC = `\nDatagrok monomer library Nucleotides\n\n  0  0  0  0  0  0              0 V3000\nM  V30 BEGIN CTAB\nM  V30 COUNTS 8 8 0 0 0\nM  V30 BEGIN ATOM\nM  V30 1 O 1.0934 -2.1636 0 0\nM  V30 2 C 1.8365 -1.4945 0 0 CFG=2\nM  V30 3 C 2.8147 -1.7024 0 0\nM  V30 4 C 3.3147 -0.8364 0 0 VAL=3\nM  V30 5 O 2.6455 -0.0932 0 0\nM  V30 6 C 1.732 -0.5 0 0 CFG=1\nM  V30 7 C 0.866 0 0 0\nM  V30 8 O 0.866 1 0 0\nM  V30 END ATOM\nM  V30 BEGIN BOND\nM  V30 1 1 2 1 CFG=1\nM  V30 2 1 2 3\nM  V30 3 1 3 4\nM  V30 4 1 4 5\nM  V30 5 1 6 5\nM  V30 6 1 2 6\nM  V30 7 1 6 7 CFG=3\nM  V30 8 1 7 8\nM  V30 END BOND\nM  V30 BEGIN COLLECTION\nM  V30 MDLV30/STEABS ATOMS=(2 2 6)\nM  V30 END COLLECTION\nM  V30 END CTAB\nM  END`;\nexport function getNucleotidesMol(smilesCodes) {\n    const molBlocks = [];\n    for (let i = 0; i < smilesCodes.length - 1; i++) {\n        smilesCodes[i] == 'OP(=O)(O)O' ? molBlocks.push(PHOSHATE) :\n            smilesCodes[i] == 'OP(=O)(S)O' ? molBlocks.push(THIOPHOSHATE) :\n                smilesCodes[i] == 'O[C@@H]1C[C@@H]O[C@H]1CO' ? molBlocks.push(rotateNucleotidesV3000(INVABASIC)) :\n                    molBlocks.push(rotateNucleotidesV3000(smilesCodes[i]));\n    }\n    return linkV3000(molBlocks, false);\n}\nexport function linkV3000(molBlocks, twoChains = false, useChirality = true) {\n    let macroMolBlock = '\\nDatagrok macromolecule handler\\n\\n';\n    macroMolBlock += '  0  0  0  0  0  0            999 V3000\\n';\n    macroMolBlock += 'M  V30 BEGIN CTAB\\n';\n    let atomBlock = '';\n    let bondBlock = '';\n    let collectionBlock = '';\n    const collection = [];\n    let natom = 0;\n    let nbond = 0;\n    let xShift = 0;\n    if (twoChains && molBlocks.length > 1)\n        molBlocks[1] = invertNucleotidesV3000(molBlocks[1]);\n    for (let i = 0; i < molBlocks.length; i++) {\n        molBlocks[i] = molBlocks[i].replaceAll('(-\\nM  V30 ', '(')\n            .replaceAll('-\\nM  V30 ', '').replaceAll(' )', ')');\n        const numbers = extractAtomsBondsNumbersV3000(molBlocks[i]);\n        const coordinates = extractAtomDataV3000(molBlocks[i]);\n        if (twoChains) {\n            const xShiftRight = Math.min(...coordinates.x);\n            const yShift = i == 0 ? Math.min(...coordinates.y) - 1 : Math.max(...coordinates.y) + 1;\n            for (let j = 0; j < coordinates.x.length; j++)\n                coordinates.x[j] -= xShiftRight;\n            for (let j = 0; j < coordinates.y.length; j++)\n                coordinates.y[j] -= yShift;\n        }\n        let indexAtoms = molBlocks[i].indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n        indexAtoms = molBlocks[i].indexOf('\\n', indexAtoms);\n        let index = indexAtoms;\n        let indexEnd = indexAtoms;\n        for (let j = 0; j < numbers.natom; j++) {\n            if (coordinates.atomIndex[j] != 1 || i == 0 || twoChains) {\n                //rewrite atom number\n                index = molBlocks[i].indexOf('V30', index) + 4;\n                indexEnd = molBlocks[i].indexOf(' ', index);\n                const atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;\n                molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);\n                //rewrite coordinates\n                index = molBlocks[i].indexOf(' ', index) + 1;\n                index = molBlocks[i].indexOf(' ', index) + 1;\n                indexEnd = molBlocks[i].indexOf(' ', index);\n                const totalShift = twoChains ? 0 : xShift - coordinates.x[0];\n                let coordinate = twoChains ?\n                    Math.round(10000 * coordinates.x[j]) / 10000 :\n                    Math.round(10000 * (parseFloat(molBlocks[i].substring(index, indexEnd)) + totalShift)) / 10000;\n                molBlocks[i] = molBlocks[i].slice(0, index) + coordinate + molBlocks[i].slice(indexEnd);\n                index = molBlocks[i].indexOf(' ', index) + 1;\n                indexEnd = molBlocks[i].indexOf(' ', index);\n                coordinate = twoChains ?\n                    Math.round(10000 * coordinates.y[j]) / 10000 :\n                    Math.round(10000 * (parseFloat(molBlocks[i].substring(index, indexEnd)))) / 10000;\n                molBlocks[i] = molBlocks[i].slice(0, index) + coordinate + molBlocks[i].slice(indexEnd);\n                index = molBlocks[i].indexOf('\\n', index) + 1;\n            }\n            else {\n                index = molBlocks[i].indexOf('M  V30', index) - 1;\n                indexEnd = molBlocks[i].indexOf('\\n', index + 1);\n                molBlocks[i] = molBlocks[i].slice(0, index) + molBlocks[i].slice(indexEnd);\n            }\n        }\n        const indexAtomsEnd = molBlocks[i].indexOf('M  V30 END ATOM');\n        atomBlock += molBlocks[i].substring(indexAtoms + 1, indexAtomsEnd);\n        let indexBonds = molBlocks[i].indexOf('M  V30 BEGIN BOND'); // V3000 index for bonds\n        indexBonds = molBlocks[i].indexOf('\\n', indexBonds);\n        index = indexBonds;\n        indexEnd = indexBonds;\n        for (let j = 0; j < numbers.nbond; j++) {\n            //rewrite bond number\n            index = molBlocks[i].indexOf('V30', index) + 4;\n            indexEnd = molBlocks[i].indexOf(' ', index);\n            const bondNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + nbond;\n            molBlocks[i] = molBlocks[i].slice(0, index) + bondNumber + molBlocks[i].slice(indexEnd);\n            //rewrite atom pair in bond\n            index = molBlocks[i].indexOf(' ', index) + 1;\n            index = molBlocks[i].indexOf(' ', index) + 1;\n            indexEnd = molBlocks[i].indexOf(' ', index);\n            let atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;\n            molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);\n            index = molBlocks[i].indexOf(' ', index) + 1;\n            indexEnd = Math.min(molBlocks[i].indexOf('\\n', index), molBlocks[i].indexOf(' ', index));\n            atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;\n            molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);\n            index = molBlocks[i].indexOf('\\n', index) + 1;\n        }\n        const indexBondEnd = molBlocks[i].indexOf('M  V30 END BOND');\n        bondBlock += molBlocks[i].substring(indexBonds + 1, indexBondEnd);\n        let indexCollection = molBlocks[i].indexOf('M  V30 MDLV30/STEABS ATOMS=('); // V3000 index for collections\n        while (indexCollection != -1) {\n            indexCollection += 28;\n            const collectionEnd = molBlocks[i].indexOf(')', indexCollection);\n            const collectionEntries = molBlocks[i].substring(indexCollection, collectionEnd).split(' ').slice(1);\n            collectionEntries.forEach((e) => {\n                collection.push(parseInt(e) + natom);\n            });\n            indexCollection = collectionEnd;\n            indexCollection = molBlocks[i].indexOf('M  V30 MDLV30/STEABS ATOMS=(', indexCollection);\n        }\n        natom += twoChains ? numbers.natom : numbers.natom - 1;\n        nbond += numbers.nbond;\n        xShift += twoChains ? 0 : coordinates.x[numbers.natom - 1] - coordinates.x[0];\n    }\n    const entries = 4;\n    const collNumber = Math.ceil(collection.length / entries);\n    //if (oclRender) {\n    // collectionBlock += 'M  V30 MDLV30/STEABS ATOMS=(' + collection.length;\n    // for (let j = 0; j < collection.length; j++)\n    //   collectionBlock += ' ' + collection[j];\n    // collectionBlock += ')\\n';\n    //} else {\n    collectionBlock += 'M  V30 MDLV30/STEABS ATOMS=(' + collection.length + ' -\\n';\n    for (let i = 0; i < collNumber; i++) {\n        collectionBlock += 'M  V30 ';\n        const entriesCurrent = i + 1 == collNumber ? collection.length - (collNumber - 1) * entries : entries;\n        for (let j = 0; j < entriesCurrent; j++) {\n            collectionBlock += (j + 1 == entriesCurrent) ?\n                (i == collNumber - 1 ? collection[entries * i + j] + ')\\n' : collection[entries * i + j] + ' -\\n') :\n                collection[entries * i + j] + ' ';\n        }\n    }\n    //}\n    //generate file\n    twoChains ? natom : natom++;\n    macroMolBlock += 'M  V30 COUNTS ' + natom + ' ' + nbond + ' 0 0 0\\n';\n    macroMolBlock += 'M  V30 BEGIN ATOM\\n';\n    macroMolBlock += atomBlock;\n    macroMolBlock += 'M  V30 END ATOM\\n';\n    macroMolBlock += 'M  V30 BEGIN BOND\\n';\n    macroMolBlock += bondBlock;\n    macroMolBlock += 'M  V30 END BOND\\n';\n    if (useChirality) {\n        macroMolBlock += 'M  V30 BEGIN COLLECTION\\n';\n        macroMolBlock += collectionBlock;\n        macroMolBlock += 'M  V30 END COLLECTION\\n';\n    }\n    else\n        macroMolBlock = macroMolBlock.replace(/ CFG=\\d/g, ' ');\n    macroMolBlock += 'M  V30 END CTAB\\n';\n    macroMolBlock += 'M  END\\n';\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, useChirality, invertSS, invertAS) {\n    const formatAs = getFormat(as);\n    const formatSs = getFormat(ss);\n    const molSS = sequenceToMolV3000(ss, invertSS, false, formatSs);\n    const molAS = sequenceToMolV3000(as, invertAS, false, formatAs);\n    let result;\n    if (oneEntity)\n        result = linkV3000([molSS, molAS], true, useChirality) + '\\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', '');\n    const asInput = ui.textInput('Anti Sense', '');\n    const straight = '5\\' ->3\\'';\n    const inverse = '3\\' ->5\\'';\n    let ssInverse = false;\n    let asInverse = false;\n    const changeSense = ui.choiceInput('SS direction', straight, [straight, inverse]);\n    changeSense.onChanged(() => { ssInverse = changeSense.value == inverse; });\n    const changeAntiSense = ui.choiceInput('AS direction', straight, [straight, inverse]);\n    changeAntiSense.onChanged(() => { asInverse = changeAntiSense.value == inverse; });\n    const saveOption = ui.switchInput('Save as one entity', true);\n    const chirality = ui.switchInput('Use chiral', true);\n    const saveBtn = ui.button('Save SDF', () => saveSdf(asInput.value, ssInput.value, saveOption.value, chirality.value, ssInverse, asInverse));\n    const saveSection = ui.panel([\n        ui.div([\n            ui.div([\n                ui.divH([ui.h1('Inputs')]),\n                ui.divV([\n                    ssInput,\n                    asInput,\n                    ui.div([changeSense], { style: { width: '40' } }),\n                    changeSense,\n                    changeAntiSense,\n                    saveOption,\n                    chirality,\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, delimiter, gcrsCodesWithoutSmiles } from './map';\nimport { asoGapmersNucleotidesToBioSpring, asoGapmersNucleotidesToGcrs, asoGapmersBioSpringToNucleotides, asoGapmersBioSpringToGcrs, asoGapmersGcrsToNucleotides, asoGapmersGcrsToBioSpring, gcrsToMermade12, siRnaNucleotideToBioSpringSenseStrand, siRnaNucleotideToAxolabsSenseStrand, siRnaNucleotidesToGcrs, siRnaBioSpringToNucleotides, siRnaBioSpringToAxolabs, siRnaBioSpringToGcrs, siRnaAxolabsToNucleotides, siRnaAxolabsToBioSpring, siRnaAxolabsToGcrs, siRnaGcrsToNucleotides, siRnaGcrsToBioSpring, siRnaGcrsToAxolabs, gcrsToNucleotides, gcrsToLcms } from './converters';\nconst noTranslationTableAvailable = 'No translation table available';\nexport const undefinedInputSequence = 'Type of input sequence is undefined';\nexport function getFormat(sequence) {\n    const possibleSynthesizers = getListOfPossibleSynthesizersByFirstMatchedCode(sequence);\n    if (possibleSynthesizers.length == 0)\n        return null;\n    let outputIndex = 0;\n    const firstUniqueCharacters = ['r', 'd'];\n    const nucleotides = ['A', 'U', 'T', 'C', 'G'];\n    possibleSynthesizers.forEach((synthesizer) => {\n        const codes = getAllCodesOfSynthesizer(synthesizer);\n        while (outputIndex < sequence.length) {\n            const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));\n            if (matchedCode == null)\n                break;\n            if ( // for mistake pattern 'rAA'\n            outputIndex > 1 &&\n                nucleotides.includes(sequence[outputIndex]) &&\n                firstUniqueCharacters.includes(sequence[outputIndex - 2]))\n                break;\n            if ( // for mistake pattern 'ArA'\n            firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&\n                nucleotides.includes(sequence[outputIndex])) {\n                outputIndex++;\n                break;\n            }\n            outputIndex += matchedCode.length;\n        }\n    });\n    const indexOfFirstNotValidChar = (outputIndex == sequence.length) ? -1 : outputIndex;\n    if (indexOfFirstNotValidChar != -1)\n        return possibleSynthesizers[0];\n    const possibleTechnologies = getListOfPossibleTechnologiesByFirstMatchedCode(sequence, possibleSynthesizers[0]);\n    if (possibleTechnologies.length == 0)\n        return null;\n    outputIndex = 0;\n    possibleTechnologies.forEach((technology) => {\n        const codes = Object.keys(map[possibleSynthesizers[0]][technology]);\n        while (outputIndex < sequence.length) {\n            const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));\n            if (matchedCode == null)\n                break;\n            if ( // for mistake pattern 'rAA'\n            outputIndex > 1 &&\n                nucleotides.includes(sequence[outputIndex]) &&\n                firstUniqueCharacters.includes(sequence[outputIndex - 2]))\n                break;\n            if ( // for mistake pattern 'ArA'\n            firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&\n                nucleotides.includes(sequence[outputIndex])) {\n                outputIndex++;\n                break;\n            }\n            outputIndex += matchedCode.length;\n        }\n    });\n    return possibleSynthesizers[0];\n}\nfunction sortByStringLengthInDescendingOrder(array) {\n    return array.sort(function (a, b) { return b.length - a.length; });\n}\nexport function isValidSequence(sequence, format) {\n    const possibleSynthesizers = format == null ?\n        getListOfPossibleSynthesizersByFirstMatchedCode(sequence) :\n        [format];\n    // if (possibleSynthesizers.length > 1) {\n    //   const synthesizer = ui.choiceInput('Choose synthesizer from list: ', possibleSynthesizers[0],\n    //  possibleSynthesizers);\n    //   ui.dialog('Choose Synthesizer')\n    //     .add(ui.panel([synthesizer.root], {style: {fontWeight: 'bold'}}))\n    //     .onOK(() => possibleSynthesizers = [synthesizer.value])\n    //     .onCancel(() => {\n    //       possibleSynthesizers = [possibleSynthesizers[0]];\n    //       grok.shell.warning('Input sequence is expected to be in format ' + possibleSynthesizers[0]);\n    //     })\n    //     .show();\n    // } else if (possibleSynthesizers.length == 0)\n    if (possibleSynthesizers.length == 0)\n        return { indexOfFirstNotValidChar: 0, synthesizer: null, technology: null };\n    let outputIndex = 0;\n    const firstUniqueCharacters = ['r', 'd'];\n    const nucleotides = ['A', 'U', 'T', 'C', 'G'];\n    possibleSynthesizers.forEach((synthesizer) => {\n        const codes = sortByStringLengthInDescendingOrder(getAllCodesOfSynthesizer(synthesizer));\n        while (outputIndex < sequence.length) {\n            const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));\n            if (matchedCode == null)\n                break;\n            if ( // for mistake pattern 'rAA'\n            outputIndex > 1 &&\n                nucleotides.includes(sequence[outputIndex]) &&\n                firstUniqueCharacters.includes(sequence[outputIndex - 2]))\n                break;\n            if ( // for mistake pattern 'ArA'\n            firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&\n                nucleotides.includes(sequence[outputIndex])) {\n                outputIndex++;\n                break;\n            }\n            outputIndex += matchedCode.length;\n        }\n    });\n    const indexOfFirstNotValidChar = (outputIndex == sequence.length) ? -1 : outputIndex;\n    if (indexOfFirstNotValidChar != -1) {\n        return {\n            indexOfFirstNotValidChar: indexOfFirstNotValidChar,\n            synthesizer: possibleSynthesizers,\n            technology: null,\n        };\n    }\n    const possibleTechnologies = getListOfPossibleTechnologiesByFirstMatchedCode(sequence, possibleSynthesizers[0]);\n    // if (possibleTechnologies.length > 1) {\n    //   const technology = ui.choiceInput('Choose technology from list: ', possibleTechnologies[0],\n    // possibleTechnologies);\n    //   ui.dialog('Choose Technology')\n    //     .add(ui.panel([technology.root], {style: {fontWeight: 'bold'}}))\n    //     .onOK(() => possibleTechnologies = [technology.value])\n    //     .onCancel(() => {\n    //       possibleTechnologies = [possibleTechnologies[0]];\n    //       grok.shell.warning('Input sequence is expected to be in format ' + possibleTechnologies[0]);\n    //     })\n    //     .show();\n    // } else if (possibleTechnologies.length == 0)\n    if (possibleTechnologies.length == 0)\n        return { indexOfFirstNotValidChar: 0, synthesizer: [possibleSynthesizers[3]], technology: null };\n    outputIndex = 0;\n    // possibleTechnologies.forEach((technology: string) => {\n    //   const codes = Object.keys(map[possibleSynthesizers[0]][technology]);\n    //   while (outputIndex < sequence.length) {\n    //     const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));\n    //     if (matchedCode == null)\n    //       break;\n    //     if ( // for mistake pattern 'rAA'\n    //       outputIndex > 1 &&\n    //       nucleotides.includes(sequence[outputIndex]) &&\n    //       firstUniqueCharacters.includes(sequence[outputIndex - 2])\n    //     ) break;\n    //     if ( // for mistake pattern 'ArA'\n    //       firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&\n    //       nucleotides.includes(sequence[outputIndex])\n    //     ) {\n    //       outputIndex++;\n    //       break;\n    //     }\n    //     outputIndex += matchedCode.length;\n    //   }\n    // });\n    return {\n        indexOfFirstNotValidChar: indexOfFirstNotValidChar,\n        synthesizer: possibleSynthesizers,\n        technology: [possibleTechnologies[outputIndex]],\n    };\n}\nexport function getAllCodesOfSynthesizer(synthesizer) {\n    let codes = [];\n    for (const technology of Object.keys(map[synthesizer]))\n        codes = codes.concat(Object.keys(map[synthesizer][technology]));\n    return codes.concat(Object.keys(MODIFICATIONS)).concat(delimiter);\n}\nfunction getListOfPossibleSynthesizersByFirstMatchedCode(sequence) {\n    let synthesizers = [];\n    Object.keys(map).forEach((synthesizer) => {\n        let codes = sortByStringLengthInDescendingOrder(getAllCodesOfSynthesizer(synthesizer));\n        if (synthesizer == 'Janssen GCRS Codes')\n            codes = codes.concat(gcrsCodesWithoutSmiles);\n        //TODO: get first non-dropdown code when there are two modifications\n        let start = 0;\n        for (let i = 0; i < sequence.length; i++) {\n            if (sequence[i] == ')' && i != sequence.length - 1) {\n                start = i + 1;\n                break;\n            }\n        }\n        if (gcrsCodesWithoutSmiles.some((s) => s == sequence.slice(start, start + s.length)))\n            synthesizers = ['Janssen GCRS Codes'];\n        if (codes.some((s) => s == sequence.slice(start, start + s.length)))\n            synthesizers.push(synthesizer);\n    });\n    return synthesizers;\n}\nfunction getListOfPossibleTechnologiesByFirstMatchedCode(sequence, synthesizer) {\n    const technologies = [];\n    Object.keys(map[synthesizer]).forEach((technology) => {\n        const codes = Object.keys(map[synthesizer][technology]).concat(Object.keys(MODIFICATIONS));\n        if (codes.some((s) => s == sequence.slice(0, s.length)))\n            technologies.push(technology);\n    });\n    return technologies;\n}\nexport function convertSequence(sequence, output) {\n    if (output.indexOfFirstNotValidChar != -1) {\n        return {\n            // type: '',\n            indexOfFirstNotValidChar: JSON.stringify(output),\n            Error: undefinedInputSequence,\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.RAW_NUCLEOTIDES)) { //&& output.technology!.includes(TECHNOLOGIES.DNA)) {\n        return {\n            type: SYNTHESIZERS.RAW_NUCLEOTIDES,\n            Nucleotides: sequence,\n            BioSpring: asoGapmersNucleotidesToBioSpring(sequence),\n            GCRS: asoGapmersNucleotidesToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.BIOSPRING) && output.technology.includes(TECHNOLOGIES.ASO_GAPMERS)) {\n        return {\n            type: SYNTHESIZERS.BIOSPRING + ' ' + TECHNOLOGIES.ASO_GAPMERS,\n            Nucleotides: asoGapmersBioSpringToNucleotides(sequence),\n            BioSpring: sequence,\n            GCRS: asoGapmersBioSpringToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.GCRS) && output.technology.includes(TECHNOLOGIES.ASO_GAPMERS)) {\n        return {\n            type: SYNTHESIZERS.GCRS + ' ' + TECHNOLOGIES.ASO_GAPMERS,\n            Nucleotides: asoGapmersGcrsToNucleotides(sequence),\n            BioSpring: asoGapmersGcrsToBioSpring(sequence),\n            Mermade12: gcrsToMermade12(sequence),\n            GCRS: sequence,\n            LCMS: gcrsToLcms(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.RAW_NUCLEOTIDES) && output.technology.includes(TECHNOLOGIES.RNA)) {\n        return {\n            type: SYNTHESIZERS.RAW_NUCLEOTIDES + ' ' + TECHNOLOGIES.RNA,\n            Nucleotides: sequence,\n            BioSpring: siRnaNucleotideToBioSpringSenseStrand(sequence),\n            Axolabs: siRnaNucleotideToAxolabsSenseStrand(sequence),\n            GCRS: siRnaNucleotidesToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.BIOSPRING) && output.technology.includes(TECHNOLOGIES.SI_RNA)) {\n        return {\n            type: SYNTHESIZERS.BIOSPRING + ' ' + TECHNOLOGIES.SI_RNA,\n            Nucleotides: siRnaBioSpringToNucleotides(sequence),\n            BioSpring: sequence,\n            Axolabs: siRnaBioSpringToAxolabs(sequence),\n            GCRS: siRnaBioSpringToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.AXOLABS)) {\n        return {\n            type: SYNTHESIZERS.AXOLABS + ' ' + TECHNOLOGIES.SI_RNA,\n            Nucleotides: siRnaAxolabsToNucleotides(sequence),\n            BioSpring: siRnaAxolabsToBioSpring(sequence),\n            Axolabs: sequence,\n            GCRS: siRnaAxolabsToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.GCRS) && output.technology.includes(TECHNOLOGIES.SI_RNA)) {\n        return {\n            type: SYNTHESIZERS.GCRS + ' ' + TECHNOLOGIES.SI_RNA,\n            Nucleotides: siRnaGcrsToNucleotides(sequence),\n            BioSpring: siRnaGcrsToBioSpring(sequence),\n            Axolabs: siRnaGcrsToAxolabs(sequence),\n            MM12: gcrsToMermade12(sequence),\n            GCRS: sequence,\n            LCMS: gcrsToLcms(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.GCRS)) {\n        return {\n            type: SYNTHESIZERS.GCRS,\n            Nucleotides: gcrsToNucleotides(sequence),\n            GCRS: sequence,\n            Mermade12: gcrsToMermade12(sequence),\n            LCMS: gcrsToLcms(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.MERMADE_12)) {\n        return {\n            type: SYNTHESIZERS.MERMADE_12,\n            Nucleotides: noTranslationTableAvailable,\n            GCRS: noTranslationTableAvailable,\n            Mermade12: sequence,\n        };\n    }\n    return {\n        type: undefinedInputSequence,\n        Nucleotides: undefinedInputSequence,\n    };\n}\n","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};","import * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\nimport { autostartOligoSdFileSubscription } from './autostart/registration';\nimport { defineAxolabsPattern } from './axolabs/define-pattern';\nimport { saveSenseAntiSense } from './structures-works/save-sense-antisense';\nimport { mainView } from './main/main-view';\nexport const _package = new DG.Package();\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    const v = grok.shell.newView('Sequence Translator', [\n        ui.tabControl({\n            'MAIN': mainView(),\n            'AXOLABS': defineAxolabsPattern(),\n            'SDF': saveSenseAntiSense(),\n        }),\n    ]);\n    v.box = true;\n}\n//tags: autostart\nautostartOligoSdFileSubscription();\n"],"names":[],"sourceRoot":""}
|