@datagrok/sequence-translator 1.0.2 → 1.0.5

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/dist/package.js CHANGED
@@ -1874,10 +1874,223 @@ NO DATA
1874
1874
 
1875
1875
  /***/ }),
1876
1876
 
1877
- /***/ "./src/axolabsMap.ts":
1878
- /*!***************************!*\
1879
- !*** ./src/axolabsMap.ts ***!
1880
- \***************************/
1877
+ /***/ "./src/autostart/registration.ts":
1878
+ /*!***************************************!*\
1879
+ !*** ./src/autostart/registration.ts ***!
1880
+ \***************************************/
1881
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1882
+
1883
+ "use strict";
1884
+ __webpack_require__.r(__webpack_exports__);
1885
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
1886
+ /* harmony export */ "autostartOligoSdFileSubscription": () => (/* binding */ autostartOligoSdFileSubscription),
1887
+ /* harmony export */ "oligoSdFile": () => (/* binding */ oligoSdFile)
1888
+ /* harmony export */ });
1889
+ /* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! datagrok-api/grok */ "datagrok-api/grok");
1890
+ /* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__);
1891
+ /* harmony import */ var datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! datagrok-api/ui */ "datagrok-api/ui");
1892
+ /* harmony import */ var datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__);
1893
+ /* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! datagrok-api/dg */ "datagrok-api/dg");
1894
+ /* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__);
1895
+ /* harmony import */ var _structures_works_converters__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../structures-works/converters */ "./src/structures-works/converters.ts");
1896
+ /* harmony import */ var _structures_works_map__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../structures-works/map */ "./src/structures-works/map.ts");
1897
+ /* harmony import */ var _structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../structures-works/sequence-codes-tools */ "./src/structures-works/sequence-codes-tools.ts");
1898
+ /* harmony import */ var _structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../structures-works/from-monomers */ "./src/structures-works/from-monomers.ts");
1899
+ /* harmony import */ var _salts__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../salts */ "./src/salts.ts");
1900
+ /* harmony import */ var _users__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../users */ "./src/users.ts");
1901
+ /* harmony import */ var _ICDs__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../ICDs */ "./src/ICDs.ts");
1902
+ /* harmony import */ var _sources__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ../sources */ "./src/sources.ts");
1903
+ /* harmony import */ var _IDPs__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ../IDPs */ "./src/IDPs.ts");
1904
+ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
1905
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
1906
+ return new (P || (P = Promise))(function (resolve, reject) {
1907
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
1908
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
1909
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
1910
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
1911
+ });
1912
+ };
1913
+ var _a;
1914
+
1915
+
1916
+
1917
+
1918
+
1919
+
1920
+
1921
+
1922
+
1923
+
1924
+
1925
+
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
+ function sortByStringLengthInDescendingOrder(array) {
1936
+ return array.sort(function (a, b) { return b.length - a.length; });
1937
+ }
1938
+ function stringify(items) {
1939
+ return '["' + items.join('", "') + '"]';
1940
+ }
1941
+ function molecularWeight(sequence, weightsObj) {
1942
+ const codes = sortByStringLengthInDescendingOrder(Object.keys(weightsObj)).concat(Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.MODIFICATIONS));
1943
+ let weight = 0;
1944
+ let i = 0;
1945
+ while (i < sequence.length) {
1946
+ const matchedCode = codes.find((s) => s == sequence.slice(i, i + s.length));
1947
+ weight += weightsObj[sequence.slice(i, i + matchedCode.length)];
1948
+ i += matchedCode.length;
1949
+ }
1950
+ return weight - 61.97;
1951
+ }
1952
+ function saveTableAsSdFile(table) {
1953
+ return __awaiter(this, void 0, void 0, function* () {
1954
+ if (!table.columns.contains('Compound Name')) {
1955
+ datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.warning('File saved without columns \'' +
1956
+ [_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,
1957
+ _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.SALT_MASS, _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.BATCH_MW].join('\', \''));
1958
+ }
1959
+ const structureColumn = table.getCol(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.SEQUENCE);
1960
+ const typeColumn = table.getCol(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.TYPE);
1961
+ let result = '';
1962
+ for (let i = 0; i < table.rowCount; i++) {
1963
+ const format = (0,_structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_5__.getFormat)(structureColumn.get(i));
1964
+ result += (typeColumn.get(i) == 'SS') ?
1965
+ (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_6__.sequenceToMolV3000)(structureColumn.get(i), false, true, format) + '\n' + `> <Sequence>\nSense Strand\n\n` :
1966
+ (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_6__.sequenceToMolV3000)(structureColumn.get(i), true, true, format) + '\n' + `> <Sequence>\nAnti Sense\n\n`;
1967
+ for (const col of table.columns) {
1968
+ if (col.name != _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.SEQUENCE)
1969
+ result += `> <${col.name}>\n${col.get(i)}\n\n`;
1970
+ }
1971
+ result += '$$$$\n\n';
1972
+ }
1973
+ const element = document.createElement('a');
1974
+ element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(result));
1975
+ element.setAttribute('download', table.name + '.sdf');
1976
+ element.click();
1977
+ });
1978
+ }
1979
+ function autostartOligoSdFileSubscription() {
1980
+ datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.events.onViewAdded.subscribe((v) => {
1981
+ if (v.type == 'TableView') {
1982
+ if (v.dataFrame.columns.contains(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.TYPE))
1983
+ oligoSdFile(v.dataFrame);
1984
+ 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) => /^[fsACGUacgu]{6,}$/.test(s))) {
1987
+ args.args.menu.item('Convert Axolabs to GCRS', () => {
1988
+ args.args.context.table.columns.addNewString(seqCol.name + ' to GCRS').init((i) => {
1989
+ return (0,_structures_works_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaAxolabsToGcrs)(seqCol.get(i));
1990
+ });
1991
+ });
1992
+ }
1993
+ else if (datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) => /^[fmpsACGU]{6,}$/.test(s)) ||
1994
+ datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) => /^(?=.*moe)(?=.*5mC)(?=.*ps){6,}/.test(s))) {
1995
+ args.args.menu.item('Convert GCRS to raw', () => {
1996
+ args.args.context.table.columns.addNewString(seqCol.name + ' to raw').init((i) => {
1997
+ return (0,_structures_works_converters__WEBPACK_IMPORTED_MODULE_3__.gcrsToNucleotides)(seqCol.get(i));
1998
+ });
1999
+ });
2000
+ args.args.menu.item('Convert GCRS to MM12', () => {
2001
+ args.args.context.table.columns.addNewString(seqCol.name + ' to MM12').init((i) => {
2002
+ return (0,_structures_works_converters__WEBPACK_IMPORTED_MODULE_3__.gcrsToMermade12)(seqCol.get(i));
2003
+ });
2004
+ });
2005
+ }
2006
+ else if (datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) => /^[*56789ATGC]{6,}$/.test(s))) {
2007
+ args.args.menu.item('Convert Biospring to GCRS', () => {
2008
+ const seqCol = args.args.context.table.currentCol;
2009
+ args.args.context.table.columns.addNewString(seqCol.name + ' to GCRS').init((i) => {
2010
+ return (0,_structures_works_converters__WEBPACK_IMPORTED_MODULE_3__.asoGapmersBioSpringToGcrs)(seqCol.get(i));
2011
+ });
2012
+ });
2013
+ }
2014
+ else if (datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Detector.sampleCategories(seqCol, (s) => /^[*1-8]{6,}$/.test(s))) {
2015
+ args.args.menu.item('Convert Biospring to GCRS', () => {
2016
+ args.args.context.table.columns.addNewString(seqCol.name + ' to GCRS').init((i) => {
2017
+ return (0,_structures_works_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaAxolabsToGcrs)(seqCol.get(i));
2018
+ });
2019
+ });
2020
+ }
2021
+ });
2022
+ }
2023
+ });
2024
+ }
2025
+ function oligoSdFile(table) {
2026
+ const saltsDf = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromCsv(_salts__WEBPACK_IMPORTED_MODULE_7__.SALTS_CSV);
2027
+ const usersDf = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromCsv(_users__WEBPACK_IMPORTED_MODULE_8__.USERS_CSV);
2028
+ const sourcesDf = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromCsv(_sources__WEBPACK_IMPORTED_MODULE_10__.SOURCES);
2029
+ const icdsDf = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromCsv(_ICDs__WEBPACK_IMPORTED_MODULE_9__.ICDS);
2030
+ const idpsDf = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromCsv(_IDPs__WEBPACK_IMPORTED_MODULE_11__.IDPS);
2031
+ function addColumns(t, saltsDf) {
2032
+ if (t.columns.contains(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.COMPOUND_NAME))
2033
+ return datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.error('Columns already exist');
2034
+ const sequence = t.getCol(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.SEQUENCE);
2035
+ const salt = t.getCol(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.SALT);
2036
+ const equivalents = t.getCol(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.EQUIVALENTS);
2037
+ t.columns.addNewString(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.COMPOUND_NAME).init((i) => sequence.get(i));
2038
+ t.columns.addNewString(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.COMPOUND_COMMENTS).init((i) => (i > 0 && i % 2 == 0) ?
2039
+ sequence.getString(i) + '; duplex of SS: ' + sequence.getString(i - 2) + ' and AS: ' + sequence.getString(i - 1) :
2040
+ sequence.getString(i));
2041
+ const molWeightCol = saltsDf.getCol('MOLWEIGHT');
2042
+ const saltNamesList = saltsDf.getCol('DISPLAY').toList();
2043
+ t.columns.addNewFloat(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.CPD_MW)
2044
+ .init((i) => molecularWeight(sequence.get(i), weightsObj));
2045
+ t.columns.addNewFloat(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.SALT_MASS).init((i) => {
2046
+ const saltRowIndex = saltNamesList.indexOf(salt.get(i));
2047
+ const mw = molWeightCol.get(saltRowIndex);
2048
+ return mw * equivalents.get(i);
2049
+ });
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
+ }
2054
+ let newDf;
2055
+ let addColumnsPressed = false;
2056
+ const d = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([
2057
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.icons.edit(() => {
2058
+ d.innerHTML = '';
2059
+ 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
+ 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
+ datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.tableView(table.name).grid.columns.setOrder(Object.values(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES));
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,
2065
+ _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
+ const view = datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.getTableView(table.name);
2067
+ 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"]');
2068
+ view.dataFrame.getCol(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.OWNER).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, stringify(usersDf.columns.byIndex(0).toList()));
2069
+ view.dataFrame.getCol(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.SALT).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, stringify(saltsDf.columns.byIndex(0).toList()));
2070
+ view.dataFrame.getCol(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.SOURCE).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, stringify(sourcesDf.columns.byIndex(0).toList()));
2071
+ view.dataFrame.getCol(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.ICD).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, stringify(icdsDf.columns.byIndex(0).toList()));
2072
+ view.dataFrame.getCol(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.IDP).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, stringify(idpsDf.columns.byIndex(0).toList()));
2073
+ datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.events.onContextMenu.subscribe((args) => {
2074
+ if ([_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.TYPE, _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.OWNER, _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.SALT, _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.SOURCE, _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.ICD, _structures_works_map__WEBPACK_IMPORTED_MODULE_4__.COL_NAMES.IDP]
2075
+ .includes(args.args.context.table.currentCol.name)) {
2076
+ args.args.menu.item('Fill Column With Value', () => {
2077
+ const v = args.args.context.table.currentCell.value;
2078
+ args.args.context.table.currentCell.column.init(v);
2079
+ });
2080
+ }
2081
+ });
2082
+ }),
2083
+ ]);
2084
+ datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.v.setRibbonPanels([[d]]);
2085
+ }
2086
+
2087
+
2088
+ /***/ }),
2089
+
2090
+ /***/ "./src/axolabs/constants.ts":
2091
+ /*!**********************************!*\
2092
+ !*** ./src/axolabs/constants.ts ***!
2093
+ \**********************************/
1881
2094
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1882
2095
 
1883
2096
  "use strict";
@@ -1979,7 +2192,7 @@ const axolabsMap = {
1979
2192
  color: invAbasicColor,
1980
2193
  },
1981
2194
  '2\'-OMe-U(o)': {
1982
- fullName: 'Nucleotide Uridine with 2O-Methyl protection (overhang)',
2195
+ fullName: 'Nucleotide Uridine with 2\'O-Methyl protection (overhang)',
1983
2196
  symbols: ['mU', 'mU', 'mU', 'mU'],
1984
2197
  color: 'rgb(65,233,80)',
1985
2198
  },
@@ -1988,10 +2201,10 @@ const axolabsMap = {
1988
2201
 
1989
2202
  /***/ }),
1990
2203
 
1991
- /***/ "./src/defineAxolabsPattern.ts":
1992
- /*!*************************************!*\
1993
- !*** ./src/defineAxolabsPattern.ts ***!
1994
- \*************************************/
2204
+ /***/ "./src/axolabs/define-pattern.ts":
2205
+ /*!***************************************!*\
2206
+ !*** ./src/axolabs/define-pattern.ts ***!
2207
+ \***************************************/
1995
2208
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1996
2209
 
1997
2210
  "use strict";
@@ -2009,8 +2222,8 @@ __webpack_require__.r(__webpack_exports__);
2009
2222
  /* harmony import */ var save_svg_as_png__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(save_svg_as_png__WEBPACK_IMPORTED_MODULE_3__);
2010
2223
  /* harmony import */ var cash_dom__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! cash-dom */ "./node_modules/cash-dom/dist/cash.js");
2011
2224
  /* harmony import */ var cash_dom__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(cash_dom__WEBPACK_IMPORTED_MODULE_4__);
2012
- /* harmony import */ var _drawAxolabsPattern__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./drawAxolabsPattern */ "./src/drawAxolabsPattern.ts");
2013
- /* harmony import */ var _axolabsMap__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./axolabsMap */ "./src/axolabsMap.ts");
2225
+ /* harmony import */ var _draw_svg__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./draw-svg */ "./src/axolabs/draw-svg.ts");
2226
+ /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./constants */ "./src/axolabs/constants.ts");
2014
2227
  var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
2015
2228
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
2016
2229
  return new (P || (P = Promise))(function (resolve, reject) {
@@ -2020,7 +2233,6 @@ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _argume
2020
2233
  step((generator = generator.apply(thisArg, _arguments || [])).next());
2021
2234
  });
2022
2235
  };
2023
- /* Do not change these import lines. Datagrok will import API library in exactly the same manner */
2024
2236
 
2025
2237
 
2026
2238
 
@@ -2029,7 +2241,7 @@ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _argume
2029
2241
 
2030
2242
 
2031
2243
 
2032
- const baseChoices = Object.keys(_axolabsMap__WEBPACK_IMPORTED_MODULE_6__.axolabsMap);
2244
+ const baseChoices = Object.keys(_constants__WEBPACK_IMPORTED_MODULE_6__.axolabsMap);
2033
2245
  const defaultBase = baseChoices[0];
2034
2246
  const defaultPto = true;
2035
2247
  const defaultSequenceLength = 23;
@@ -2037,7 +2249,7 @@ const maximalValidSequenceLength = 35;
2037
2249
  const userStorageKey = 'SequenceTranslator';
2038
2250
  const exampleMinWidth = '400px';
2039
2251
  function generateExample(sequenceLength, sequenceBasis) {
2040
- const uniqueSymbols = _axolabsMap__WEBPACK_IMPORTED_MODULE_6__.axolabsMap[sequenceBasis].symbols.join('');
2252
+ const uniqueSymbols = _constants__WEBPACK_IMPORTED_MODULE_6__.axolabsMap[sequenceBasis].symbols.join('');
2041
2253
  return uniqueSymbols.repeat(Math.floor(sequenceLength / 4)) + uniqueSymbols.slice(0, sequenceLength % 4);
2042
2254
  }
2043
2255
  function findDuplicates(data) {
@@ -2072,12 +2284,18 @@ function getUserName(patternName) {
2072
2284
  return (first == -1) ? ['', ''] : patternName.slice(first + 9, patternName.length - 1).split(' ').slice(1);
2073
2285
  }
2074
2286
  function translateSequence(sequence, bases, ptoLinkages, startModification, endModification, firstPtoExist) {
2075
- let counter = -1;
2287
+ let i = -1;
2076
2288
  let mainSequence = sequence.replace(/[AUGC]/g, function (x) {
2077
- counter++;
2078
- const indexOfSymbol = _axolabsMap__WEBPACK_IMPORTED_MODULE_6__.axolabsMap.RNA.symbols.indexOf(x);
2079
- const symbol = _axolabsMap__WEBPACK_IMPORTED_MODULE_6__.axolabsMap[bases[counter].value]['symbols'][indexOfSymbol];
2080
- return (ptoLinkages[counter].value) ? symbol + 's' : symbol;
2289
+ i++;
2290
+ const indexOfSymbol = _constants__WEBPACK_IMPORTED_MODULE_6__.axolabsMap.RNA.symbols.indexOf(x);
2291
+ let symbol = _constants__WEBPACK_IMPORTED_MODULE_6__.axolabsMap[bases[i].value]['symbols'][indexOfSymbol];
2292
+ if (bases[i].value.slice(-3) == '(o)') {
2293
+ if (i < sequence.length / 2 && bases[i + 1].value.slice(-3) != '(o)')
2294
+ symbol = symbol + x + 'f';
2295
+ else if (i > sequence.length / 2 && bases[i - 1].value.slice(-3) != '(o)')
2296
+ symbol = x + 'f' + symbol;
2297
+ }
2298
+ return (ptoLinkages[i].value) ? symbol + 's' : symbol;
2081
2299
  });
2082
2300
  if (mainSequence.slice(0, 5).split('mU').length == 3)
2083
2301
  mainSequence = '(uu)' + mainSequence.slice(4);
@@ -2091,7 +2309,9 @@ function addColumnWithIds(tableName, columnName, patternName) {
2091
2309
  if (columns.contains(nameOfNewColumn))
2092
2310
  columns.remove(nameOfNewColumn);
2093
2311
  const columnWithIds = columns.byName(columnName);
2094
- return columns.addNewString(nameOfNewColumn).init((i) => columnWithIds.get(i) + '_' + patternName);
2312
+ return columns.addNewString(nameOfNewColumn).init((i) => {
2313
+ return (columnWithIds.getString(i) == '') ? '' : columnWithIds.get(i) + '_' + patternName;
2314
+ });
2095
2315
  }
2096
2316
  function addColumnWithTranslatedSequences(tableName, columnName, bases, ptoLinkages, startModification, endModification, firstPtoExist) {
2097
2317
  const nameOfNewColumn = 'Axolabs ' + columnName;
@@ -2100,7 +2320,9 @@ function addColumnWithTranslatedSequences(tableName, columnName, bases, ptoLinka
2100
2320
  columns.remove(nameOfNewColumn);
2101
2321
  const columnWithInputSequences = columns.byName(columnName);
2102
2322
  return columns.addNewString(nameOfNewColumn).init((i) => {
2103
- return translateSequence(columnWithInputSequences.getString(i), bases, ptoLinkages, startModification, endModification, firstPtoExist);
2323
+ return columnWithInputSequences.getString(i) == '' ?
2324
+ '' :
2325
+ translateSequence(columnWithInputSequences.getString(i), bases, ptoLinkages, startModification, endModification, firstPtoExist);
2104
2326
  });
2105
2327
  }
2106
2328
  function defineAxolabsPattern() {
@@ -2220,8 +2442,9 @@ function defineAxolabsPattern() {
2220
2442
  updateSvgScheme();
2221
2443
  }
2222
2444
  function updateInputExamples() {
2223
- ssInputExample.value = generateExample(ssLength.value, sequenceBase.value);
2224
- if (createAsStrand.value)
2445
+ if (inputSsColumn.value == '')
2446
+ ssInputExample.value = generateExample(ssLength.value, sequenceBase.value);
2447
+ if (createAsStrand.value && inputAsColumn.value == '')
2225
2448
  asInputExample.value = generateExample(asLength.value, sequenceBase.value);
2226
2449
  }
2227
2450
  function updateOutputExamples() {
@@ -2233,7 +2456,7 @@ function defineAxolabsPattern() {
2233
2456
  function updateSvgScheme() {
2234
2457
  svgDiv.innerHTML = '';
2235
2458
  svgDiv.append(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.span([
2236
- (0,_drawAxolabsPattern__WEBPACK_IMPORTED_MODULE_5__.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),
2459
+ (0,_draw_svg__WEBPACK_IMPORTED_MODULE_5__.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),
2237
2460
  ]));
2238
2461
  }
2239
2462
  function detectDefaultBasis(array) {
@@ -2287,10 +2510,10 @@ function defineAxolabsPattern() {
2287
2510
  });
2288
2511
  }
2289
2512
  function checkWhetherAllValuesInColumnHaveTheSameLength(colName) {
2290
- const col = tables.value.columns.byName(colName);
2513
+ const col = tables.value.getCol(colName);
2291
2514
  let allLengthsAreTheSame = true;
2292
2515
  for (let i = 1; i < col.length; i++) {
2293
- if (col.get(i - 1).length != col.get(i).length) {
2516
+ if (col.get(i - 1).length != col.get(i).length && col.get(i).length != 0) {
2294
2517
  allLengthsAreTheSame = false;
2295
2518
  break;
2296
2519
  }
@@ -2320,10 +2543,11 @@ function defineAxolabsPattern() {
2320
2543
  }
2321
2544
  function postPatternToUserStorage() {
2322
2545
  return __awaiter(this, void 0, void 0, function* () {
2323
- const author = yield getCurrentUserName();
2324
- if (!saveAs.stringValue.includes('(created by '))
2325
- saveAs.value = saveAs.stringValue + author;
2326
- return datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.dapi.userDataStorage.postValue(userStorageKey, saveAs.stringValue, JSON.stringify({
2546
+ const currUserName = yield getCurrentUserName();
2547
+ saveAs.value = (saveAs.stringValue.includes('(created by ')) ?
2548
+ getShortName(saveAs.value) + currUserName :
2549
+ saveAs.stringValue + currUserName;
2550
+ return datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.dapi.userDataStorage.postValue(userStorageKey, saveAs.value, JSON.stringify({
2327
2551
  'ssBases': ssBases.slice(0, ssLength.value).map((e) => e.value),
2328
2552
  'asBases': asBases.slice(0, asLength.value).map((e) => e.value),
2329
2553
  'ssPtoLinkages': [firstSsPto.value].concat(ssPtoLinkages.slice(0, ssLength.value).map((e) => e.value)),
@@ -2341,11 +2565,12 @@ function defineAxolabsPattern() {
2341
2565
  datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.dapi.userDataStorage.get(userStorageKey, false).then((entities) => __awaiter(this, void 0, void 0, function* () {
2342
2566
  const lstMy = [];
2343
2567
  const lstOthers = [];
2568
+ // TODO: display short name, but use long for querying userdataStorage
2344
2569
  for (const ent of Object.keys(entities)) {
2345
2570
  if (yield isCurrentUserCreatedThisPattern(ent))
2346
2571
  lstOthers.push(ent);
2347
2572
  else
2348
- lstMy.push(getShortName(ent));
2573
+ lstMy.push(ent); //getShortName(ent));
2349
2574
  }
2350
2575
  let loadPattern = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('Load Pattern', '', lstMy, (v) => parsePatternAndUpdateUi(v));
2351
2576
  const myOrOthersPatternList = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('', 'Mine', ['Mine', 'Others'], (v) => {
@@ -2451,25 +2676,23 @@ function defineAxolabsPattern() {
2451
2676
  const asLengthDiv = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([asLength.root]);
2452
2677
  function validateSsColumn(colName) {
2453
2678
  const allLengthsAreTheSame = checkWhetherAllValuesInColumnHaveTheSameLength(colName);
2454
- const firstSequence = tables.value.columns.byName(colName).get(0);
2679
+ const firstSequence = tables.value.getCol(colName).get(0);
2455
2680
  if (allLengthsAreTheSame && firstSequence.length != ssLength.value)
2456
- ssLength.value = tables.value.columns.byName(colName).get(0).length;
2681
+ ssLength.value = tables.value.getCol(colName).get(0).length;
2457
2682
  ssInputExample.value = firstSequence;
2458
2683
  }
2459
2684
  function validateAsColumn(colName) {
2460
2685
  const allLengthsAreTheSame = checkWhetherAllValuesInColumnHaveTheSameLength(colName);
2461
- const firstSequence = tables.value.columns.byName(colName).get(0);
2686
+ const firstSequence = tables.value.getCol(colName).get(0);
2462
2687
  if (allLengthsAreTheSame && firstSequence.length != asLength.value)
2463
- asLength.value = tables.value.columns.byName(colName).get(0).length;
2464
- asLengthDiv.innerHTML = '';
2465
- asLengthDiv.append(asLength.root);
2688
+ asLength.value = tables.value.getCol(colName).get(0).length;
2466
2689
  asInputExample.value = firstSequence;
2467
2690
  }
2468
2691
  function validateIdsColumn(colName) {
2469
- const col = tables.value.columns.byName(colName);
2692
+ const col = tables.value.getCol(colName);
2470
2693
  if (col.type != datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TYPE.INT)
2471
2694
  datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.error('Column should contain integers only');
2472
- else if (col.categories.length < col.length) {
2695
+ else if (col.categories.filter((e) => e != '').length < col.toList().filter((e) => e != '').length) {
2473
2696
  const duplicates = findDuplicates(col.getRawData());
2474
2697
  datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.dialog('Non-unique IDs')
2475
2698
  .add(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText('Press \'OK\' to select rows with non-unique values'))
@@ -2483,21 +2706,42 @@ function defineAxolabsPattern() {
2483
2706
  }
2484
2707
  }
2485
2708
  const tables = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.tableInput('Tables', datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.tables[0], datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.tables, (t) => {
2486
- const inputSsColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('SS Column', '', t.columns.names(), (colName) => validateSsColumn(colName));
2709
+ const inputSsColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('SS Column', '', t.columns.names(), (colName) => {
2710
+ validateSsColumn(colName);
2711
+ ssVar = colName;
2712
+ });
2487
2713
  inputSsColumnDiv.innerHTML = '';
2488
2714
  inputSsColumnDiv.append(inputSsColumn.root);
2489
- const inputAsColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('AS Column', '', t.columns.names(), (colName) => validateAsColumn(colName));
2715
+ const inputAsColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('AS Column', '', t.columns.names(), (colName) => {
2716
+ validateAsColumn(colName);
2717
+ asVar = colName;
2718
+ });
2490
2719
  inputAsColumnDiv.innerHTML = '';
2491
2720
  inputAsColumnDiv.append(inputAsColumn.root);
2492
- const inputIdColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('ID Column', '', t.columns.names(), (colName) => validateIdsColumn(colName));
2721
+ const inputIdColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('ID Column', '', t.columns.names(), (colName) => {
2722
+ validateIdsColumn(colName);
2723
+ idVar = colName;
2724
+ });
2493
2725
  inputIdColumnDiv.innerHTML = '';
2494
2726
  inputIdColumnDiv.append(inputIdColumn.root);
2495
2727
  });
2496
- const inputSsColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('SS Column', '', []);
2728
+ let ssVar = '';
2729
+ const inputSsColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('SS Column', '', [], (colName) => {
2730
+ validateSsColumn(colName);
2731
+ ssVar = colName;
2732
+ });
2497
2733
  inputSsColumnDiv.append(inputSsColumn.root);
2498
- const inputAsColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('AS Column', '', []);
2734
+ let asVar = '';
2735
+ const inputAsColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('AS Column', '', [], (colName) => {
2736
+ validateAsColumn(colName);
2737
+ asVar = colName;
2738
+ });
2499
2739
  inputAsColumnDiv.append(inputAsColumn.root);
2500
- const inputIdColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('ID Column', '', []);
2740
+ let idVar = '';
2741
+ const inputIdColumn = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('ID Column', '', [], (colName) => {
2742
+ validateIdsColumn(colName);
2743
+ idVar = colName;
2744
+ });
2501
2745
  inputIdColumnDiv.append(inputIdColumn.root);
2502
2746
  updatePatternsList();
2503
2747
  const sequenceBase = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('Sequence Basis', defaultBase, baseChoices, (v) => {
@@ -2562,7 +2806,7 @@ function defineAxolabsPattern() {
2562
2806
  }
2563
2807
  });
2564
2808
  const convertSequenceButton = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.button('Convert Sequences', () => {
2565
- if (inputSsColumn.value == null || (createAsStrand.value && inputAsColumn.value == null))
2809
+ if (ssVar == '' || (createAsStrand.value && asVar == ''))
2566
2810
  datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.info('Please select table and columns on which to apply pattern');
2567
2811
  else if (ssLength.value != ssInputExample.value.length || asLength.value != asInputExample.value.length) {
2568
2812
  const dialog = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.dialog('Length Mismatch');
@@ -2570,27 +2814,25 @@ function defineAxolabsPattern() {
2570
2814
  dialog
2571
2815
  .add(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText('Length of sequences in columns doesn\'t match entered length. Update length value?'))
2572
2816
  .addButton('YES', () => {
2573
- ssLength.value = tables.value.columns.byName(inputSsColumn.value).getString(0).length;
2574
- asLength.value = tables.value.columns.byName(inputAsColumn.value).getString(0).length;
2817
+ ssLength.value = tables.value.getCol(inputSsColumn.value).getString(0).length;
2818
+ asLength.value = tables.value.getCol(inputAsColumn.value).getString(0).length;
2575
2819
  dialog.close();
2576
2820
  })
2577
2821
  .show();
2578
2822
  }
2579
2823
  else {
2580
- if (inputIdColumn.value != null)
2581
- addColumnWithIds(tables.value.name, inputIdColumn.value, getShortName(saveAs.value));
2582
- addColumnWithTranslatedSequences(tables.value.name, inputSsColumn.value, ssBases, ssPtoLinkages, ssFiveModification, ssThreeModification, firstSsPto.value);
2824
+ if (idVar != '')
2825
+ addColumnWithIds(tables.value.name, idVar, getShortName(saveAs.value));
2826
+ addColumnWithTranslatedSequences(tables.value.name, ssVar, ssBases, ssPtoLinkages, ssFiveModification, ssThreeModification, firstSsPto.value);
2583
2827
  if (createAsStrand.value) {
2584
- addColumnWithTranslatedSequences(tables.value.name, inputAsColumn.value, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstAsPto.value);
2828
+ addColumnWithTranslatedSequences(tables.value.name, asVar, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstAsPto.value);
2585
2829
  }
2586
2830
  datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.v = datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.getTableView(tables.value.name);
2587
2831
  datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.info(((createAsStrand.value) ? 'Columns were' : 'Column was') +
2588
2832
  ' added to table \'' + tables.value.name + '\'');
2589
2833
  }
2590
2834
  });
2591
- const ssInputExample = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.textInput('Sense Strand', generateExample(ssLength.value, sequenceBase.value), () => {
2592
- ssOutputExample.value = translateSequence(ssInputExample.value, ssBases, ssPtoLinkages, ssFiveModification, ssThreeModification, firstSsPto.value);
2593
- });
2835
+ const ssInputExample = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.textInput('Sense Strand', generateExample(ssLength.value, sequenceBase.value));
2594
2836
  const ssOutputExample = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.textInput(' ', translateSequence(ssInputExample.value, ssBases, ssPtoLinkages, ssThreeModification, ssFiveModification, firstSsPto.value));
2595
2837
  ssInputExample.input.style.resize = 'none';
2596
2838
  ssInputExample.input.style.minWidth = exampleMinWidth;
@@ -2603,9 +2845,7 @@ function defineAxolabsPattern() {
2603
2845
  navigator.clipboard.writeText(ssOutputExample.value).then(() => datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.info('Sequence was copied to clipboard'));
2604
2846
  }),
2605
2847
  ], 'ui-input-options'));
2606
- const asInputExample = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.textInput('Antisense Strand', generateExample(asLength.value, sequenceBase.value), () => {
2607
- asOutputExample.value = translateSequence(asInputExample.value, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstSsPto.value);
2608
- });
2848
+ const asInputExample = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.textInput('Antisense Strand', generateExample(asLength.value, sequenceBase.value));
2609
2849
  const asOutputExample = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.textInput(' ', translateSequence(asInputExample.value, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstSsPto.value));
2610
2850
  asInputExample.input.style.resize = 'none';
2611
2851
  asInputExample.input.style.minWidth = exampleMinWidth;
@@ -2641,11 +2881,12 @@ function defineAxolabsPattern() {
2641
2881
  convertSequenceButton,
2642
2882
  ]),
2643
2883
  ], 'ui-form');
2884
+ const downloadButton = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.button('Download', () => save_svg_as_png__WEBPACK_IMPORTED_MODULE_3__.saveSvgAsPng(document.getElementById('mySvg'), saveAs.value, { backgroundColor: 'white' }));
2644
2885
  const mainSection = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.panel([
2645
2886
  datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.block([
2646
2887
  svgDiv,
2647
2888
  ], { style: { overflowX: 'scroll' } }),
2648
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.button('Download', () => save_svg_as_png__WEBPACK_IMPORTED_MODULE_3__.saveSvgAsPng(document.getElementById('mySvg'), saveAs.value)),
2889
+ downloadButton,
2649
2890
  isEnumerateModificationsDiv,
2650
2891
  datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([
2651
2892
  datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([
@@ -2727,10 +2968,10 @@ function defineAxolabsPattern() {
2727
2968
 
2728
2969
  /***/ }),
2729
2970
 
2730
- /***/ "./src/drawAxolabsPattern.ts":
2731
- /*!***********************************!*\
2732
- !*** ./src/drawAxolabsPattern.ts ***!
2733
- \***********************************/
2971
+ /***/ "./src/axolabs/draw-svg.ts":
2972
+ /*!*********************************!*\
2973
+ !*** ./src/axolabs/draw-svg.ts ***!
2974
+ \*********************************/
2734
2975
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2735
2976
 
2736
2977
  "use strict";
@@ -2738,7 +2979,7 @@ __webpack_require__.r(__webpack_exports__);
2738
2979
  /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2739
2980
  /* harmony export */ "drawAxolabsPattern": () => (/* binding */ drawAxolabsPattern)
2740
2981
  /* harmony export */ });
2741
- /* harmony import */ var _axolabsMap__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./axolabsMap */ "./src/axolabsMap.ts");
2982
+ /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./src/axolabs/constants.ts");
2742
2983
 
2743
2984
  // https://uxdesign.cc/star-rating-make-svg-great-again-d4ce4731347e
2744
2985
  function getPointsToDrawStar(centerX, centerY) {
@@ -2780,7 +3021,7 @@ function getFontColorVisibleOnBackground(rgbString) {
2780
3021
  return (rgbIntList[0] * 0.299 + rgbIntList[1] * 0.587 + rgbIntList[2] * 0.114) > 186 ? '#33333' : '#ffffff';
2781
3022
  }
2782
3023
  function getBaseColor(base) {
2783
- return _axolabsMap__WEBPACK_IMPORTED_MODULE_0__.axolabsMap[base]['color'];
3024
+ return _constants__WEBPACK_IMPORTED_MODULE_0__.axolabsMap[base]['color'];
2784
3025
  }
2785
3026
  function drawAxolabsPattern(patternName, asExists, ssBases, asBases, ssPtoStatuses, asPtoStatuses, ssThreeModification, ssFiveModification, asThreeModification, asFiveModification, comment, enumerateModifications) {
2786
3027
  function getEquidistantXForLegend(index) {
@@ -2889,7 +3130,7 @@ function drawAxolabsPattern(patternName, asExists, ssBases, asBases, ssPtoStatus
2889
3130
  if (ssBases[i].slice(-3) != '(o)')
2890
3131
  nucleotideCounter--;
2891
3132
  image.append(svg.circle(getXOfBaseCircles(i, ssRightOverhangs), yOfSsCircles, baseRadius, getBaseColor(ssBases[i])), svg.text(getTextInsideCircle(ssBases, i, nucleotideCounter, numberOfSsNucleotides, enumerateModifications), getXOfBaseCircles(i, ssRightOverhangs) +
2892
- getShiftToAlignNumberInsideCircle(ssBases, ssBases.length - i, numberOfSsNucleotides - nucleotideCounter), yOfSsTexts, baseFontSize, getFontColorVisibleOnBackground(_axolabsMap__WEBPACK_IMPORTED_MODULE_0__.axolabsMap[ssBases[i]]['color'])), ssPtoStatuses[i] ?
3133
+ getShiftToAlignNumberInsideCircle(ssBases, ssBases.length - i, numberOfSsNucleotides - nucleotideCounter), yOfSsTexts, baseFontSize, getFontColorVisibleOnBackground(_constants__WEBPACK_IMPORTED_MODULE_0__.axolabsMap[ssBases[i]]['color'])), ssPtoStatuses[i] ?
2893
3134
  svg.star(getXOfBaseCircles(i, ssRightOverhangs) + baseRadius, yOfSsTexts + psLinkageRadius, psLinkageColor) :
2894
3135
  '');
2895
3136
  }
@@ -2907,7 +3148,7 @@ function drawAxolabsPattern(patternName, asExists, ssBases, asBases, ssPtoStatus
2907
3148
  if (asBases[i].slice(-3) != '(o)')
2908
3149
  nucleotideCounter--;
2909
3150
  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) +
2910
- getShiftToAlignNumberInsideCircle(asBases, i, nucleotideCounter + 1), yOfAsTexts, baseFontSize, getFontColorVisibleOnBackground(_axolabsMap__WEBPACK_IMPORTED_MODULE_0__.axolabsMap[asBases[i]]['color'])), asPtoStatuses[i] ? svg.star(getXOfBaseCircles(i, asRightOverhangs) +
3151
+ getShiftToAlignNumberInsideCircle(asBases, i, nucleotideCounter + 1), yOfAsTexts, baseFontSize, getFontColorVisibleOnBackground(_constants__WEBPACK_IMPORTED_MODULE_0__.axolabsMap[asBases[i]]['color'])), asPtoStatuses[i] ? svg.star(getXOfBaseCircles(i, asRightOverhangs) +
2911
3152
  baseRadius, yOfAsTexts + psLinkageRadius, psLinkageColor) : '');
2912
3153
  }
2913
3154
  image.append(asPtoStatuses[asBases.length] ?
@@ -2927,128 +3168,346 @@ function drawAxolabsPattern(patternName, asExists, ssBases, asBases, ssPtoStatus
2927
3168
 
2928
3169
  /***/ }),
2929
3170
 
2930
- /***/ "./src/salts.ts":
2931
- /*!**********************!*\
2932
- !*** ./src/salts.ts ***!
2933
- \**********************/
3171
+ /***/ "./src/main/main-view.ts":
3172
+ /*!*******************************!*\
3173
+ !*** ./src/main/main-view.ts ***!
3174
+ \*******************************/
2934
3175
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2935
3176
 
2936
3177
  "use strict";
2937
3178
  __webpack_require__.r(__webpack_exports__);
2938
3179
  /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2939
- /* harmony export */ "SALTS_CSV": () => (/* binding */ SALTS_CSV)
3180
+ /* harmony export */ "mainView": () => (/* binding */ mainView)
2940
3181
  /* harmony export */ });
2941
- const SALTS_CSV = `DISPLAY,MOLWEIGHT
2942
- no Data Added,100`;
2943
-
2944
-
2945
- /***/ }),
2946
-
2947
- /***/ "./src/sources.ts":
2948
- /*!************************!*\
2949
- !*** ./src/sources.ts ***!
2950
- \************************/
2951
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3182
+ /* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! datagrok-api/grok */ "datagrok-api/grok");
3183
+ /* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__);
3184
+ /* harmony import */ var datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! datagrok-api/ui */ "datagrok-api/ui");
3185
+ /* harmony import */ var datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__);
3186
+ /* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! datagrok-api/dg */ "datagrok-api/dg");
3187
+ /* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__);
3188
+ /* harmony import */ var _structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../structures-works/sequence-codes-tools */ "./src/structures-works/sequence-codes-tools.ts");
3189
+ /* harmony import */ var _structures_works_map__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../structures-works/map */ "./src/structures-works/map.ts");
3190
+ /* harmony import */ var _structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../structures-works/from-monomers */ "./src/structures-works/from-monomers.ts");
3191
+ /* harmony import */ var cash_dom__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! cash-dom */ "./node_modules/cash-dom/dist/cash.js");
3192
+ /* harmony import */ var cash_dom__WEBPACK_IMPORTED_MODULE_6___default = /*#__PURE__*/__webpack_require__.n(cash_dom__WEBPACK_IMPORTED_MODULE_6__);
2952
3193
 
2953
- "use strict";
2954
- __webpack_require__.r(__webpack_exports__);
2955
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2956
- /* harmony export */ "SOURCES": () => (/* binding */ SOURCES)
2957
- /* harmony export */ });
2958
- const SOURCES = `DISPLAY
2959
- NO DATA
2960
- `;
2961
3194
 
2962
3195
 
2963
- /***/ }),
2964
3196
 
2965
- /***/ "./src/structures-works/converters.ts":
2966
- /*!********************************************!*\
2967
- !*** ./src/structures-works/converters.ts ***!
2968
- \********************************************/
2969
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2970
3197
 
2971
- "use strict";
2972
- __webpack_require__.r(__webpack_exports__);
2973
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2974
- /* harmony export */ "gcrsToLcms": () => (/* binding */ gcrsToLcms),
2975
- /* harmony export */ "asoGapmersNucleotidesToBioSpring": () => (/* binding */ asoGapmersNucleotidesToBioSpring),
2976
- /* harmony export */ "asoGapmersNucleotidesToGcrs": () => (/* binding */ asoGapmersNucleotidesToGcrs),
2977
- /* harmony export */ "asoGapmersBioSpringToNucleotides": () => (/* binding */ asoGapmersBioSpringToNucleotides),
2978
- /* harmony export */ "asoGapmersBioSpringToGcrs": () => (/* binding */ asoGapmersBioSpringToGcrs),
2979
- /* harmony export */ "asoGapmersGcrsToBioSpring": () => (/* binding */ asoGapmersGcrsToBioSpring),
2980
- /* harmony export */ "asoGapmersGcrsToNucleotides": () => (/* binding */ asoGapmersGcrsToNucleotides),
2981
- /* harmony export */ "siRnaBioSpringToNucleotides": () => (/* binding */ siRnaBioSpringToNucleotides),
2982
- /* harmony export */ "siRnaBioSpringToAxolabs": () => (/* binding */ siRnaBioSpringToAxolabs),
2983
- /* harmony export */ "siRnaBioSpringToGcrs": () => (/* binding */ siRnaBioSpringToGcrs),
2984
- /* harmony export */ "siRnaAxolabsToGcrs": () => (/* binding */ siRnaAxolabsToGcrs),
2985
- /* harmony export */ "siRnaAxolabsToBioSpring": () => (/* binding */ siRnaAxolabsToBioSpring),
2986
- /* harmony export */ "siRnaAxolabsToNucleotides": () => (/* binding */ siRnaAxolabsToNucleotides),
2987
- /* harmony export */ "siRnaGcrsToNucleotides": () => (/* binding */ siRnaGcrsToNucleotides),
2988
- /* harmony export */ "siRnaGcrsToBioSpring": () => (/* binding */ siRnaGcrsToBioSpring),
2989
- /* harmony export */ "siRnaGcrsToAxolabs": () => (/* binding */ siRnaGcrsToAxolabs),
2990
- /* harmony export */ "siRnaNucleotideToBioSpringSenseStrand": () => (/* binding */ siRnaNucleotideToBioSpringSenseStrand),
2991
- /* harmony export */ "siRnaNucleotidesToGcrs": () => (/* binding */ siRnaNucleotidesToGcrs),
2992
- /* harmony export */ "siRnaNucleotideToAxolabsSenseStrand": () => (/* binding */ siRnaNucleotideToAxolabsSenseStrand),
2993
- /* harmony export */ "siRnaNucleotideToAxolabsAntisenseStrand": () => (/* binding */ siRnaNucleotideToAxolabsAntisenseStrand),
2994
- /* harmony export */ "gcrsToNucleotides": () => (/* binding */ gcrsToNucleotides),
2995
- /* harmony export */ "gcrsToMermade12": () => (/* binding */ gcrsToMermade12)
2996
- /* harmony export */ });
2997
- /* harmony import */ var _map__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./map */ "./src/structures-works/map.ts");
2998
- /* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! datagrok-api/dg */ "datagrok-api/dg");
2999
- /* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__);
3000
3198
 
3001
3199
 
3002
- //name: gcrsToLcms
3003
- //input: string nucleotides {semType: GCRS}
3004
- //output: string result {semType: LCMS}
3005
- function gcrsToLcms(sequence) {
3006
- const df = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__.DataFrame.fromCsv(_map__WEBPACK_IMPORTED_MODULE_0__.lcmsToGcrs);
3007
- const arr1 = df.getCol('GCRS').toList();
3008
- const arr2 = df.getCol('LCMS').toList();
3009
- const obj = {};
3010
- arr1.forEach((element, index) => obj[element] = arr2[index]);
3011
- for (let i = 0; i < arr1.length; i++) {
3012
- arr1[i] = arr1[i].replace('(', '\\(');
3013
- arr1[i] = arr1[i].replace(')', '\\)');
3014
- }
3015
- const regExp = new RegExp('(' + arr1.join('|') + ')', 'g');
3016
- return sequence.replace(regExp, function (code) { return obj[code]; });
3017
- }
3018
- //name: asoGapmersNucleotidesToBioSpring
3019
- //input: string nucleotides {semType: DNA nucleotides}
3020
- //output: string result {semType: BioSpring / Gapmers}
3021
- function asoGapmersNucleotidesToBioSpring(nucleotides) {
3022
- let count = -1;
3023
- const objForEdges = {
3024
- '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': '5*', 'A': '6*', 'C': '7*', 'G': '8*'
3025
- };
3026
- const objForCenter = {
3027
- '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'T*', 'A': 'A*', 'C': '9*', 'G': 'G*'
3028
- };
3029
- return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|T|C|G)/g, function (x) {
3030
- count++;
3031
- return (count > 4 && count < 15) ? objForCenter[x] : objForEdges[x];
3032
- }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?
3033
- nucleotides.length : 2 * count + 1);
3034
- }
3035
- //name: asoGapmersNucleotidesToGcrs
3036
- //input: string nucleotides {semType: DNA nucleotides}
3037
- //output: string result {semType: GCRS / Gapmers}
3038
- function asoGapmersNucleotidesToGcrs(nucleotides) {
3039
- let count = -1;
3040
- const objForEdges = {
3041
- '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'moeUnps',
3042
- 'A': 'moeAnps', 'C': 'moe5mCnps', 'G': 'moeGnps'
3043
- };
3044
- const objForCenter = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
3045
- 'C': '5mCps', 'A': 'Aps', 'T': 'Tps', 'G': 'Gps' };
3046
- return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|T|C|G)/g, function (x) {
3047
- count++;
3048
- if (count < 5)
3049
- return (count == 4) ? objForEdges[x].slice(0, -3) + 'ps' : objForEdges[x];
3050
- if (count < 15)
3051
- return (count == 14) ? objForCenter[x].slice(0, -2) + 'nps' : objForCenter[x];
3200
+ const defaultInput = 'fAmCmGmAmCpsmU';
3201
+ const sequenceWasCopied = 'Copied';
3202
+ const tooltipSequence = 'Copy sequence';
3203
+ function mainView() {
3204
+ function updateTableAndMolecule(sequence, inputFormat, isSet) {
3205
+ moleculeSvgDiv.innerHTML = '';
3206
+ outputTableDiv.innerHTML = '';
3207
+ const pi = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TaskBarProgressIndicator.create('Rendering table and molecule...');
3208
+ let errorsExist = false;
3209
+ try {
3210
+ sequence = sequence.replace(/\s/g, '');
3211
+ const output = (0,_structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_3__.isValidSequence)(sequence, null);
3212
+ if (isSet)
3213
+ output.synthesizer = [inputFormat];
3214
+ inputFormatChoiceInput.value = output.synthesizer[0];
3215
+ const outputSequenceObj = (0,_structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_3__.convertSequence)(sequence, output);
3216
+ const tableRows = [];
3217
+ for (const key of Object.keys(outputSequenceObj).slice(1)) {
3218
+ const indexOfFirstNotValidChar = ('indexOfFirstNotValidChar' in outputSequenceObj) ?
3219
+ JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).indexOfFirstNotValidChar :
3220
+ -1;
3221
+ if ('indexOfFirstNotValidChar' in outputSequenceObj) {
3222
+ const indexOfFirstNotValidChar = ('indexOfFirstNotValidChar' in outputSequenceObj) ?
3223
+ JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).indexOfFirstNotValidChar :
3224
+ -1;
3225
+ if (indexOfFirstNotValidChar != -1)
3226
+ errorsExist = true;
3227
+ }
3228
+ tableRows.push({
3229
+ 'key': key,
3230
+ 'value': ('indexOfFirstNotValidChar' in outputSequenceObj) ?
3231
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divH([
3232
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText(sequence.slice(0, indexOfFirstNotValidChar), { style: { color: 'grey' } }),
3233
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.tooltip.bind(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText(sequence.slice(indexOfFirstNotValidChar), { style: { color: 'red' } }), 'Expected format: ' + JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).synthesizer +
3234
+ '. See tables with valid codes on the right'),
3235
+ ]) : //@ts-ignore
3236
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.link(outputSequenceObj[key], () => navigator.clipboard.writeText(outputSequenceObj[key])
3237
+ .then(() => datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.info(sequenceWasCopied)), tooltipSequence, ''),
3238
+ });
3239
+ }
3240
+ if (errorsExist) {
3241
+ const synthesizer = JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).synthesizer.slice(0, -6);
3242
+ asoGapmersGrid.onCellPrepare(function (gc) {
3243
+ gc.style.backColor = (gc.gridColumn.name == synthesizer) ? 0xFFF00000 : 0xFFFFFFFF;
3244
+ });
3245
+ omeAndFluoroGrid.onCellPrepare(function (gc) {
3246
+ gc.style.backColor = (gc.gridColumn.name == synthesizer) ? 0xFFF00000 : 0xFFFFFFFF;
3247
+ });
3248
+ switchInput.enabled = true;
3249
+ }
3250
+ else {
3251
+ asoGapmersGrid.onCellPrepare(function (gc) { gc.style.backColor = 0xFFFFFFFF; });
3252
+ omeAndFluoroGrid.onCellPrepare(function (gc) { gc.style.backColor = 0xFFFFFFFF; });
3253
+ }
3254
+ outputTableDiv.append(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([
3255
+ datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.HtmlTable.create(tableRows, (item) => [item.key, item.value], ['Code', 'Sequence']).root,
3256
+ ]));
3257
+ if (outputSequenceObj.type != _structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_3__.undefinedInputSequence && outputSequenceObj.Error != _structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_3__.undefinedInputSequence) {
3258
+ const canvas = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.canvas(300, 170);
3259
+ canvas.addEventListener('click', () => {
3260
+ const canv = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.canvas(cash_dom__WEBPACK_IMPORTED_MODULE_6___default()(window).width(), cash_dom__WEBPACK_IMPORTED_MODULE_6___default()(window).height());
3261
+ const mol = (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_5__.sequenceToMolV3000)(inputSequenceField.value.replace(/\s/g, ''), false, true, output.synthesizer[0]);
3262
+ // @ts-ignore
3263
+ OCL.StructureView.drawMolecule(canv, OCL.Molecule.fromMolfile(mol), { suppressChiralText: true });
3264
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.dialog('Molecule: ' + inputSequenceField.value)
3265
+ .add(canv)
3266
+ .showModal(true);
3267
+ });
3268
+ cash_dom__WEBPACK_IMPORTED_MODULE_6___default()(canvas).on('mouseover', () => cash_dom__WEBPACK_IMPORTED_MODULE_6___default()(canvas).css('cursor', 'zoom-in'));
3269
+ cash_dom__WEBPACK_IMPORTED_MODULE_6___default()(canvas).on('mouseout', () => cash_dom__WEBPACK_IMPORTED_MODULE_6___default()(canvas).css('cursor', 'default'));
3270
+ const mol = (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_5__.sequenceToMolV3000)(inputSequenceField.value.replace(/\s/g, ''), false, true, output.synthesizer[0]);
3271
+ // @ts-ignore
3272
+ OCL.StructureView.drawMolecule(canvas, OCL.Molecule.fromMolfile(mol), { suppressChiralText: true });
3273
+ moleculeSvgDiv.append(canvas);
3274
+ }
3275
+ else
3276
+ moleculeSvgDiv.innerHTML = '';
3277
+ }
3278
+ finally {
3279
+ pi.close();
3280
+ }
3281
+ }
3282
+ const inputFormatChoiceInput = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('Input format: ', 'Janssen GCRS Codes', Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.map), (format) => {
3283
+ updateTableAndMolecule(inputSequenceField.value.replace(/\s/g, ''), format, true);
3284
+ });
3285
+ const moleculeSvgDiv = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.block([]);
3286
+ const outputTableDiv = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([]);
3287
+ const inputSequenceField = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.textInput('', defaultInput, (sequence) => updateTableAndMolecule(sequence, inputFormatChoiceInput.value, false));
3288
+ const asoDf = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromObjects([
3289
+ { 'Name': '2\'MOE-5Me-rU', 'BioSpring': '5', 'Janssen GCRS': 'moeT' },
3290
+ { 'Name': '2\'MOE-rA', 'BioSpring': '6', 'Janssen GCRS': 'moeA' },
3291
+ { 'Name': '2\'MOE-5Me-rC', 'BioSpring': '7', 'Janssen GCRS': 'moe5mC' },
3292
+ { 'Name': '2\'MOE-rG', 'BioSpring': '8', 'Janssen GCRS': 'moeG' },
3293
+ { 'Name': '5-Methyl-dC', 'BioSpring': '9', 'Janssen GCRS': '5mC' },
3294
+ { 'Name': 'ps linkage', 'BioSpring': '*', 'Janssen GCRS': 'ps' },
3295
+ { 'Name': 'dA', 'BioSpring': 'A', 'Janssen GCRS': 'A, dA' },
3296
+ { 'Name': 'dC', 'BioSpring': 'C', 'Janssen GCRS': 'C, dC' },
3297
+ { 'Name': 'dG', 'BioSpring': 'G', 'Janssen GCRS': 'G, dG' },
3298
+ { 'Name': 'dT', 'BioSpring': 'T', 'Janssen GCRS': 'T, dT' },
3299
+ { 'Name': 'rA', 'BioSpring': '', 'Janssen GCRS': 'rA' },
3300
+ { 'Name': 'rC', 'BioSpring': '', 'Janssen GCRS': 'rC' },
3301
+ { 'Name': 'rG', 'BioSpring': '', 'Janssen GCRS': 'rG' },
3302
+ { 'Name': 'rU', 'BioSpring': '', 'Janssen GCRS': 'rU' },
3303
+ ]);
3304
+ const asoGapmersGrid = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Viewer.grid(asoDf, { showRowHeader: false, showCellTooltip: false });
3305
+ asoDf.onCurrentCellChanged.subscribe((_) => {
3306
+ navigator.clipboard.writeText(asoDf.currentCell.value).then(() => datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.info('Copied'));
3307
+ });
3308
+ const omeAndFluoroGrid = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Viewer.grid(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromObjects([
3309
+ { 'Name': '2\'-fluoro-U', 'BioSpring': '1', 'Axolabs': 'Uf', 'Janssen GCRS': 'fU' },
3310
+ { 'Name': '2\'-fluoro-A', 'BioSpring': '2', 'Axolabs': 'Af', 'Janssen GCRS': 'fA' },
3311
+ { 'Name': '2\'-fluoro-C', 'BioSpring': '3', 'Axolabs': 'Cf', 'Janssen GCRS': 'fC' },
3312
+ { 'Name': '2\'-fluoro-G', 'BioSpring': '4', 'Axolabs': 'Gf', 'Janssen GCRS': 'fG' },
3313
+ { 'Name': '2\'OMe-rU', 'BioSpring': '5', 'Axolabs': 'u', 'Janssen GCRS': 'mU' },
3314
+ { 'Name': '2\'OMe-rA', 'BioSpring': '6', 'Axolabs': 'a', 'Janssen GCRS': 'mA' },
3315
+ { 'Name': '2\'OMe-rC', 'BioSpring': '7', 'Axolabs': 'c', 'Janssen GCRS': 'mC' },
3316
+ { 'Name': '2\'OMe-rG', 'BioSpring': '8', 'Axolabs': 'g', 'Janssen GCRS': 'mG' },
3317
+ { 'Name': 'ps linkage', 'BioSpring': '*', 'Axolabs': 's', 'Janssen GCRS': 'ps' },
3318
+ ]), { showRowHeader: false, showCellTooltip: false });
3319
+ const overhangModificationsGrid = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Viewer.grid(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromColumns([
3320
+ datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Column.fromStrings('Name', Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_4__.MODIFICATIONS)),
3321
+ ]), { showRowHeader: false, showCellTooltip: false });
3322
+ updateTableAndMolecule(defaultInput, inputFormatChoiceInput.value, true);
3323
+ const codesTablesDiv = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.splitV([
3324
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.box(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.h2('ASO Gapmers'), { style: { maxHeight: '40px' } }),
3325
+ asoGapmersGrid.root,
3326
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.box(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.h2('2\'-OMe and 2\'-F siRNA'), { style: { maxHeight: '40px' } }),
3327
+ omeAndFluoroGrid.root,
3328
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.box(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.h2('Overhang modifications'), { style: { maxHeight: '40px' } }),
3329
+ overhangModificationsGrid.root,
3330
+ ], { style: { maxWidth: '350px' } });
3331
+ const appMainDescription = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.info([
3332
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText('How to convert one sequence:', { style: { 'font-weight': 'bolder' } }),
3333
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText('Paste sequence into the text field below'),
3334
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText('\n How to convert many sequences:', { style: { 'font-weight': 'bolder' } }),
3335
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText('1. Drag & drop an Excel or CSV file with sequences into Datagrok'),
3336
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText('2. Right-click on the column header, then see the \'Convert\' menu'),
3337
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText('This will add the result column to the right of the table'),
3338
+ ], 'Convert oligonucleotide sequences between Nucleotides, BioSpring, Axolabs, Mermade 12 and GCRS representations.');
3339
+ cash_dom__WEBPACK_IMPORTED_MODULE_6___default()(codesTablesDiv).hide();
3340
+ const switchInput = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.switchInput('Codes', false, (v) => (v) ?
3341
+ cash_dom__WEBPACK_IMPORTED_MODULE_6___default()(codesTablesDiv).show() :
3342
+ cash_dom__WEBPACK_IMPORTED_MODULE_6___default()(codesTablesDiv).hide());
3343
+ const topPanel = [
3344
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.iconFA('download', () => {
3345
+ const result = (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_5__.sequenceToMolV3000)(inputSequenceField.value.replace(/\s/g, ''), false, false, inputFormatChoiceInput.value);
3346
+ const element = document.createElement('a');
3347
+ element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(result));
3348
+ element.setAttribute('download', inputSequenceField.value.replace(/\s/g, '') + '.mol');
3349
+ element.click();
3350
+ }, 'Save .mol file'),
3351
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.iconFA('copy', () => {
3352
+ navigator.clipboard.writeText((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_5__.sequenceToSmiles)(inputSequenceField.value.replace(/\s/g, ''), false, inputFormatChoiceInput.value))
3353
+ .then(() => datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.info(sequenceWasCopied));
3354
+ }, 'Copy SMILES'),
3355
+ switchInput.root,
3356
+ ];
3357
+ const v = datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.v;
3358
+ const tabControl = datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.sidebar;
3359
+ tabControl.onTabChanged.subscribe((_) => v.setRibbonPanels([(tabControl.currentPane.name == 'MAIN') ? topPanel : []]));
3360
+ v.setRibbonPanels([topPanel]);
3361
+ return datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.box(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.splitH([
3362
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.splitV([
3363
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.panel([
3364
+ appMainDescription,
3365
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([
3366
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.h1('Input sequence'),
3367
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([
3368
+ inputSequenceField.root,
3369
+ ], 'input-base'),
3370
+ ], 'inputSequence'),
3371
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([inputFormatChoiceInput], { style: { padding: '5px 0' } }),
3372
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.block([
3373
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.h1('Output'),
3374
+ outputTableDiv,
3375
+ ]),
3376
+ moleculeSvgDiv,
3377
+ ], 'sequence'),
3378
+ ]),
3379
+ codesTablesDiv,
3380
+ ], { style: { height: '100%', width: '100%' } }));
3381
+ }
3382
+
3383
+
3384
+ /***/ }),
3385
+
3386
+ /***/ "./src/salts.ts":
3387
+ /*!**********************!*\
3388
+ !*** ./src/salts.ts ***!
3389
+ \**********************/
3390
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3391
+
3392
+ "use strict";
3393
+ __webpack_require__.r(__webpack_exports__);
3394
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
3395
+ /* harmony export */ "SALTS_CSV": () => (/* binding */ SALTS_CSV)
3396
+ /* harmony export */ });
3397
+ const SALTS_CSV = `DISPLAY,MOLWEIGHT
3398
+ no Data Added,100`;
3399
+
3400
+
3401
+ /***/ }),
3402
+
3403
+ /***/ "./src/sources.ts":
3404
+ /*!************************!*\
3405
+ !*** ./src/sources.ts ***!
3406
+ \************************/
3407
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3408
+
3409
+ "use strict";
3410
+ __webpack_require__.r(__webpack_exports__);
3411
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
3412
+ /* harmony export */ "SOURCES": () => (/* binding */ SOURCES)
3413
+ /* harmony export */ });
3414
+ const SOURCES = `DISPLAY
3415
+ NO DATA
3416
+ `;
3417
+
3418
+
3419
+ /***/ }),
3420
+
3421
+ /***/ "./src/structures-works/converters.ts":
3422
+ /*!********************************************!*\
3423
+ !*** ./src/structures-works/converters.ts ***!
3424
+ \********************************************/
3425
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3426
+
3427
+ "use strict";
3428
+ __webpack_require__.r(__webpack_exports__);
3429
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
3430
+ /* harmony export */ "gcrsToLcms": () => (/* binding */ gcrsToLcms),
3431
+ /* harmony export */ "asoGapmersNucleotidesToBioSpring": () => (/* binding */ asoGapmersNucleotidesToBioSpring),
3432
+ /* harmony export */ "asoGapmersNucleotidesToGcrs": () => (/* binding */ asoGapmersNucleotidesToGcrs),
3433
+ /* harmony export */ "asoGapmersBioSpringToNucleotides": () => (/* binding */ asoGapmersBioSpringToNucleotides),
3434
+ /* harmony export */ "asoGapmersBioSpringToGcrs": () => (/* binding */ asoGapmersBioSpringToGcrs),
3435
+ /* harmony export */ "asoGapmersGcrsToBioSpring": () => (/* binding */ asoGapmersGcrsToBioSpring),
3436
+ /* harmony export */ "asoGapmersGcrsToNucleotides": () => (/* binding */ asoGapmersGcrsToNucleotides),
3437
+ /* harmony export */ "siRnaBioSpringToNucleotides": () => (/* binding */ siRnaBioSpringToNucleotides),
3438
+ /* harmony export */ "siRnaBioSpringToAxolabs": () => (/* binding */ siRnaBioSpringToAxolabs),
3439
+ /* harmony export */ "siRnaBioSpringToGcrs": () => (/* binding */ siRnaBioSpringToGcrs),
3440
+ /* harmony export */ "siRnaAxolabsToGcrs": () => (/* binding */ siRnaAxolabsToGcrs),
3441
+ /* harmony export */ "siRnaAxolabsToBioSpring": () => (/* binding */ siRnaAxolabsToBioSpring),
3442
+ /* harmony export */ "siRnaAxolabsToNucleotides": () => (/* binding */ siRnaAxolabsToNucleotides),
3443
+ /* harmony export */ "siRnaGcrsToNucleotides": () => (/* binding */ siRnaGcrsToNucleotides),
3444
+ /* harmony export */ "siRnaGcrsToBioSpring": () => (/* binding */ siRnaGcrsToBioSpring),
3445
+ /* harmony export */ "siRnaGcrsToAxolabs": () => (/* binding */ siRnaGcrsToAxolabs),
3446
+ /* harmony export */ "siRnaNucleotideToBioSpringSenseStrand": () => (/* binding */ siRnaNucleotideToBioSpringSenseStrand),
3447
+ /* harmony export */ "siRnaNucleotidesToGcrs": () => (/* binding */ siRnaNucleotidesToGcrs),
3448
+ /* harmony export */ "siRnaNucleotideToAxolabsSenseStrand": () => (/* binding */ siRnaNucleotideToAxolabsSenseStrand),
3449
+ /* harmony export */ "siRnaNucleotideToAxolabsAntisenseStrand": () => (/* binding */ siRnaNucleotideToAxolabsAntisenseStrand),
3450
+ /* harmony export */ "gcrsToNucleotides": () => (/* binding */ gcrsToNucleotides),
3451
+ /* harmony export */ "gcrsToMermade12": () => (/* binding */ gcrsToMermade12)
3452
+ /* harmony export */ });
3453
+ /* harmony import */ var _map__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./map */ "./src/structures-works/map.ts");
3454
+ /* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! datagrok-api/dg */ "datagrok-api/dg");
3455
+ /* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__);
3456
+
3457
+
3458
+ //name: gcrsToLcms
3459
+ //input: string nucleotides {semType: GCRS}
3460
+ //output: string result {semType: LCMS}
3461
+ function gcrsToLcms(sequence) {
3462
+ const df = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__.DataFrame.fromCsv(_map__WEBPACK_IMPORTED_MODULE_0__.lcmsToGcrs);
3463
+ const arr1 = df.getCol('GCRS').toList();
3464
+ const arr2 = df.getCol('LCMS').toList();
3465
+ const obj = {};
3466
+ arr1.forEach((element, index) => obj[element] = arr2[index]);
3467
+ for (let i = 0; i < arr1.length; i++) {
3468
+ arr1[i] = arr1[i].replace('(', '\\(');
3469
+ arr1[i] = arr1[i].replace(')', '\\)');
3470
+ }
3471
+ const regExp = new RegExp('(' + arr1.join('|') + ')', 'g');
3472
+ let r1 = sequence.replace(regExp, function (code) { return obj[code]; });
3473
+ r1 = r1.replace('//', '/');
3474
+ r1 = r1.replace('//', '/');
3475
+ return r1.replace('//', '/');
3476
+ }
3477
+ //name: asoGapmersNucleotidesToBioSpring
3478
+ //input: string nucleotides {semType: DNA nucleotides}
3479
+ //output: string result {semType: BioSpring / Gapmers}
3480
+ function asoGapmersNucleotidesToBioSpring(nucleotides) {
3481
+ let count = -1;
3482
+ const objForEdges = {
3483
+ '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': '5*', 'A': '6*', 'C': '7*', 'G': '8*'
3484
+ };
3485
+ const objForCenter = {
3486
+ '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'T*', 'A': 'A*', 'C': '9*', 'G': 'G*'
3487
+ };
3488
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|T|C|G)/g, function (x) {
3489
+ count++;
3490
+ return (count > 4 && count < 15) ? objForCenter[x] : objForEdges[x];
3491
+ }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?
3492
+ nucleotides.length : 2 * count + 1);
3493
+ }
3494
+ //name: asoGapmersNucleotidesToGcrs
3495
+ //input: string nucleotides {semType: DNA nucleotides}
3496
+ //output: string result {semType: GCRS / Gapmers}
3497
+ function asoGapmersNucleotidesToGcrs(nucleotides) {
3498
+ let count = -1;
3499
+ const objForEdges = {
3500
+ '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'moeUnps',
3501
+ 'A': 'moeAnps', 'C': 'moe5mCnps', 'G': 'moeGnps'
3502
+ };
3503
+ const objForCenter = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
3504
+ 'C': '5mCps', 'A': 'Aps', 'T': 'Tps', 'G': 'Gps' };
3505
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|T|C|G)/g, function (x) {
3506
+ count++;
3507
+ if (count < 5)
3508
+ return (count == 4) ? objForEdges[x].slice(0, -3) + 'ps' : objForEdges[x];
3509
+ if (count < 15)
3510
+ return (count == 14) ? objForCenter[x].slice(0, -2) + 'nps' : objForCenter[x];
3052
3511
  return objForEdges[x];
3053
3512
  }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?
3054
3513
  nucleotides.length : -3);
@@ -3311,7 +3770,7 @@ function sequenceToMolV3000(sequence, inverted = false, oclRender = false, forma
3311
3770
  const links = ['s', 'ps', '*'];
3312
3771
  const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];
3313
3772
  const dropdowns = Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS);
3314
- codes = codes.concat(dropdowns);
3773
+ codes = codes.concat(dropdowns).concat(_map__WEBPACK_IMPORTED_MODULE_0__.delimiter);
3315
3774
  while (i < sequence.length) {
3316
3775
  const code = codes.find((s) => s == sequence.slice(i, i + s.length));
3317
3776
  i += code.length;
@@ -3345,7 +3804,7 @@ function sequenceToSmiles(sequence, inverted = false, format) {
3345
3804
  const links = ['s', 'ps', '*'];
3346
3805
  const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];
3347
3806
  const dropdowns = Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS);
3348
- codes = codes.concat(dropdowns);
3807
+ codes = codes.concat(dropdowns).concat(_map__WEBPACK_IMPORTED_MODULE_0__.delimiter);
3349
3808
  while (i < sequence.length) {
3350
3809
  const code = codes.find((s) => s == sequence.slice(i, i + s.length));
3351
3810
  i += code.length;
@@ -3391,6 +3850,7 @@ function getObjectWithCodesAndSmiles(sequence, format) {
3391
3850
  obj[code] = _map__WEBPACK_IMPORTED_MODULE_0__.map[format][technology][code].SMILES;
3392
3851
  }
3393
3852
  }
3853
+ obj[_map__WEBPACK_IMPORTED_MODULE_0__.delimiter] = '';
3394
3854
  // TODO: create object based from synthesizer type to avoid key(codes) duplicates
3395
3855
  const output = (0,_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_1__.isValidSequence)(sequence, format);
3396
3856
  if (output.synthesizer.includes(_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.MERMADE_12))
@@ -3415,6 +3875,7 @@ function sortByStringLengthInDescendingOrder(array) {
3415
3875
  "use strict";
3416
3876
  __webpack_require__.r(__webpack_exports__);
3417
3877
  /* harmony export */ __webpack_require__.d(__webpack_exports__, {
3878
+ /* harmony export */ "delimiter": () => (/* binding */ delimiter),
3418
3879
  /* harmony export */ "SYNTHESIZERS": () => (/* binding */ SYNTHESIZERS),
3419
3880
  /* harmony export */ "TECHNOLOGIES": () => (/* binding */ TECHNOLOGIES),
3420
3881
  /* harmony export */ "COL_NAMES": () => (/* binding */ COL_NAMES),
@@ -3429,6 +3890,7 @@ __webpack_require__.r(__webpack_exports__);
3429
3890
  /* harmony import */ var _sequence_codes_tools__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./sequence-codes-tools */ "./src/structures-works/sequence-codes-tools.ts");
3430
3891
 
3431
3892
 
3893
+ const delimiter = ';';
3432
3894
  const SYNTHESIZERS = {
3433
3895
  RAW_NUCLEOTIDES: 'Raw Nucleotides',
3434
3896
  BIOSPRING: 'BioSpring Codes',
@@ -4164,9 +4626,6 @@ __webpack_require__.r(__webpack_exports__);
4164
4626
  /* harmony export */ "getNucleotidesMol": () => (/* binding */ getNucleotidesMol),
4165
4627
  /* harmony export */ "linkV3000": () => (/* binding */ linkV3000)
4166
4628
  /* harmony export */ });
4167
- /* harmony import */ var openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! openchemlib/full.js */ "openchemlib/full.js");
4168
- /* harmony import */ var openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__);
4169
-
4170
4629
  const PHOSHATE = `
4171
4630
  Datagrok monomer library Nucleotides
4172
4631
 
@@ -4384,15 +4843,17 @@ function linkV3000(molBlocks, twoChains = false, oclRender = false) {
4384
4843
  macroMolBlock += 'M V30 BEGIN BOND\n';
4385
4844
  macroMolBlock += bondBlock;
4386
4845
  macroMolBlock += 'M V30 END BOND\n';
4387
- macroMolBlock += 'M V30 BEGIN COLLECTION\n';
4388
- macroMolBlock += collectionBlock;
4389
- macroMolBlock += 'M V30 END COLLECTION\n';
4846
+ //macroMolBlock += 'M V30 BEGIN COLLECTION\n';
4847
+ //macroMolBlock += collectionBlock;
4848
+ //macroMolBlock += 'M V30 END COLLECTION\n';
4390
4849
  macroMolBlock += 'M V30 END CTAB\n';
4391
4850
  macroMolBlock += 'M END\n';
4851
+ macroMolBlock = macroMolBlock.replaceAll('CFG=1', '').replaceAll('CFG=2', '').replaceAll('CFG=3', '').replaceAll('CFG=4', '');
4392
4852
  return macroMolBlock;
4393
4853
  }
4394
4854
  function rotateNucleotidesV3000(molecule) {
4395
- let molBlock = molecule.includes('M END') ? molecule : openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__.Molecule.fromSmiles(molecule).toMolfileV3();
4855
+ // @ts-ignore
4856
+ let molBlock = molecule.includes('M END') ? molecule : OCL.Molecule.fromSmiles(molecule).toMolfileV3();
4396
4857
  const coordinates = extractAtomDataV3000(molBlock);
4397
4858
  const natom = coordinates.atomIndex.length;
4398
4859
  const indexFivePrime = coordinates.atomIndex.indexOf(1);
@@ -4445,7 +4906,8 @@ function rotateNucleotidesV3000(molecule) {
4445
4906
  return molBlock;
4446
4907
  }
4447
4908
  function invertNucleotidesV3000(molecule) {
4448
- let molBlock = molecule.includes('M END') ? molecule : openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__.Molecule.fromSmiles(molecule).toMolfileV3();
4909
+ // @ts-ignore
4910
+ let molBlock = molecule.includes('M END') ? molecule : OCL.Molecule.fromSmiles(molecule).toMolfileV3();
4449
4911
  const coordinates = extractAtomDataV3000(molBlock);
4450
4912
  const natom = coordinates.atomIndex.length;
4451
4913
  const xCenter = (Math.max(...coordinates.x) + Math.min(...coordinates.x)) / 2;
@@ -4745,37 +5207,38 @@ function isValidSequence(sequence, format) {
4745
5207
  // const technology = ui.choiceInput('Choose technology from list: ', possibleTechnologies[0],
4746
5208
  // possibleTechnologies);
4747
5209
  // ui.dialog('Choose Technology')
4748
- // .add(ui.panel([technology.root], {style: {fontWeight: 'bold'}}))
4749
- // .onOK(() => possibleTechnologies = [technology.value])
4750
- // .onCancel(() => {
4751
- // possibleTechnologies = [possibleTechnologies[0]];
4752
- // grok.shell.warning('Input sequence is expected to be in format ' + possibleTechnologies[0]);
4753
- // })
4754
- // .show();
4755
- // } else if (possibleTechnologies.length == 0)
4756
- if (possibleTechnologies.length == 0)
4757
- return { indexOfFirstNotValidChar: 0, synthesizer: null, technology: null };
4758
- outputIndex = 0;
4759
- possibleTechnologies.forEach((technology) => {
4760
- const codes = Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[possibleSynthesizers[0]][technology]);
4761
- while (outputIndex < sequence.length) {
4762
- const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));
4763
- if (matchedCode == null)
4764
- break;
4765
- if ( // for mistake pattern 'rAA'
4766
- outputIndex > 1 &&
4767
- nucleotides.includes(sequence[outputIndex]) &&
4768
- firstUniqueCharacters.includes(sequence[outputIndex - 2]))
4769
- break;
4770
- if ( // for mistake pattern 'ArA'
4771
- firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&
4772
- nucleotides.includes(sequence[outputIndex])) {
4773
- outputIndex++;
4774
- break;
4775
- }
4776
- outputIndex += matchedCode.length;
4777
- }
4778
- });
5210
+ // .add(ui.panel([technology.root], {style: {fontWeight: 'bold'}}))
5211
+ // .onOK(() => possibleTechnologies = [technology.value])
5212
+ // .onCancel(() => {
5213
+ // possibleTechnologies = [possibleTechnologies[0]];
5214
+ // grok.shell.warning('Input sequence is expected to be in format ' + possibleTechnologies[0]);
5215
+ // })
5216
+ // .show();
5217
+ // } else if (possibleTechnologies.length == 0)
5218
+ if (possibleTechnologies.length == 0)
5219
+ return { indexOfFirstNotValidChar: 0, synthesizer: [possibleSynthesizers[3]], technology: null };
5220
+ outputIndex = 0;
5221
+ // possibleTechnologies.forEach((technology: string) => {
5222
+ // const codes = Object.keys(map[possibleSynthesizers[0]][technology]);
5223
+ // while (outputIndex < sequence.length) {
5224
+ // const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));
5225
+ // if (matchedCode == null)
5226
+ // break;
5227
+ // if ( // for mistake pattern 'rAA'
5228
+ // outputIndex > 1 &&
5229
+ // nucleotides.includes(sequence[outputIndex]) &&
5230
+ // firstUniqueCharacters.includes(sequence[outputIndex - 2])
5231
+ // ) break;
5232
+ // if ( // for mistake pattern 'ArA'
5233
+ // firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&
5234
+ // nucleotides.includes(sequence[outputIndex])
5235
+ // ) {
5236
+ // outputIndex++;
5237
+ // break;
5238
+ // }
5239
+ // outputIndex += matchedCode.length;
5240
+ // }
5241
+ // });
4779
5242
  return {
4780
5243
  indexOfFirstNotValidChar: indexOfFirstNotValidChar,
4781
5244
  synthesizer: possibleSynthesizers,
@@ -4786,7 +5249,7 @@ function getAllCodesOfSynthesizer(synthesizer) {
4786
5249
  let codes = [];
4787
5250
  for (const technology of Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer]))
4788
5251
  codes = codes.concat(Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer][technology]));
4789
- return codes.concat(Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS)).concat(',');
5252
+ return codes.concat(Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS)).concat(_map__WEBPACK_IMPORTED_MODULE_0__.delimiter);
4790
5253
  }
4791
5254
  function getListOfPossibleSynthesizersByFirstMatchedCode(sequence) {
4792
5255
  const synthesizers = [];
@@ -4941,17 +5404,6 @@ module.exports = DG;
4941
5404
 
4942
5405
  /***/ }),
4943
5406
 
4944
- /***/ "openchemlib/full.js":
4945
- /*!**********************!*\
4946
- !*** external "OCL" ***!
4947
- \**********************/
4948
- /***/ ((module) => {
4949
-
4950
- "use strict";
4951
- module.exports = OCL;
4952
-
4953
- /***/ }),
4954
-
4955
5407
  /***/ "datagrok-api/grok":
4956
5408
  /*!***********************!*\
4957
5409
  !*** external "grok" ***!
@@ -5052,9 +5504,7 @@ var __webpack_exports__ = {};
5052
5504
  __webpack_require__.r(__webpack_exports__);
5053
5505
  /* harmony export */ __webpack_require__.d(__webpack_exports__, {
5054
5506
  /* harmony export */ "_package": () => (/* binding */ _package),
5055
- /* harmony export */ "sequenceTranslator": () => (/* binding */ sequenceTranslator),
5056
- /* harmony export */ "autostartOligoSdFileSubscription": () => (/* binding */ autostartOligoSdFileSubscription),
5057
- /* harmony export */ "oligoSdFile": () => (/* binding */ oligoSdFile)
5507
+ /* harmony export */ "sequenceTranslator": () => (/* binding */ sequenceTranslator)
5058
5508
  /* harmony export */ });
5059
5509
  /* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! datagrok-api/grok */ "datagrok-api/grok");
5060
5510
  /* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__);
@@ -5062,39 +5512,10 @@ __webpack_require__.r(__webpack_exports__);
5062
5512
  /* harmony import */ var datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__);
5063
5513
  /* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! datagrok-api/dg */ "datagrok-api/dg");
5064
5514
  /* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__);
5065
- /* harmony import */ var openchemlib_full_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! openchemlib/full.js */ "openchemlib/full.js");
5066
- /* harmony import */ var openchemlib_full_js__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(openchemlib_full_js__WEBPACK_IMPORTED_MODULE_3__);
5067
- /* harmony import */ var cash_dom__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! cash-dom */ "./node_modules/cash-dom/dist/cash.js");
5068
- /* harmony import */ var cash_dom__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(cash_dom__WEBPACK_IMPORTED_MODULE_4__);
5069
- /* harmony import */ var _defineAxolabsPattern__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./defineAxolabsPattern */ "./src/defineAxolabsPattern.ts");
5070
- /* harmony import */ var _structures_works_save_sense_antisense__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./structures-works/save-sense-antisense */ "./src/structures-works/save-sense-antisense.ts");
5071
- /* harmony import */ var _structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./structures-works/from-monomers */ "./src/structures-works/from-monomers.ts");
5072
- /* harmony import */ var _structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./structures-works/sequence-codes-tools */ "./src/structures-works/sequence-codes-tools.ts");
5073
- /* harmony import */ var _structures_works_map__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./structures-works/map */ "./src/structures-works/map.ts");
5074
- /* harmony import */ var _salts__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./salts */ "./src/salts.ts");
5075
- /* harmony import */ var _users__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./users */ "./src/users.ts");
5076
- /* harmony import */ var _ICDs__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./ICDs */ "./src/ICDs.ts");
5077
- /* harmony import */ var _sources__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./sources */ "./src/sources.ts");
5078
- /* harmony import */ var _IDPs__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ./IDPs */ "./src/IDPs.ts");
5079
- var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
5080
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
5081
- return new (P || (P = Promise))(function (resolve, reject) {
5082
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5083
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
5084
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
5085
- step((generator = generator.apply(thisArg, _arguments || [])).next());
5086
- });
5087
- };
5088
- var _a;
5089
- /* Do not change these import lines. Datagrok will import API library in exactly the same manner */
5090
-
5091
-
5092
-
5093
-
5094
-
5095
-
5096
-
5097
-
5515
+ /* harmony import */ var _autostart_registration__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./autostart/registration */ "./src/autostart/registration.ts");
5516
+ /* harmony import */ var _axolabs_define_pattern__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./axolabs/define-pattern */ "./src/axolabs/define-pattern.ts");
5517
+ /* harmony import */ var _structures_works_save_sense_antisense__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./structures-works/save-sense-antisense */ "./src/structures-works/save-sense-antisense.ts");
5518
+ /* harmony import */ var _main_main_view__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./main/main-view */ "./src/main/main-view.ts");
5098
5519
 
5099
5520
 
5100
5521
 
@@ -5103,9 +5524,6 @@ var _a;
5103
5524
 
5104
5525
 
5105
5526
  const _package = new datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Package();
5106
- const defaultInput = 'fAmCmGmAmCpsmU';
5107
- const sequenceWasCopied = 'Copied';
5108
- const tooltipSequence = 'Copy sequence';
5109
5527
  //name: Sequence Translator
5110
5528
  //tags: app
5111
5529
  function sequenceTranslator() {
@@ -5113,312 +5531,21 @@ function sequenceTranslator() {
5113
5531
  windows.showProperties = false;
5114
5532
  windows.showToolbox = false;
5115
5533
  windows.showHelp = false;
5116
- function updateTableAndMolecule(sequence, inputFormat, isSet) {
5117
- moleculeSvgDiv.innerHTML = '';
5118
- outputTableDiv.innerHTML = '';
5119
- const pi = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TaskBarProgressIndicator.create('Rendering table and molecule...');
5120
- let errorsExist = false;
5121
- try {
5122
- sequence = sequence.replace(/\s/g, '');
5123
- const output = (0,_structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_8__.isValidSequence)(sequence, null);
5124
- if (isSet)
5125
- output.synthesizer = [inputFormat];
5126
- inputFormatChoiceInput.value = output.synthesizer[0];
5127
- const outputSequenceObj = (0,_structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_8__.convertSequence)(sequence, output);
5128
- const tableRows = [];
5129
- for (const key of Object.keys(outputSequenceObj).slice(1)) {
5130
- const indexOfFirstNotValidChar = ('indexOfFirstNotValidChar' in outputSequenceObj) ?
5131
- JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).indexOfFirstNotValidChar :
5132
- -1;
5133
- if ('indexOfFirstNotValidChar' in outputSequenceObj) {
5134
- const indexOfFirstNotValidChar = ('indexOfFirstNotValidChar' in outputSequenceObj) ?
5135
- JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).indexOfFirstNotValidChar :
5136
- -1;
5137
- if (indexOfFirstNotValidChar != -1)
5138
- errorsExist = true;
5139
- }
5140
- tableRows.push({
5141
- 'key': key,
5142
- 'value': ('indexOfFirstNotValidChar' in outputSequenceObj) ?
5143
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divH([
5144
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText(sequence.slice(0, indexOfFirstNotValidChar), { style: { color: 'grey' } }),
5145
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.tooltip.bind(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText(sequence.slice(indexOfFirstNotValidChar), { style: { color: 'red' } }), 'Expected format: ' + JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).synthesizer +
5146
- '. See tables with valid codes on the right'),
5147
- ]) : //@ts-ignore
5148
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.link(outputSequenceObj[key], () => navigator.clipboard.writeText(outputSequenceObj[key])
5149
- .then(() => datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.info(sequenceWasCopied)), tooltipSequence, ''),
5150
- });
5151
- }
5152
- if (errorsExist) {
5153
- const synthesizer = JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).synthesizer.slice(0, -6);
5154
- asoGapmersGrid.onCellPrepare(function (gc) {
5155
- gc.style.backColor = (gc.gridColumn.name == synthesizer) ? 0xFFF00000 : 0xFFFFFFFF;
5156
- });
5157
- omeAndFluoroGrid.onCellPrepare(function (gc) {
5158
- gc.style.backColor = (gc.gridColumn.name == synthesizer) ? 0xFFF00000 : 0xFFFFFFFF;
5159
- });
5160
- switchInput.enabled = true;
5161
- }
5162
- else {
5163
- asoGapmersGrid.onCellPrepare(function (gc) { gc.style.backColor = 0xFFFFFFFF; });
5164
- omeAndFluoroGrid.onCellPrepare(function (gc) { gc.style.backColor = 0xFFFFFFFF; });
5165
- }
5166
- outputTableDiv.append(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([
5167
- datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.HtmlTable.create(tableRows, (item) => [item.key, item.value], ['Code', 'Sequence']).root,
5168
- ]));
5169
- if (outputSequenceObj.type != _structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_8__.undefinedInputSequence && outputSequenceObj.Error != _structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_8__.undefinedInputSequence) {
5170
- const canvas = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.canvas(300, 170);
5171
- canvas.addEventListener('click', () => {
5172
- const canv = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.canvas(cash_dom__WEBPACK_IMPORTED_MODULE_4___default()(window).width(), cash_dom__WEBPACK_IMPORTED_MODULE_4___default()(window).height());
5173
- const mol = (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_7__.sequenceToMolV3000)(inputSequenceField.value.replace(/\s/g, ''), false, true, output.synthesizer[0]);
5174
- // @ts-ignore
5175
- openchemlib_full_js__WEBPACK_IMPORTED_MODULE_3__.StructureView.drawMolecule(canv, openchemlib_full_js__WEBPACK_IMPORTED_MODULE_3__.Molecule.fromMolfile(mol), { suppressChiralText: true });
5176
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.dialog('Molecule: ' + inputSequenceField.value)
5177
- .add(canv)
5178
- .showModal(true);
5179
- });
5180
- cash_dom__WEBPACK_IMPORTED_MODULE_4___default()(canvas).on('mouseover', () => cash_dom__WEBPACK_IMPORTED_MODULE_4___default()(canvas).css('cursor', 'zoom-in'));
5181
- cash_dom__WEBPACK_IMPORTED_MODULE_4___default()(canvas).on('mouseout', () => cash_dom__WEBPACK_IMPORTED_MODULE_4___default()(canvas).css('cursor', 'default'));
5182
- const mol = (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_7__.sequenceToMolV3000)(inputSequenceField.value.replace(/\s/g, ''), false, true, output.synthesizer[0]);
5183
- // @ts-ignore
5184
- openchemlib_full_js__WEBPACK_IMPORTED_MODULE_3__.StructureView.drawMolecule(canvas, openchemlib_full_js__WEBPACK_IMPORTED_MODULE_3__.Molecule.fromMolfile(mol), { suppressChiralText: true });
5185
- moleculeSvgDiv.append(canvas);
5186
- }
5187
- else
5188
- moleculeSvgDiv.innerHTML = '';
5189
- }
5190
- finally {
5191
- pi.close();
5192
- }
5193
- }
5194
- const inputFormatChoiceInput = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('Input format: ', 'Janssen GCRS Codes', Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.map), (format) => {
5195
- updateTableAndMolecule(inputSequenceField.value.replace(/\s/g, ''), format, true);
5196
- });
5197
- const moleculeSvgDiv = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.block([]);
5198
- const outputTableDiv = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([]);
5199
- const inputSequenceField = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.textInput('', defaultInput, (sequence) => updateTableAndMolecule(sequence, inputFormatChoiceInput.value, false));
5200
- const asoDf = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromObjects([
5201
- { 'Name': '2\'MOE-5Me-rU', 'BioSpring': '5', 'Janssen GCRS': 'moeT' },
5202
- { 'Name': '2\'MOE-rA', 'BioSpring': '6', 'Janssen GCRS': 'moeA' },
5203
- { 'Name': '2\'MOE-5Me-rC', 'BioSpring': '7', 'Janssen GCRS': 'moe5mC' },
5204
- { 'Name': '2\'MOE-rG', 'BioSpring': '8', 'Janssen GCRS': 'moeG' },
5205
- { 'Name': '5-Methyl-dC', 'BioSpring': '9', 'Janssen GCRS': '5mC' },
5206
- { 'Name': 'ps linkage', 'BioSpring': '*', 'Janssen GCRS': 'ps' },
5207
- { 'Name': 'dA', 'BioSpring': 'A', 'Janssen GCRS': 'A, dA' },
5208
- { 'Name': 'dC', 'BioSpring': 'C', 'Janssen GCRS': 'C, dC' },
5209
- { 'Name': 'dG', 'BioSpring': 'G', 'Janssen GCRS': 'G, dG' },
5210
- { 'Name': 'dT', 'BioSpring': 'T', 'Janssen GCRS': 'T, dT' },
5211
- { 'Name': 'rA', 'BioSpring': '', 'Janssen GCRS': 'rA' },
5212
- { 'Name': 'rC', 'BioSpring': '', 'Janssen GCRS': 'rC' },
5213
- { 'Name': 'rG', 'BioSpring': '', 'Janssen GCRS': 'rG' },
5214
- { 'Name': 'rU', 'BioSpring': '', 'Janssen GCRS': 'rU' },
5534
+ const v = datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.newView('Sequence Translator', [
5535
+ datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.tabControl({
5536
+ 'MAIN': (0,_main_main_view__WEBPACK_IMPORTED_MODULE_6__.mainView)(),
5537
+ 'AXOLABS': (0,_axolabs_define_pattern__WEBPACK_IMPORTED_MODULE_4__.defineAxolabsPattern)(),
5538
+ 'SDF': (0,_structures_works_save_sense_antisense__WEBPACK_IMPORTED_MODULE_5__.saveSenseAntiSense)(),
5539
+ }),
5215
5540
  ]);
5216
- const asoGapmersGrid = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Viewer.grid(asoDf, { showRowHeader: false, showCellTooltip: false });
5217
- asoDf.onCurrentCellChanged.subscribe((_) => {
5218
- navigator.clipboard.writeText(asoDf.currentCell.value).then(() => datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.info('Copied'));
5219
- });
5220
- const omeAndFluoroGrid = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Viewer.grid(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromObjects([
5221
- { 'Name': '2\'-fluoro-U', 'BioSpring': '1', 'Axolabs': 'Uf', 'Janssen GCRS': 'fU' },
5222
- { 'Name': '2\'-fluoro-A', 'BioSpring': '2', 'Axolabs': 'Af', 'Janssen GCRS': 'fA' },
5223
- { 'Name': '2\'-fluoro-C', 'BioSpring': '3', 'Axolabs': 'Cf', 'Janssen GCRS': 'fC' },
5224
- { 'Name': '2\'-fluoro-G', 'BioSpring': '4', 'Axolabs': 'Gf', 'Janssen GCRS': 'fG' },
5225
- { 'Name': '2\'OMe-rU', 'BioSpring': '5', 'Axolabs': 'u', 'Janssen GCRS': 'mU' },
5226
- { 'Name': '2\'OMe-rA', 'BioSpring': '6', 'Axolabs': 'a', 'Janssen GCRS': 'mA' },
5227
- { 'Name': '2\'OMe-rC', 'BioSpring': '7', 'Axolabs': 'c', 'Janssen GCRS': 'mC' },
5228
- { 'Name': '2\'OMe-rG', 'BioSpring': '8', 'Axolabs': 'g', 'Janssen GCRS': 'mG' },
5229
- { 'Name': 'ps linkage', 'BioSpring': '*', 'Axolabs': 's', 'Janssen GCRS': 'ps' },
5230
- ]), { showRowHeader: false, showCellTooltip: false });
5231
- const overhangModificationsGrid = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Viewer.grid(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromColumns([
5232
- datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.Column.fromStrings('Name', Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.MODIFICATIONS)),
5233
- ]), { showRowHeader: false, showCellTooltip: false });
5234
- updateTableAndMolecule(defaultInput, inputFormatChoiceInput.value, true);
5235
- const appMainDescription = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.info([
5236
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText('How to convert one sequence:', { style: { 'font-weight': 'bolder' } }),
5237
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText('Paste sequence into the text field below'),
5238
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText('\n How to convert many sequences:', { style: { 'font-weight': 'bolder' } }),
5239
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText('1. Drag & drop an Excel or CSV file with sequences into Datagrok'),
5240
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText('2. Right-click on the column header, then see the \'Convert\' menu'),
5241
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.divText('This will add the result column to the right of the table'),
5242
- ], 'Convert oligonucleotide sequences between Nucleotides, BioSpring, Axolabs, Mermade 12 and GCRS representations.');
5243
- const codesTablesDiv = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.splitV([
5244
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.box(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.h2('ASO Gapmers'), { style: { maxHeight: '40px' } }),
5245
- asoGapmersGrid.root,
5246
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.box(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.h2('2\'-OMe and 2\'-F siRNA'), { style: { maxHeight: '40px' } }),
5247
- omeAndFluoroGrid.root,
5248
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.box(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.h2('Overhang modifications'), { style: { maxHeight: '40px' } }),
5249
- overhangModificationsGrid.root,
5250
- ], { style: { maxWidth: '350px' } });
5251
- const tabControl = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.tabControl({
5252
- 'MAIN': datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.box(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.splitH([
5253
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.splitV([
5254
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.panel([
5255
- appMainDescription,
5256
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([
5257
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.h1('Input sequence'),
5258
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([
5259
- inputSequenceField.root,
5260
- ], 'input-base'),
5261
- ], 'inputSequence'),
5262
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([inputFormatChoiceInput], { style: { padding: '5px 0' } }),
5263
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.block([
5264
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.h1('Output'),
5265
- outputTableDiv,
5266
- ]),
5267
- moleculeSvgDiv,
5268
- ], 'sequence'),
5269
- ]),
5270
- codesTablesDiv,
5271
- ], { style: { height: '100%', width: '100%' } })),
5272
- 'AXOLABS': (0,_defineAxolabsPattern__WEBPACK_IMPORTED_MODULE_5__.defineAxolabsPattern)(),
5273
- 'SDF': (0,_structures_works_save_sense_antisense__WEBPACK_IMPORTED_MODULE_6__.saveSenseAntiSense)(),
5274
- });
5275
- const v = datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.newView('Sequence Translator', [tabControl]);
5276
5541
  v.box = true;
5277
- const switchInput = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.switchInput('Codes', true, (v) => (v) ?
5278
- cash_dom__WEBPACK_IMPORTED_MODULE_4___default()(codesTablesDiv).show() :
5279
- cash_dom__WEBPACK_IMPORTED_MODULE_4___default()(codesTablesDiv).hide());
5280
- const topPanel = [
5281
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.iconFA('download', () => {
5282
- const result = (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_7__.sequenceToMolV3000)(inputSequenceField.value.replace(/\s/g, ''), false, false, inputFormatChoiceInput.value);
5283
- const element = document.createElement('a');
5284
- element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(result));
5285
- element.setAttribute('download', inputSequenceField.value.replace(/\s/g, '') + '.mol');
5286
- element.click();
5287
- }, 'Save .mol file'),
5288
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.iconFA('copy', () => {
5289
- navigator.clipboard.writeText((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_7__.sequenceToSmiles)(inputSequenceField.value.replace(/\s/g, ''), false, inputFormatChoiceInput.value))
5290
- .then(() => datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.info(sequenceWasCopied));
5291
- }, 'Copy SMILES'),
5292
- switchInput.root,
5293
- ];
5294
- tabControl.onTabChanged.subscribe((_) => v.setRibbonPanels([(tabControl.currentPane.name == 'MAIN') ? topPanel : []]));
5295
- v.setRibbonPanels([topPanel]);
5296
- }
5297
- function saveTableAsSdFile(table) {
5298
- return __awaiter(this, void 0, void 0, function* () {
5299
- if (!table.columns.contains('Compound Name')) {
5300
- datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.warning('File saved without columns \'' +
5301
- [_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.COMPOUND_NAME, _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.COMPOUND_COMMENTS, _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.CPD_MW,
5302
- _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.SALT_MASS, _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.BATCH_MW].join('\', \''));
5303
- }
5304
- const structureColumn = table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.SEQUENCE);
5305
- const typeColumn = table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.TYPE);
5306
- let result = '';
5307
- for (let i = 0; i < table.rowCount; i++) {
5308
- const format = (0,_structures_works_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_8__.getFormat)(structureColumn.get(i));
5309
- result += (typeColumn.get(i) == 'SS') ?
5310
- (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_7__.sequenceToMolV3000)(structureColumn.get(i), false, true, format) + '\n' + `> <Sequence>\nSense Strand\n\n` :
5311
- (0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_7__.sequenceToMolV3000)(structureColumn.get(i), true, true, format) + '\n' + `> <Sequence>\nAnti Sense\n\n`;
5312
- for (const col of table.columns) {
5313
- if (col.name != _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.SEQUENCE)
5314
- result += `> <${col.name}>\n${col.get(i)}\n\n`;
5315
- }
5316
- result += '$$$$\n\n';
5317
- }
5318
- const element = document.createElement('a');
5319
- element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(result));
5320
- element.setAttribute('download', table.name + '.sdf');
5321
- element.click();
5322
- });
5323
- }
5324
- const weightsObj = {};
5325
- for (const synthesizer of Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.map)) {
5326
- for (const technology of Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.map[synthesizer])) {
5327
- for (const code of Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.map[synthesizer][technology]))
5328
- (_a = weightsObj[code]) !== null && _a !== void 0 ? _a : _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.map[synthesizer][technology][code].weight;
5329
- }
5330
- }
5331
- for (const [key, value] of Object.entries(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.MODIFICATIONS))
5332
- weightsObj[key] = value.molecularWeight;
5333
- function sortByStringLengthInDescendingOrder(array) {
5334
- return array.sort(function (a, b) { return b.length - a.length; });
5335
- }
5336
- function stringifyItems(items) {
5337
- return '["' + items.join('", "') + '"]';
5338
- }
5339
- function molecularWeight(sequence, weightsObj) {
5340
- const codes = sortByStringLengthInDescendingOrder(Object.keys(weightsObj)).concat(Object.keys(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.MODIFICATIONS));
5341
- let weight = 0;
5342
- let i = 0;
5343
- while (i < sequence.length) {
5344
- const matchedCode = codes.find((s) => s == sequence.slice(i, i + s.length));
5345
- weight += weightsObj[sequence.slice(i, i + matchedCode.length)];
5346
- i += matchedCode.length;
5347
- }
5348
- return weight - 61.97;
5349
5542
  }
5350
5543
  //tags: autostart
5351
- function autostartOligoSdFileSubscription() {
5352
- datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.events.onViewAdded.subscribe((v) => {
5353
- if (v.type == 'TableView' && v.dataFrame.columns.contains(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.TYPE))
5354
- oligoSdFile(v.dataFrame);
5355
- });
5356
- }
5357
- function oligoSdFile(table) {
5358
- const saltsDf = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromCsv(_salts__WEBPACK_IMPORTED_MODULE_10__.SALTS_CSV);
5359
- const usersDf = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromCsv(_users__WEBPACK_IMPORTED_MODULE_11__.USERS_CSV);
5360
- const sourcesDf = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromCsv(_sources__WEBPACK_IMPORTED_MODULE_13__.SOURCES);
5361
- const icdsDf = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromCsv(_ICDs__WEBPACK_IMPORTED_MODULE_12__.ICDS);
5362
- const idpsDf = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.DataFrame.fromCsv(_IDPs__WEBPACK_IMPORTED_MODULE_14__.IDPS);
5363
- function addColumns(t, saltsDf) {
5364
- if (t.columns.contains(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.COMPOUND_NAME))
5365
- return datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.error('Columns already exist!');
5366
- const sequence = t.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.SEQUENCE);
5367
- const salt = t.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.SALT);
5368
- const equivalents = t.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.EQUIVALENTS);
5369
- t.columns.addNewString(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.COMPOUND_NAME).init((i) => sequence.get(i));
5370
- t.columns.addNewString(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.COMPOUND_COMMENTS).init((i) => (i > 0 && i % 2 == 0) ?
5371
- sequence.getString(i) + '; duplex of SS: ' + sequence.getString(i - 2) + ' and AS: ' + sequence.getString(i - 1) :
5372
- sequence.getString(i));
5373
- const molWeightCol = saltsDf.col('MOLWEIGHT');
5374
- const saltNamesList = saltsDf.col('DISPLAY').toList();
5375
- t.columns.addNewFloat(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.CPD_MW)
5376
- .init((i) => molecularWeight(sequence.get(i), weightsObj));
5377
- t.columns.addNewFloat(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.SALT_MASS).init((i) => {
5378
- const saltRowIndex = saltNamesList.indexOf(salt.get(i));
5379
- const mw = molWeightCol.get(saltRowIndex);
5380
- return mw * equivalents.get(i);
5381
- });
5382
- t.columns.addNewCalculated(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.BATCH_MW, '${' + _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.CPD_MW + '} + ${' + _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.SALT_MASS + '}', datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.COLUMN_TYPE.FLOAT, false);
5383
- addColumnsPressed = true;
5384
- return newDf = t;
5385
- }
5386
- let newDf;
5387
- let addColumnsPressed = false;
5388
- const d = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.div([
5389
- datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.icons.edit(() => {
5390
- d.innerHTML = '';
5391
- if (table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.IDP).type != datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.COLUMN_TYPE.STRING)
5392
- table.changeColumnType(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.IDP, datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.COLUMN_TYPE.STRING);
5393
- d.append(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.link('Add Columns', () => {
5394
- addColumns(table, saltsDf);
5395
- datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.tableView(table.name).grid.columns.setOrder(Object.values(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES));
5396
- }, 'Add columns: \'' + [_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.COMPOUND_NAME, _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.COMPOUND_COMMENTS, _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.CPD_MW,
5397
- _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.SALT_MASS, _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.BATCH_MW].join('\', \''), ''), datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.button('Save SD file', () => saveTableAsSdFile(addColumnsPressed ? newDf : table)));
5398
- const view = datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.getTableView(table.name);
5399
- view.table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.TYPE).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, '["AS", "SS", "Duplex"]');
5400
- view.table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.OWNER).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, stringifyItems(usersDf.columns.byIndex(0).toList()));
5401
- view.table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.SALT).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, stringifyItems(saltsDf.columns.byIndex(0).toList()));
5402
- view.table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.SOURCE).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, stringifyItems(sourcesDf.columns.byIndex(0).toList()));
5403
- view.table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.ICD).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, stringifyItems(icdsDf.columns.byIndex(0).toList()));
5404
- view.table.col(_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.IDP).setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_2__.TAGS.CHOICES, stringifyItems(idpsDf.columns.byIndex(0).toList()));
5405
- datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.events.onContextMenu.subscribe((args) => {
5406
- if ([_structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.TYPE, _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.OWNER, _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.SALT, _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.SOURCE, _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.ICD, _structures_works_map__WEBPACK_IMPORTED_MODULE_9__.COL_NAMES.IDP]
5407
- .includes(args.args.context.table.currentCol.name)) {
5408
- args.args.menu.item('Fill Column With Value', () => {
5409
- const v = args.args.context.table.currentCell.value;
5410
- args.args.context.table.currentCell.column.init(v);
5411
- });
5412
- }
5413
- });
5414
- }),
5415
- ]);
5416
- datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.v.setRibbonPanels([[d]]);
5417
- }
5544
+ (0,_autostart_registration__WEBPACK_IMPORTED_MODULE_3__.autostartOligoSdFileSubscription)();
5418
5545
 
5419
5546
  })();
5420
5547
 
5421
5548
  sequencetranslator = __webpack_exports__;
5422
5549
  /******/ })()
5423
5550
  ;
5424
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"package.js","mappings":";;;;;;;;;;AAAA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;;AAErB;AACA;AACA,EAAE;AACF;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN,mCAAmC;AACnC;;AAEA;AACA;;AAEA,qCAAqC,OAAO;AAC5C;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA,+BAA+B;;AAE/B;AACA,oBAAoB;;AAEpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA,GAAG;;;AAGH;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA,eAAe;;AAEf;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;;AAEA,qCAAqC,OAAO;AAC5C;AACA;AACA;AACA,IAAI;AACJ,oCAAoC,OAAO;AAC3C;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;;AAEA,mBAAmB,uBAAuB;AAC1C;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,kBAAkB,YAAY;AAC9B;;AAEA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA,GAAG;AACH;;;AAGA;AACA;AACA;AACA,IAAI;AACJ;AACA,IAAI;AACJ;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH,GAAG;;;AAGH;AACA;AACA,EAAE;;;AAGF;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,kCAAkC,OAAO;AACzC;AACA;AACA;AACA,MAAM;AACN;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;AAEA;AACA;AACA,GAAG;AACH;;;AAGA;AACA;AACA;AACA;AACA,EAAE;;;AAGF;AACA;AACA;;AAEA,2BAA2B;;AAE3B;AACA;AACA,EAAE;AACF;AACA;AACA;AACA;;;AAGA,sBAAsB;AACtB;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;AAEA,EAAE;AACF;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,QAAQ;AACR;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,cAAc;AACd;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,EAAE;AACF;;;AAGA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,gBAAgB;;AAEhB;AACA;AACA;AACA,EAAE;;;AAGF;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH,CAAC;AACD;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,CAAC,GAAG;AACJ;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAE;;;AAGF;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;;AAGA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD;AACA;AACA;AACA,CAAC;AACD,8EAA8E;;AAE9E;AACA;AACA,EAAE;;;AAGF;AACA;AACA,EAAE;AACF;;;AAGA;AACA;AACA;AACA;AACA;AACA,EAAE;;;AAGF;AACA;AACA,4CAA4C;AAC5C,EAAE;AACF;AACA;;;AAGA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL,IAAI;AACJ;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA,wFAAwF;;AAExF;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,8BAA8B;AAC9B;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,uCAAuC;;AAEvC;;AAEA,wCAAwC;AACxC;;AAEA;AACA,GAAG;AACH,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT,QAAQ;AACR;AACA;AACA,MAAM;AACN;AACA;AACA,GAAG;AACH;;AAEA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA,GAAG;AACH,GAAG;AACH;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,GAAG;AACH,EAAE;;;AAGF;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA,EAAE;;;AAGF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL,GAAG;AACH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA,IAAI,IAA8B;AAClC;AACA;AACA,EAAE,KAAK,EAGN;AACD,CAAC;;;;;;;;;;;AC71CD,gEAAa;;AAEb;AACA,aAAa,KAA6B,eAAe,KAA4B,OAAO;AAC5F,MAAM,IAA6B,EAAE,iCAA0B,EAAE,mCAAE;AACnE;AACA,GAAG;AAAA,kGAAC;AACJ;;AAEA;AACA;AACA;AACA,8KAA8K;AAC9K;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,mFAAmF;AACnF;AACA;AACA;AACA,qCAAqC,iEAAiE;AACtG,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,2EAA2E,EAAE;AAC7E;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA,6DAA6D;AAC7D;AACA;AACA,oBAAoB,uBAAuB;AAC3C;AACA;AACA,gCAAgC,kBAAkB;AAClD;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mFAAmF;AACnF;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB,QAAQ;AACR;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA,4BAA4B;AAC5B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,qBAAqB,cAAc;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,yGAAyG;AACzG;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA,OAAO;AACP,KAAK;;AAEL;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA,eAAe;AACf;AACA;;AAEA;AACA;;AAEA,6BAA6B;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,kDAAkD;;AAElD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;;AAEA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA,iEAAiE,cAAc;AAC/E,QAAQ;AACR;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,mEAAmE,cAAc;AACjF,SAAS;AACT;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,uCAAuC;AACvC;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;AAEA,6BAA6B;AAC7B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,oCAAoC;;AAEpC;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA,sEAAsE;AACtE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA,qFAAqF;AACrF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;;AAEA;AACA,0CAA0C;AAC1C;AACA,gDAAgD;AAChD,KAAK;AACL;AACA,KAAK;AACL;;AAEA;AACA,0CAA0C;AAC1C;AACA,+CAA+C;AAC/C,KAAK;AACL;AACA,KAAK;AACL;AACA,CAAC;;;;;;;;;;;;;;;AC5bM;AACP;AACA;;;;;;;;;;;;;;;;ACFO;AACP;AACA;;;;;;;;;;;;;;;;ACFA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;;;;;;;;;;;;;;;;;;;;;;;;;;;;AClGA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACA;AAC0C;AACJ;AACA;AACtC;AACuC;AACd;AACiC;AAChB;AAC1C,gCAAgC,mDAAU;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,mDAAU;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,iEAAuB;AAC5C;AACA;AACA,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA,oBAAoB,wBAAwB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,wBAAwB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,uEAAoC;AAClE,uBAAuB,mDAAU;AACjC;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,0DAAgB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,0DAAgB;AACpC;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,oBAAoB;AAC5C,+BAA+B,sDAAY;AAC3C;AACA;AACA,aAAa;AACb,yBAAyB,wDAAc;AACvC;AACA;AACA,uDAAuD,sDAAY;AACnE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,uCAAuC,iDAAO;AAC9C,gBAAgB,gDAAM,EAAE,kDAAQ,2EAA2E,SAAS,iBAAiB;AACrI,gBAAgB,oDAAU;AAC1B,gBAAgB,gDAAM;AACtB,iBAAiB,SAAS,wBAAwB;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,oBAAoB;AAC5C,+BAA+B,sDAAY;AAC3C;AACA;AACA,aAAa;AACb,yBAAyB,wDAAc;AACvC;AACA;AACA,uDAAuD,sDAAY;AACnE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,uCAAuC,iDAAO;AAC9C,gBAAgB,gDAAM,EAAE,kDAAQ,2EAA2E,SAAS,iBAAiB;AACrI,gBAAgB,oDAAU;AAC1B,gBAAgB,gDAAM;AACtB,iBAAiB,SAAS,wBAAwB;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,mDAAS;AACrB,qBAAqB,oDAAU;AAC/B;AACA,qBAAqB,oDAAU;AAC/B;AACA;AACA;AACA;AACA,wBAAwB,0BAA0B;AAClD;AACA,wBAAwB,0BAA0B;AAClD;AACA;AACA;AACA;AACA,wBAAwB,oBAAoB;AAC5C;AACA,wBAAwB,oBAAoB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,iDAAO;AAC7B,YAAY,uEAAkB;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,kBAAkB;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,4EAAkC;AACzD,kBAAkB,uEAA6B;AAC/C;AACA;AACA;AACA;AACA;AACA,gCAAgC,2BAA2B;AAC3D,iCAAiC,wDAAc;AAC/C;AACA,gCAAgC,2BAA2B;AAC3D,iCAAiC,wDAAc;AAC/C;AACA;AACA,gCAAgC,iCAAiC;AACjE,uCAAuC,sDAAY;AACnD;AACA;AACA,gCAAgC,iCAAiC;AACjE,uCAAuC,sDAAY;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,mDAAS;AACpC,YAAY,+CAAC;AACb;AACA,qBAAqB,oDAAU;AAC/B,qBAAqB,oDAAU;AAC/B;AACA;AACA,gBAAgB,yDAAe;AAC/B;AACA,gBAAgB,sDAAY,GAAG,iEAAuB;AACtD,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB,iEAAuB;AAChD;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,6EAAmC;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,qBAAqB,yDAAe;AACjD,SAAS;AACT;AACA;AACA;AACA,YAAY,uEAA6B;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,wDAAc;AAChD,8CAA8C,wDAAc;AAC5D;AACA,kCAAkC,wDAAc;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,gDAAM;AAClD,wBAAwB,mDAAS,CAAC,mDAAS,uBAAuB;AAClE;AACA,gCAAgC,4DAAkB;AAClD;AACA,gCAAgC,4DAAkB;AAClD;AACA,sCAAsC,0EAAgC;AACtE,gDAAgD,yDAAe;AAC/D;AACA;AACA,yBAAyB;AACzB;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,gDAAM;AAC9C,oBAAoB,mDAAS,CAAC,mDAAS,uBAAuB;AAC9D;AACA,4BAA4B,4DAAkB;AAC9C;AACA,4BAA4B,4DAAkB;AAC9C;AACA,kCAAkC,0EAAgC;AAClE,4CAA4C,yDAAe;AAC3D;AACA;AACA,qBAAqB;AACrB;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA,kBAAkB,uEAA6B;AAC/C;AACA;AACA,mCAAmC,mDAAS;AAC5C,oBAAoB,+CAAC;AACrB;AACA,6BAA6B,oDAAU;AACvC,6BAA6B,oDAAU;AACvC;AACA,8BAA8B,0EAAgC;AAC9D;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,SAAS;AACT;AACA,6BAA6B,gDAAM;AACnC,6BAA6B,gDAAM;AACnC,6BAA6B,gDAAM;AACnC,gCAAgC,gDAAM;AACtC,gCAAgC,gDAAM;AACtC,mBAAmB,gDAAM;AACzB,yBAAyB,gDAAM;AAC/B,kCAAkC,gDAAM;AACxC,2BAA2B,gDAAM;AACjC,8BAA8B,gDAAM;AACpC,0BAA0B,gDAAM;AAChC,wCAAwC,iDAAO,EAAE,sDAAY;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,oDAAoD,wDAAc;AAClE,oDAAoD,wDAAc;AAClE,0DAA0D,sDAAY;AACtE,0DAA0D,sDAAY;AACtE,qBAAqB,qDAAW;AAChC,qBAAqB,qDAAW;AAChC,wBAAwB,gDAAM;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,qDAAW;AACnC,YAAY,0DAAgB;AAC5B;AACA;AACA,YAAY,mDAAS;AACrB,qBAAqB,oDAAU;AAC/B;AACA;AACA;AACA,gBAAgB,sDAAY,GAAG,iEAAuB;AACtD,gBAAgB,yDAAe;AAC/B,aAAa;AACb;AACA;AACA;AACA,mBAAmB,uDAAa,WAAW,8DAAoB,EAAE,2DAAiB;AAClF,8BAA8B,wDAAc;AAC5C;AACA;AACA,8BAA8B,wDAAc;AAC5C;AACA;AACA,8BAA8B,wDAAc;AAC5C;AACA;AACA,KAAK;AACL,0BAA0B,wDAAc;AACxC;AACA,0BAA0B,wDAAc;AACxC;AACA,0BAA0B,wDAAc;AACxC;AACA;AACA,yBAAyB,wDAAc;AACvC;AACA;AACA,KAAK;AACL,qBAAqB,sDAAY;AACjC;AACA;AACA;AACA;AACA,KAAK;AACL,uBAAuB,sDAAY;AACnC,uBAAuB,sDAAY;AACnC;AACA,2BAA2B,sDAAY;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,mBAAmB,sDAAY;AAC/B;AACA,gCAAgC,wDAAc;AAC9C;AACA;AACA,KAAK;AACL;AACA,+BAA+B,wDAAc;AAC7C;AACA;AACA,KAAK;AACL;AACA,gCAAgC,wDAAc;AAC9C;AACA;AACA,KAAK;AACL;AACA,+BAA+B,wDAAc;AAC7C;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,oBAAoB,sDAAY;AAChC,8BAA8B,mDAAS;AACvC;AACA,sCAAsC,yDAAe;AACrD;AACA,yBAAyB,wDAAc;AACvC,YAAY,mDAAS;AACrB;AACA;AACA;AACA,0CAA0C,yDAAe;AACzD,aAAa;AACb;AACA;AACA,KAAK;AACL,kCAAkC,mDAAS;AAC3C;AACA,YAAY,yDAAe;AAC3B;AACA,2BAA2B,mDAAS;AACpC,YAAY,+CAAC;AACb;AACA,qBAAqB,oDAAU;AAC/B;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,sDAAY,GAAG,iEAAuB;AAClD,YAAY,yDAAe;AAC3B;AACA;AACA,KAAK;AACL,2BAA2B,sDAAY;AACvC;AACA,KAAK;AACL,4BAA4B,sDAAY;AACxC;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,gDAAM;AACtC,QAAQ,mDAAS,CAAC,mDAAS,kBAAkB;AAC7C,4EAA4E,yDAAe;AAC3F,SAAS;AACT;AACA,2BAA2B,sDAAY;AACvC;AACA,KAAK;AACL,4BAA4B,sDAAY;AACxC;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,gDAAM;AACtC,QAAQ,mDAAS,CAAC,mDAAS,kBAAkB;AAC7C,4EAA4E,yDAAe;AAC3F,SAAS;AACT;AACA;AACA;AACA;AACA,2BAA2B,gDAAM;AACjC,QAAQ,+CAAK;AACb;AACA;AACA;AACA;AACA,0BAA0B,gDAAM;AAChC,QAAQ,+CAAK;AACb,QAAQ,iDAAO;AACf;AACA;AACA;AACA,QAAQ,iDAAO;AACf;AACA;AACA;AACA,QAAQ,yDAAe;AACvB;AACA;AACA;AACA,wBAAwB,kDAAQ;AAChC,QAAQ,kDAAQ;AAChB;AACA,aAAa,SAAS,uBAAuB;AAC7C,QAAQ,mDAAS,mBAAmB,yDAAgB;AACpD;AACA,QAAQ,gDAAM;AACd,YAAY,gDAAM;AAClB,gBAAgB,iDAAO;AACvB,oBAAoB,+CAAK;AACzB,oBAAoB,gDAAM;AAC1B,wBAAwB,mDAAS;AACjC;AACA;AACA,yBAAyB;AACzB,yBAAyB,SAAS,kBAAkB;AACpD;AACA,gBAAgB,iDAAO;AACvB,oBAAoB,gDAAM;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,yDAAe;AACvC;AACA;AACA;AACA,oBAAoB,gDAAM;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,SAAS,oBAAoB;AAC1C;AACA,kCAAkC,kDAAQ;AAC1C,QAAQ,+CAAK;AACb,QAAQ,iDAAO;AACf,YAAY,gDAAM,EAAE,oDAAU,UAAU,SAAS,iBAAiB;AAClE,YAAY,oDAAU,EAAE,oDAAU;AAClC,YAAY,gDAAM,EAAE,oDAAU,YAAY,SAAS,uBAAuB;AAC1E;AACA;AACA;AACA,kCAAkC,kDAAQ;AAC1C,QAAQ,+CAAK;AACb,QAAQ,iDAAO;AACf,YAAY,gDAAM,EAAE,oDAAU,UAAU,SAAS,iBAAiB;AAClE,YAAY,oDAAU,EAAE,oDAAU;AAClC,YAAY,gDAAM,EAAE,oDAAU,YAAY,SAAS,uBAAuB;AAC1E;AACA;AACA;AACA,iBAAiB,iDAAO;AACxB,QAAQ,oDAAU,oCAAoC,SAAS,2BAA2B;AAC1F,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB;AACA,WAAW,mDAAS;AACpB,QAAQ,gDAAM;AACd;AACA;AACA;AACA,QAAQ,gDAAM,CAAC,iDAAO;AACtB;AACA;AACA,cAAc,SAAS,qBAAqB;AAC5C;AACA;;;;;;;;;;;;;;;;;ACvsB0C;AAC1C;AACA;AACA,iCAAiC;AACjC;AACA,qCAAqC;AACrC;AACA;AACA;AACA,uDAAuD;AACvD;AACA,oBAAoB,yBAAyB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,mDAAU;AACrB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,oBAAoB;AACxC;AACA;AACA;AACA;AACA,qCAAqC,QAAQ;AAC7C;AACA;AACA;AACA,iLAAiL,mDAAU;AAC3L;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,oBAAoB;AACxC;AACA;AACA;AACA;AACA;AACA,yCAAyC,QAAQ;AACjD;AACA;AACA;AACA,gJAAgJ,mDAAU;AAC1J;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,wBAAwB;AAC5C;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;ACvLO;AACP;;;;;;;;;;;;;;;;ACDO;AACP;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACFmC;AACG;AACtC;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,eAAe,8DAAoB,CAAC,4CAAU;AAC9C;AACA;AACA;AACA;AACA,oBAAoB,iBAAiB;AACrC;AACA;AACA;AACA;AACA,sDAAsD,mBAAmB;AACzE;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA;AACA;AACA;AACA;AACA,2BAA2B;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,gGAAgG,gBAAgB;AAChH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,2HAA2H,gBAAgB;AAC3I;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,iGAAiG,gBAAgB;AACjH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,8BAA8B;AAC9B;AACA,+BAA+B;AAC/B;AACA,gCAAgC;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,8BAA8B;AAC9B;AACA,gCAAgC;AAChC;AACA,+BAA+B;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,gCAAgC;AAChC;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,kCAAkC;AAClC;AACA,gCAAgC;AAChC;AACA,gCAAgC;AAChC;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA;AACA,mJAAmJ,gBAAgB;AACnK;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA;AACA,mJAAmJ,gBAAgB;AACnK;;;;;;;;;;;;;;;;;;;;AC1RmG;AAC1C;AACC;AACnD;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,+CAAa;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA,gBAAgB,+CAAa,uBAAuB,+CAAa;AACjE,6BAA6B,4DAA0B;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,4DAA0B;AAC3D;AACA;AACA;AACA,WAAW,uEAAiB;AAC5B;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,+CAAa;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA,gBAAgB,+CAAa,uBAAuB,4DAA0B;AAC9E,gBAAgB,+CAAa,sBAAsB,4DAA0B;AAC7E;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,4DAA0B;AACxE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,mEAAiC;AACzE;AACA;AACA;AACA;AACA,8CAA8C,qCAAG;AACjD,iDAAiD,qCAAG;AACpD,+CAA+C,qCAAG;AAClD,gCAAgC,qCAAG;AACnC;AACA;AACA;AACA;AACA,6CAA6C,qCAAG;AAChD,2CAA2C,qCAAG;AAC9C,4BAA4B,qCAAG;AAC/B;AACA;AACA;AACA,mBAAmB,sEAAe;AAClC,oCAAoC,yDAAuB;AAC3D,mBAAmB,qCAAG,CAAC,yDAAuB,EAAE,qDAAmB;AACnE,yCAAyC,sDAAoB;AAC7D,mBAAmB,qCAAG,CAAC,sDAAoB,EAAE,qDAAmB;AAChE;AACA;AACA;AACA,wCAAwC,6BAA6B;AACrE;;;;;;;;;;;;;;;;;;;;;;;;;;ACtGsC;AAC4B;AAC3D;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACO;AACA;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,oBAAoB;AACpB,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,+EAAwB;AAChD,qBAAqB,8DAAoB;AAClC;AACP;AACA,4CAA4C;;;;;;;;;;;;;;;;;;;AChtBD;AAC3C;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,oBAAoB,4BAA4B;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,0BAA0B;AACtD;AACA,4BAA4B,0BAA0B;AACtD;AACA;AACA,oEAAoE;AACpE;AACA;AACA;AACA,wBAAwB,mBAAmB;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oEAAoE;AACpE;AACA;AACA;AACA,wBAAwB,mBAAmB;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oFAAoF;AACpF;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,uBAAuB;AAC/C;AACA;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA,4BAA4B,oBAAoB;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D,oEAAuB;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA,uDAAuD;AACvD;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D,oEAAuB;AACnF;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA,uDAAuD;AACvD;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C;AAC9C,gDAAgD;AAChD;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,uDAAuD;AACvD;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;;;;;;;;;;;;;;;;;;;;;;ACtXsC;AACiC;AACH;AACC;AAC9D;AACP,qBAAqB,iFAAS;AAC9B,qBAAqB,iFAAS;AAC9B,kBAAkB,mFAAkB;AACpC,kBAAkB,mFAAkB;AACpC;AACA;AACA,iBAAiB,gFAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kDAAkD;AAClD;AACA;AACA;AACO;AACP,2BAA2B,kDAAQ;AACnC,oBAAoB,sDAAY;AAChC,oBAAoB,sDAAY;AAChC,uBAAuB,wDAAc;AACrC,oBAAoB,wDAAc;AAClC,oBAAoB,mDAAS;AAC7B,wBAAwB,kDAAQ;AAChC,QAAQ,gDAAM;AACd,YAAY,gDAAM;AAClB,gBAAgB,iDAAO,EAAE,+CAAK;AAC9B,gBAAgB,iDAAO;AACvB,oBAAoB,gDAAM;AAC1B,oBAAoB,gDAAM;AAC1B;AACA;AACA,oBAAoB,yDAAe;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;AC/CuE;AACqf;AAC5jB;AACO;AACA;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,qCAAG;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,QAAQ,oBAAoB;AAC1E;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA,SAAS;AACT;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,QAAQ,oBAAoB;AACzE;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA,SAAS;AACT;AACA,iBAAiB;AACjB;AACA;AACA,kCAAkC,qCAAG;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,yCAAyC,qCAAG;AAC5C,yCAAyC,qCAAG;AAC5C,oCAAoC,+CAAa;AACjD;AACA;AACA;AACA,gBAAgB,qCAAG;AACnB;AACA;AACA;AACA,wBAAwB,qBAAqB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,gBAAgB,qCAAG;AACnB,kCAAkC,qCAAG,8CAA8C,+CAAa;AAChG;AACA;AACA,KAAK;AACL;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,8DAA4B,KAAK;AACrE;AACA,kBAAkB,8DAA4B;AAC9C;AACA,uBAAuB,6EAAgC;AACvD,kBAAkB,wEAA2B;AAC7C;AACA;AACA,oCAAoC,wDAAsB,gCAAgC,0DAAwB;AAClH;AACA,kBAAkB,wDAAsB,SAAS,0DAAwB;AACzE,yBAAyB,6EAAgC;AACzD;AACA,kBAAkB,sEAAyB;AAC3C;AACA;AACA,oCAAoC,mDAAiB,gCAAgC,0DAAwB;AAC7G;AACA,kBAAkB,mDAAiB,SAAS,0DAAwB;AACpE,yBAAyB,wEAA2B;AACpD,uBAAuB,sEAAyB;AAChD,uBAAuB,4DAAe;AACtC;AACA,kBAAkB,uDAAU;AAC5B;AACA;AACA,oCAAoC,8DAA4B,gCAAgC,kDAAgB;AAChH;AACA,kBAAkB,8DAA4B,SAAS,kDAAgB;AACvE;AACA,uBAAuB,kFAAqC;AAC5D,qBAAqB,gFAAmC;AACxD,kBAAkB,mEAAsB;AACxC;AACA;AACA,oCAAoC,wDAAsB,gCAAgC,qDAAmB;AAC7G;AACA,kBAAkB,wDAAsB,SAAS,qDAAmB;AACpE,yBAAyB,wEAA2B;AACpD;AACA,qBAAqB,oEAAuB;AAC5C,kBAAkB,iEAAoB;AACtC;AACA;AACA,oCAAoC,sDAAoB;AACxD;AACA,kBAAkB,sDAAoB,SAAS,qDAAmB;AAClE,yBAAyB,sEAAyB;AAClD,uBAAuB,oEAAuB;AAC9C;AACA,kBAAkB,+DAAkB;AACpC;AACA;AACA,oCAAoC,mDAAiB,gCAAgC,qDAAmB;AACxG;AACA,kBAAkB,mDAAiB,SAAS,qDAAmB;AAC/D,yBAAyB,mEAAsB;AAC/C,uBAAuB,iEAAoB;AAC3C,qBAAqB,+DAAkB;AACvC,kBAAkB,4DAAe;AACjC;AACA,kBAAkB,uDAAU;AAC5B;AACA;AACA,oCAAoC,mDAAiB;AACrD;AACA,kBAAkB,mDAAiB;AACnC,yBAAyB,8DAAiB;AAC1C;AACA,uBAAuB,4DAAe;AACtC,kBAAkB,uDAAU;AAC5B;AACA;AACA,oCAAoC,yDAAuB;AAC3D;AACA,kBAAkB,yDAAuB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;ACpRO;AACP;AACA;;;;;;;;;;;;ACFA;;;;;;;;;;;ACAA;;;;;;;;;;;ACAA;;;;;;;;;;;ACAA;;;;;;UCAA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;WACA;WACA;WACA;WACA;WACA,iCAAiC,WAAW;WAC5C;WACA;;;;;WCPA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA;;;;;WCPA;;;;;WCAA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACNA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACA;AACA;AAC0C;AACJ;AACA;AACK;AAClB;AACqC;AACe;AACW;AACsC;AACvD;AACnC;AACA;AACN;AACM;AACN;AACvB,qBAAqB,oDAAU;AACtC;AACA;AACA;AACA;AACA;AACO;AACP,oBAAoB,4DAAkB;AACtC;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,4EAAkC;AACrD;AACA;AACA;AACA,2BAA2B,uFAAe;AAC1C;AACA;AACA;AACA,sCAAsC,uFAAe;AACrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,iDAAO;AAC/B,4BAA4B,oDAAU,gDAAgD,SAAS,iBAAiB;AAChH,4BAA4B,yDAAe,CAAC,oDAAU,6CAA6C,SAAS,gBAAgB;AAC5H;AACA;AACA,wBAAwB,iDAAO;AAC/B,wCAAwC,yDAAe;AACvD,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA,6DAA6D,kCAAkC;AAC/F,+DAA+D,kCAAkC;AACjG;AACA,kCAAkC,gDAAM;AACxC,gBAAgB,6DAAmB;AACnC;AACA,0CAA0C,0FAAsB,+BAA+B,0FAAsB;AACrH,+BAA+B,mDAAS;AACxC;AACA,iCAAiC,mDAAS,CAAC,+CAAC,kBAAkB,+CAAC;AAC/D,gCAAgC,mFAAkB;AAClD;AACA,oBAAoB,2EAA8B,OAAO,qEAAwB,SAAS,0BAA0B;AACpH,oBAAoB,mDAAS;AAC7B;AACA;AACA,iBAAiB;AACjB,gBAAgB,+CAAC,+BAA+B,+CAAC;AACjD,gBAAgB,+CAAC,8BAA8B,+CAAC;AAChD,4BAA4B,mFAAkB;AAC9C;AACA,gBAAgB,2EAA8B,SAAS,qEAAwB,SAAS,0BAA0B;AAClH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,wDAAc,qDAAqD,sDAAG;AACzG;AACA,KAAK;AACL,2BAA2B,kDAAQ;AACnC,2BAA2B,gDAAM;AACjC,+BAA+B,sDAAY;AAC3C,kBAAkB,kEAAwB;AAC1C,UAAU,mEAAmE;AAC7E,UAAU,+DAA+D;AACzE,UAAU,qEAAqE;AAC/E,UAAU,+DAA+D;AACzE,UAAU,gEAAgE;AAC1E,UAAU,8DAA8D;AACxE,UAAU,yDAAyD;AACnE,UAAU,yDAAyD;AACnE,UAAU,yDAAyD;AACnE,UAAU,yDAAyD;AACnE,UAAU,qDAAqD;AAC/D,UAAU,qDAAqD;AAC/D,UAAU,qDAAqD;AAC/D,UAAU,qDAAqD;AAC/D;AACA,2BAA2B,wDAAc,UAAU,8CAA8C;AACjG;AACA,0EAA0E,yDAAe;AACzF,KAAK;AACL,6BAA6B,wDAAc,CAAC,kEAAwB;AACpE,UAAU,iFAAiF;AAC3F,UAAU,iFAAiF;AAC3F,UAAU,iFAAiF;AAC3F,UAAU,iFAAiF;AAC3F,UAAU,6EAA6E;AACvF,UAAU,6EAA6E;AACvF,UAAU,6EAA6E;AACvF,UAAU,6EAA6E;AACvF,UAAU,8EAA8E;AACxF,UAAU,8CAA8C;AACxD,sCAAsC,wDAAc,CAAC,kEAAwB;AAC7E,QAAQ,+DAAqB,qBAAqB,gEAAa;AAC/D,UAAU,8CAA8C;AACxD;AACA,+BAA+B,iDAAO;AACtC,QAAQ,oDAAU,mCAAmC,SAAS,2BAA2B;AACzF,QAAQ,oDAAU;AAClB,QAAQ,oDAAU,wCAAwC,SAAS,2BAA2B;AAC9F,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB;AACA,2BAA2B,mDAAS;AACpC,QAAQ,gDAAM,CAAC,+CAAK,mBAAmB,SAAS,qBAAqB;AACrE;AACA,QAAQ,gDAAM,CAAC,+CAAK,+BAA+B,SAAS,qBAAqB;AACjF;AACA,QAAQ,gDAAM,CAAC,+CAAK,8BAA8B,SAAS,qBAAqB;AAChF;AACA,SAAS,SAAS,qBAAqB;AACvC,uBAAuB,uDAAa;AACpC,gBAAgB,gDAAM,CAAC,mDAAS;AAChC,YAAY,mDAAS;AACrB,gBAAgB,kDAAQ;AACxB;AACA,oBAAoB,gDAAM;AAC1B,wBAAwB,+CAAK;AAC7B,wBAAwB,gDAAM;AAC9B;AACA;AACA;AACA,oBAAoB,gDAAM,6BAA6B,SAAS,oBAAoB;AACpF,oBAAoB,kDAAQ;AAC5B,wBAAwB,+CAAK;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,SAAS,iCAAiC;AACvD,mBAAmB,2EAAoB;AACvC,eAAe,0FAAkB;AACjC,KAAK;AACL,cAAc,4DAAkB;AAChC;AACA,wBAAwB,wDAAc;AACtC,QAAQ,+CAAC;AACT,QAAQ,+CAAC;AACT;AACA,QAAQ,mDAAS;AACjB,2BAA2B,mFAAkB;AAC7C;AACA,0DAA0D;AAC1D;AACA;AACA,SAAS;AACT,QAAQ,mDAAS;AACjB,0CAA0C,iFAAgB;AAC1D,4BAA4B,yDAAe;AAC3C,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,4DAAkB;AAC9B,iBAAiB,0EAAuB,EAAE,8EAA2B,EAAE,mEAAgB;AACvF,oBAAoB,sEAAmB,EAAE,qEAAkB;AAC3D;AACA,0CAA0C,qEAAkB;AAC5D,qCAAqC,iEAAc;AACnD;AACA,wBAAwB,oBAAoB;AAC5C,2BAA2B,iFAAS;AACpC;AACA,gBAAgB,mFAAkB;AAClC,gBAAgB,mFAAkB;AAClC;AACA,gCAAgC,qEAAkB;AAClD,qCAAqC,SAAS,KAAK,WAAW;AAC9D;AACA;AACA;AACA;AACA,sDAAsD;AACtD;AACA;AACA,KAAK;AACL;AACA;AACA,sCAAsC,sDAAG;AACzC,yCAAyC,sDAAG;AAC5C,uCAAuC,sDAAG;AAC1C,qEAAqE,sDAAG;AACxE;AACA;AACA,0CAA0C,gEAAa;AACvD;AACA;AACA,wCAAwC,6BAA6B;AACrE;AACA;AACA;AACA;AACA;AACA,kGAAkG,gEAAa;AAC/G;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP,IAAI,2EAAiC;AACrC,kEAAkE,iEAAc;AAChF;AACA,KAAK;AACL;AACO;AACP,oBAAoB,8DAAoB,CAAC,8CAAS;AAClD,oBAAoB,8DAAoB,CAAC,8CAAS;AAClD,sBAAsB,8DAAoB,CAAC,8CAAO;AAClD,mBAAmB,8DAAoB,CAAC,wCAAI;AAC5C,mBAAmB,8DAAoB,CAAC,wCAAI;AAC5C;AACA,+BAA+B,0EAAuB;AACtD,mBAAmB,0DAAgB;AACnC,+BAA+B,qEAAkB;AACjD,2BAA2B,iEAAc;AACzC,kCAAkC,wEAAqB;AACvD,+BAA+B,0EAAuB;AACtD,+BAA+B,8EAA2B;AAC1D,uCAAuC;AACvC;AACA;AACA;AACA,8BAA8B,mEAAgB;AAC9C;AACA,8BAA8B,sEAAmB;AACjD;AACA;AACA;AACA,SAAS;AACT,mCAAmC,qEAAkB,KAAK,IAAI,mEAAgB,MAAM,IAAI,IAAI,sEAAmB,KAAK,GAAG,8DAAoB;AAC3I;AACA;AACA;AACA;AACA;AACA,cAAc,gDAAM;AACpB,QAAQ,uDAAa;AACrB;AACA,0BAA0B,gEAAa,UAAU,+DAAqB;AACtE,uCAAuC,gEAAa,EAAE,+DAAqB;AAC3E,qBAAqB,iDAAO;AAC5B;AACA,gBAAgB,8DAAoB,iDAAiD,4DAAS;AAC9F,aAAa,uBAAuB,0EAAuB,EAAE,8EAA2B,EAAE,mEAAgB;AAC1G,gBAAgB,sEAAmB,EAAE,qEAAkB,uBAAuB,mDAAS;AACvF,yBAAyB,iEAAuB;AAChD,2BAA2B,iEAAc,SAAS,yDAAe;AACjE,2BAA2B,kEAAe,SAAS,yDAAe;AAClE,2BAA2B,iEAAc,SAAS,yDAAe;AACjE,2BAA2B,mEAAgB,SAAS,yDAAe;AACnE,2BAA2B,gEAAa,SAAS,yDAAe;AAChE,2BAA2B,gEAAa,SAAS,yDAAe;AAChE,YAAY,6EAAmC;AAC/C,qBAAqB,iEAAc,EAAE,kEAAe,EAAE,iEAAc,EAAE,mEAAgB,EAAE,gEAAa,EAAE,gEAAa;AACpH;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA,aAAa;AACb,SAAS;AACT;AACA,IAAI,sEAA4B;AAChC","sources":["webpack://sequencetranslator/./node_modules/cash-dom/dist/cash.js","webpack://sequencetranslator/./node_modules/save-svg-as-png/lib/saveSvgAsPng.js","webpack://sequencetranslator/./src/ICDs.ts","webpack://sequencetranslator/./src/IDPs.ts","webpack://sequencetranslator/./src/axolabsMap.ts","webpack://sequencetranslator/./src/defineAxolabsPattern.ts","webpack://sequencetranslator/./src/drawAxolabsPattern.ts","webpack://sequencetranslator/./src/salts.ts","webpack://sequencetranslator/./src/sources.ts","webpack://sequencetranslator/./src/structures-works/converters.ts","webpack://sequencetranslator/./src/structures-works/from-monomers.ts","webpack://sequencetranslator/./src/structures-works/map.ts","webpack://sequencetranslator/./src/structures-works/mol-transformations.ts","webpack://sequencetranslator/./src/structures-works/save-sense-antisense.ts","webpack://sequencetranslator/./src/structures-works/sequence-codes-tools.ts","webpack://sequencetranslator/./src/users.ts","webpack://sequencetranslator/external var \"DG\"","webpack://sequencetranslator/external var \"OCL\"","webpack://sequencetranslator/external var \"grok\"","webpack://sequencetranslator/external var \"ui\"","webpack://sequencetranslator/webpack/bootstrap","webpack://sequencetranslator/webpack/runtime/compat get default export","webpack://sequencetranslator/webpack/runtime/define property getters","webpack://sequencetranslator/webpack/runtime/hasOwnProperty shorthand","webpack://sequencetranslator/webpack/runtime/make namespace object","webpack://sequencetranslator/./src/package.ts"],"sourcesContent":["/* MIT https://github.com/fabiospampinato/cash */\n(function(){\n\"use strict\";\n\nvar propMap = {\n  /* GENERAL */\n  \"class\": 'className',\n  contenteditable: 'contentEditable',\n\n  /* LABEL */\n  \"for\": 'htmlFor',\n\n  /* INPUT */\n  readonly: 'readOnly',\n  maxlength: 'maxLength',\n  tabindex: 'tabIndex',\n\n  /* TABLE */\n  colspan: 'colSpan',\n  rowspan: 'rowSpan',\n\n  /* IMAGE */\n  usemap: 'useMap'\n};\n\nfunction attempt(fn, arg) {\n  try {\n    return fn(arg);\n  } catch (_a) {\n    return arg;\n  }\n}\n\nvar doc = document,\n    win = window,\n    docEle = doc.documentElement,\n    createElement = doc.createElement.bind(doc),\n    div = createElement('div'),\n    table = createElement('table'),\n    tbody = createElement('tbody'),\n    tr = createElement('tr'),\n    isArray = Array.isArray,\n    ArrayPrototype = Array.prototype,\n    concat = ArrayPrototype.concat,\n    filter = ArrayPrototype.filter,\n    indexOf = ArrayPrototype.indexOf,\n    map = ArrayPrototype.map,\n    push = ArrayPrototype.push,\n    slice = ArrayPrototype.slice,\n    some = ArrayPrototype.some,\n    splice = ArrayPrototype.splice;\nvar idRe = /^#(?:[\\w-]|\\\\.|[^\\x00-\\xa0])*$/,\n    classRe = /^\\.(?:[\\w-]|\\\\.|[^\\x00-\\xa0])*$/,\n    htmlRe = /<.+>/,\n    tagRe = /^\\w+$/; // @require ./variables.ts\n\nfunction find(selector, context) {\n  return !selector || !isDocument(context) && !isElement(context) ? [] : classRe.test(selector) ? context.getElementsByClassName(selector.slice(1)) : tagRe.test(selector) ? context.getElementsByTagName(selector) : context.querySelectorAll(selector);\n} // @require ./find.ts\n// @require ./variables.ts\n\n\nvar Cash =\n/** @class */\nfunction () {\n  function Cash(selector, context) {\n    if (!selector) return;\n    if (isCash(selector)) return selector;\n    var eles = selector;\n\n    if (isString(selector)) {\n      var ctx = (isCash(context) ? context[0] : context) || doc;\n      eles = idRe.test(selector) ? ctx.getElementById(selector.slice(1)) : htmlRe.test(selector) ? parseHTML(selector) : find(selector, ctx);\n      if (!eles) return;\n    } else if (isFunction(selector)) {\n      return this.ready(selector); //FIXME: `fn.ready` is not included in `core`, but it's actually a core functionality\n    }\n\n    if (eles.nodeType || eles === win) eles = [eles];\n    this.length = eles.length;\n\n    for (var i = 0, l = this.length; i < l; i++) {\n      this[i] = eles[i];\n    }\n  }\n\n  Cash.prototype.init = function (selector, context) {\n    return new Cash(selector, context);\n  };\n\n  return Cash;\n}();\n\nvar fn = Cash.prototype,\n    cash = fn.init;\ncash.fn = cash.prototype = fn; // Ensuring that `cash () instanceof cash`\n\nfn.length = 0;\nfn.splice = splice; // Ensuring a cash collection gets printed as array-like in Chrome's devtools\n\nif (typeof Symbol === 'function') {\n  // Ensuring a cash collection is iterable\n  fn[Symbol['iterator']] = ArrayPrototype[Symbol['iterator']];\n}\n\nfn.map = function (callback) {\n  return cash(concat.apply([], map.call(this, function (ele, i) {\n    return callback.call(ele, i, ele);\n  })));\n};\n\nfn.slice = function (start, end) {\n  return cash(slice.call(this, start, end));\n}; // @require ./cash.ts\n\n\nvar dashAlphaRe = /-([a-z])/g;\n\nfunction camelCase(str) {\n  return str.replace(dashAlphaRe, function (match, letter) {\n    return letter.toUpperCase();\n  });\n}\n\ncash.guid = 1; // @require ./cash.ts\n\nfunction matches(ele, selector) {\n  var matches = ele && (ele['matches'] || ele['webkitMatchesSelector'] || ele['msMatchesSelector']);\n  return !!matches && !!selector && matches.call(ele, selector);\n}\n\nfunction isCash(x) {\n  return x instanceof Cash;\n}\n\nfunction isWindow(x) {\n  return !!x && x === x.window;\n}\n\nfunction isDocument(x) {\n  return !!x && x.nodeType === 9;\n}\n\nfunction isElement(x) {\n  return !!x && x.nodeType === 1;\n}\n\nfunction isBoolean(x) {\n  return typeof x === 'boolean';\n}\n\nfunction isFunction(x) {\n  return typeof x === 'function';\n}\n\nfunction isString(x) {\n  return typeof x === 'string';\n}\n\nfunction isUndefined(x) {\n  return x === undefined;\n}\n\nfunction isNull(x) {\n  return x === null;\n}\n\nfunction isNumeric(x) {\n  return !isNaN(parseFloat(x)) && isFinite(x);\n}\n\nfunction isPlainObject(x) {\n  if (typeof x !== 'object' || x === null) return false;\n  var proto = Object.getPrototypeOf(x);\n  return proto === null || proto === Object.prototype;\n}\n\ncash.isWindow = isWindow;\ncash.isFunction = isFunction;\ncash.isArray = isArray;\ncash.isNumeric = isNumeric;\ncash.isPlainObject = isPlainObject;\n\nfn.get = function (index) {\n  if (isUndefined(index)) return slice.call(this);\n  index = Number(index);\n  return this[index < 0 ? index + this.length : index];\n};\n\nfn.eq = function (index) {\n  return cash(this.get(index));\n};\n\nfn.first = function () {\n  return this.eq(0);\n};\n\nfn.last = function () {\n  return this.eq(-1);\n};\n\nfunction each(arr, callback, _reverse) {\n  if (_reverse) {\n    var i = arr.length;\n\n    while (i--) {\n      if (callback.call(arr[i], i, arr[i]) === false) return arr;\n    }\n  } else if (isPlainObject(arr)) {\n    var keys = Object.keys(arr);\n\n    for (var i = 0, l = keys.length; i < l; i++) {\n      var key = keys[i];\n      if (callback.call(arr[key], key, arr[key]) === false) return arr;\n    }\n  } else {\n    for (var i = 0, l = arr.length; i < l; i++) {\n      if (callback.call(arr[i], i, arr[i]) === false) return arr;\n    }\n  }\n\n  return arr;\n}\n\ncash.each = each;\n\nfn.each = function (callback) {\n  return each(this, callback);\n};\n\nfn.prop = function (prop, value) {\n  if (!prop) return;\n\n  if (isString(prop)) {\n    prop = propMap[prop] || prop;\n    if (arguments.length < 2) return this[0] && this[0][prop];\n    return this.each(function (i, ele) {\n      ele[prop] = value;\n    });\n  }\n\n  for (var key in prop) {\n    this.prop(key, prop[key]);\n  }\n\n  return this;\n};\n\nfn.removeProp = function (prop) {\n  return this.each(function (i, ele) {\n    delete ele[propMap[prop] || prop];\n  });\n};\n\nfunction extend() {\n  var sources = [];\n\n  for (var _i = 0; _i < arguments.length; _i++) {\n    sources[_i] = arguments[_i];\n  }\n\n  var deep = isBoolean(sources[0]) ? sources.shift() : false,\n      target = sources.shift(),\n      length = sources.length;\n  if (!target) return {};\n  if (!length) return extend(deep, cash, target);\n\n  for (var i = 0; i < length; i++) {\n    var source = sources[i];\n\n    for (var key in source) {\n      if (deep && (isArray(source[key]) || isPlainObject(source[key]))) {\n        if (!target[key] || target[key].constructor !== source[key].constructor) target[key] = new source[key].constructor();\n        extend(deep, target[key], source[key]);\n      } else {\n        target[key] = source[key];\n      }\n    }\n  }\n\n  return target;\n}\n\ncash.extend = extend;\n\nfn.extend = function (plugins) {\n  return extend(fn, plugins);\n}; // @require ./matches.ts\n// @require ./type_checking.ts\n\n\nfunction getCompareFunction(comparator) {\n  return isString(comparator) ? function (i, ele) {\n    return matches(ele, comparator);\n  } : isFunction(comparator) ? comparator : isCash(comparator) ? function (i, ele) {\n    return comparator.is(ele);\n  } : !comparator ? function () {\n    return false;\n  } : function (i, ele) {\n    return ele === comparator;\n  };\n}\n\nfn.filter = function (comparator) {\n  var compare = getCompareFunction(comparator);\n  return cash(filter.call(this, function (ele, i) {\n    return compare.call(ele, i, ele);\n  }));\n}; // @require collection/filter.ts\n\n\nfunction filtered(collection, comparator) {\n  return !comparator ? collection : collection.filter(comparator);\n} // @require ./type_checking.ts\n\n\nvar splitValuesRe = /\\S+/g;\n\nfunction getSplitValues(str) {\n  return isString(str) ? str.match(splitValuesRe) || [] : [];\n}\n\nfn.hasClass = function (cls) {\n  return !!cls && some.call(this, function (ele) {\n    return isElement(ele) && ele.classList.contains(cls);\n  });\n};\n\nfn.removeAttr = function (attr) {\n  var attrs = getSplitValues(attr);\n  return this.each(function (i, ele) {\n    if (!isElement(ele)) return;\n    each(attrs, function (i, a) {\n      ele.removeAttribute(a);\n    });\n  });\n};\n\nfunction attr(attr, value) {\n  if (!attr) return;\n\n  if (isString(attr)) {\n    if (arguments.length < 2) {\n      if (!this[0] || !isElement(this[0])) return;\n      var value_1 = this[0].getAttribute(attr);\n      return isNull(value_1) ? undefined : value_1;\n    }\n\n    if (isUndefined(value)) return this;\n    if (isNull(value)) return this.removeAttr(attr);\n    return this.each(function (i, ele) {\n      if (!isElement(ele)) return;\n      ele.setAttribute(attr, value);\n    });\n  }\n\n  for (var key in attr) {\n    this.attr(key, attr[key]);\n  }\n\n  return this;\n}\n\nfn.attr = attr;\n\nfn.toggleClass = function (cls, force) {\n  var classes = getSplitValues(cls),\n      isForce = !isUndefined(force);\n  return this.each(function (i, ele) {\n    if (!isElement(ele)) return;\n    each(classes, function (i, c) {\n      if (isForce) {\n        force ? ele.classList.add(c) : ele.classList.remove(c);\n      } else {\n        ele.classList.toggle(c);\n      }\n    });\n  });\n};\n\nfn.addClass = function (cls) {\n  return this.toggleClass(cls, true);\n};\n\nfn.removeClass = function (cls) {\n  if (arguments.length) return this.toggleClass(cls, false);\n  return this.attr('class', '');\n};\n\nfunction pluck(arr, prop, deep, until) {\n  var plucked = [],\n      isCallback = isFunction(prop),\n      compare = until && getCompareFunction(until);\n\n  for (var i = 0, l = arr.length; i < l; i++) {\n    if (isCallback) {\n      var val_1 = prop(arr[i]);\n      if (val_1.length) push.apply(plucked, val_1);\n    } else {\n      var val_2 = arr[i][prop];\n\n      while (val_2 != null) {\n        if (until && compare(-1, val_2)) break;\n        plucked.push(val_2);\n        val_2 = deep ? val_2[prop] : null;\n      }\n    }\n  }\n\n  return plucked;\n}\n\nfunction unique(arr) {\n  return arr.length > 1 ? filter.call(arr, function (item, index, self) {\n    return indexOf.call(self, item) === index;\n  }) : arr;\n}\n\ncash.unique = unique;\n\nfn.add = function (selector, context) {\n  return cash(unique(this.get().concat(cash(selector, context).get())));\n}; // @require core/type_checking.ts\n// @require core/variables.ts\n\n\nfunction computeStyle(ele, prop, isVariable) {\n  if (!isElement(ele)) return;\n  var style = win.getComputedStyle(ele, null);\n  return isVariable ? style.getPropertyValue(prop) || undefined : style[prop] || ele.style[prop];\n} // @require ./compute_style.ts\n\n\nfunction computeStyleInt(ele, prop) {\n  return parseInt(computeStyle(ele, prop), 10) || 0;\n}\n\nvar cssVariableRe = /^--/; // @require ./variables.ts\n\nfunction isCSSVariable(prop) {\n  return cssVariableRe.test(prop);\n} // @require core/camel_case.ts\n// @require core/cash.ts\n// @require core/each.ts\n// @require core/variables.ts\n// @require ./is_css_variable.ts\n\n\nvar prefixedProps = {},\n    style = div.style,\n    vendorsPrefixes = ['webkit', 'moz', 'ms'];\n\nfunction getPrefixedProp(prop, isVariable) {\n  if (isVariable === void 0) {\n    isVariable = isCSSVariable(prop);\n  }\n\n  if (isVariable) return prop;\n\n  if (!prefixedProps[prop]) {\n    var propCC = camelCase(prop),\n        propUC = \"\" + propCC[0].toUpperCase() + propCC.slice(1),\n        props = (propCC + \" \" + vendorsPrefixes.join(propUC + \" \") + propUC).split(' ');\n    each(props, function (i, p) {\n      if (p in style) {\n        prefixedProps[prop] = p;\n        return false;\n      }\n    });\n  }\n\n  return prefixedProps[prop];\n}\n\n; // @require core/type_checking.ts\n// @require ./is_css_variable.ts\n\nvar numericProps = {\n  animationIterationCount: true,\n  columnCount: true,\n  flexGrow: true,\n  flexShrink: true,\n  fontWeight: true,\n  gridArea: true,\n  gridColumn: true,\n  gridColumnEnd: true,\n  gridColumnStart: true,\n  gridRow: true,\n  gridRowEnd: true,\n  gridRowStart: true,\n  lineHeight: true,\n  opacity: true,\n  order: true,\n  orphans: true,\n  widows: true,\n  zIndex: true\n};\n\nfunction getSuffixedValue(prop, value, isVariable) {\n  if (isVariable === void 0) {\n    isVariable = isCSSVariable(prop);\n  }\n\n  return !isVariable && !numericProps[prop] && isNumeric(value) ? value + \"px\" : value;\n}\n\nfunction css(prop, value) {\n  if (isString(prop)) {\n    var isVariable_1 = isCSSVariable(prop);\n    prop = getPrefixedProp(prop, isVariable_1);\n    if (arguments.length < 2) return this[0] && computeStyle(this[0], prop, isVariable_1);\n    if (!prop) return this;\n    value = getSuffixedValue(prop, value, isVariable_1);\n    return this.each(function (i, ele) {\n      if (!isElement(ele)) return;\n\n      if (isVariable_1) {\n        ele.style.setProperty(prop, value);\n      } else {\n        ele.style[prop] = value;\n      }\n    });\n  }\n\n  for (var key in prop) {\n    this.css(key, prop[key]);\n  }\n\n  return this;\n}\n\n;\nfn.css = css; // @optional ./css.ts\n// @require core/attempt.ts\n// @require core/camel_case.ts\n\nvar JSONStringRe = /^\\s+|\\s+$/;\n\nfunction getData(ele, key) {\n  var value = ele.dataset[key] || ele.dataset[camelCase(key)];\n  if (JSONStringRe.test(value)) return value;\n  return attempt(JSON.parse, value);\n} // @require core/attempt.ts\n// @require core/camel_case.ts\n\n\nfunction setData(ele, key, value) {\n  value = attempt(JSON.stringify, value);\n  ele.dataset[camelCase(key)] = value;\n}\n\nfunction data(name, value) {\n  if (!name) {\n    if (!this[0]) return;\n    var datas = {};\n\n    for (var key in this[0].dataset) {\n      datas[key] = getData(this[0], key);\n    }\n\n    return datas;\n  }\n\n  if (isString(name)) {\n    if (arguments.length < 2) return this[0] && getData(this[0], name);\n    if (isUndefined(value)) return this;\n    return this.each(function (i, ele) {\n      setData(ele, name, value);\n    });\n  }\n\n  for (var key in name) {\n    this.data(key, name[key]);\n  }\n\n  return this;\n}\n\nfn.data = data; // @optional ./data.ts\n\nfunction getDocumentDimension(doc, dimension) {\n  var docEle = doc.documentElement;\n  return Math.max(doc.body[\"scroll\" + dimension], docEle[\"scroll\" + dimension], doc.body[\"offset\" + dimension], docEle[\"offset\" + dimension], docEle[\"client\" + dimension]);\n} // @require css/helpers/compute_style_int.ts\n\n\nfunction getExtraSpace(ele, xAxis) {\n  return computeStyleInt(ele, \"border\" + (xAxis ? 'Left' : 'Top') + \"Width\") + computeStyleInt(ele, \"padding\" + (xAxis ? 'Left' : 'Top')) + computeStyleInt(ele, \"padding\" + (xAxis ? 'Right' : 'Bottom')) + computeStyleInt(ele, \"border\" + (xAxis ? 'Right' : 'Bottom') + \"Width\");\n}\n\neach([true, false], function (i, outer) {\n  each(['Width', 'Height'], function (i, prop) {\n    var name = \"\" + (outer ? 'outer' : 'inner') + prop;\n\n    fn[name] = function (includeMargins) {\n      if (!this[0]) return;\n      if (isWindow(this[0])) return outer ? this[0][\"inner\" + prop] : this[0].document.documentElement[\"client\" + prop];\n      if (isDocument(this[0])) return getDocumentDimension(this[0], prop);\n      return this[0][\"\" + (outer ? 'offset' : 'client') + prop] + (includeMargins && outer ? computeStyleInt(this[0], \"margin\" + (i ? 'Top' : 'Left')) + computeStyleInt(this[0], \"margin\" + (i ? 'Bottom' : 'Right')) : 0);\n    };\n  });\n});\neach(['Width', 'Height'], function (index, prop) {\n  var propLC = prop.toLowerCase();\n\n  fn[propLC] = function (value) {\n    if (!this[0]) return isUndefined(value) ? undefined : this;\n\n    if (!arguments.length) {\n      if (isWindow(this[0])) return this[0].document.documentElement[\"client\" + prop];\n      if (isDocument(this[0])) return getDocumentDimension(this[0], prop);\n      return this[0].getBoundingClientRect()[propLC] - getExtraSpace(this[0], !index);\n    }\n\n    var valueNumber = parseInt(value, 10);\n    return this.each(function (i, ele) {\n      if (!isElement(ele)) return;\n      var boxSizing = computeStyle(ele, 'boxSizing');\n      ele.style[propLC] = getSuffixedValue(propLC, valueNumber + (boxSizing === 'border-box' ? getExtraSpace(ele, !index) : 0));\n    });\n  };\n}); // @optional ./inner_outer.ts\n// @optional ./normal.ts\n// @require css/helpers/compute_style.ts\n\nvar defaultDisplay = {};\n\nfunction getDefaultDisplay(tagName) {\n  if (defaultDisplay[tagName]) return defaultDisplay[tagName];\n  var ele = createElement(tagName);\n  doc.body.insertBefore(ele, null);\n  var display = computeStyle(ele, 'display');\n  doc.body.removeChild(ele);\n  return defaultDisplay[tagName] = display !== 'none' ? display : 'block';\n} // @require css/helpers/compute_style.ts\n\n\nfunction isHidden(ele) {\n  return computeStyle(ele, 'display') === 'none';\n}\n\nvar displayProperty = '___cd';\n\nfn.toggle = function (force) {\n  return this.each(function (i, ele) {\n    if (!isElement(ele)) return;\n    var show = isUndefined(force) ? isHidden(ele) : force;\n\n    if (show) {\n      ele.style.display = ele[displayProperty] || '';\n\n      if (isHidden(ele)) {\n        ele.style.display = getDefaultDisplay(ele.tagName);\n      }\n    } else {\n      ele[displayProperty] = computeStyle(ele, 'display');\n      ele.style.display = 'none';\n    }\n  });\n};\n\nfn.hide = function () {\n  return this.toggle(false);\n};\n\nfn.show = function () {\n  return this.toggle(true);\n}; // @optional ./hide.ts\n// @optional ./show.ts\n// @optional ./toggle.ts\n\n\nfunction hasNamespaces(ns1, ns2) {\n  return !ns2 || !some.call(ns2, function (ns) {\n    return ns1.indexOf(ns) < 0;\n  });\n}\n\nvar eventsNamespace = '___ce',\n    eventsNamespacesSeparator = '.',\n    eventsFocus = {\n  focus: 'focusin',\n  blur: 'focusout'\n},\n    eventsHover = {\n  mouseenter: 'mouseover',\n  mouseleave: 'mouseout'\n},\n    eventsMouseRe = /^(mouse|pointer|contextmenu|drag|drop|click|dblclick)/i; // @require ./variables.ts\n\nfunction getEventNameBubbling(name) {\n  return eventsHover[name] || eventsFocus[name] || name;\n} // @require ./variables.ts\n\n\nfunction getEventsCache(ele) {\n  return ele[eventsNamespace] = ele[eventsNamespace] || {};\n} // @require core/guid.ts\n// @require events/helpers/get_events_cache.ts\n\n\nfunction addEvent(ele, name, namespaces, selector, callback) {\n  var eventCache = getEventsCache(ele);\n  eventCache[name] = eventCache[name] || [];\n  eventCache[name].push([namespaces, selector, callback]);\n  ele.addEventListener(name, callback);\n} // @require ./variables.ts\n\n\nfunction parseEventName(eventName) {\n  var parts = eventName.split(eventsNamespacesSeparator);\n  return [parts[0], parts.slice(1).sort()]; // [name, namespace[]]\n} // @require ./get_events_cache.ts\n// @require ./has_namespaces.ts\n// @require ./parse_event_name.ts\n\n\nfunction removeEvent(ele, name, namespaces, selector, callback) {\n  var cache = getEventsCache(ele);\n\n  if (!name) {\n    for (name in cache) {\n      removeEvent(ele, name, namespaces, selector, callback);\n    }\n  } else if (cache[name]) {\n    cache[name] = cache[name].filter(function (_a) {\n      var ns = _a[0],\n          sel = _a[1],\n          cb = _a[2];\n      if (callback && cb.guid !== callback.guid || !hasNamespaces(ns, namespaces) || selector && selector !== sel) return true;\n      ele.removeEventListener(name, cb);\n    });\n  }\n}\n\nfn.off = function (eventFullName, selector, callback) {\n  var _this = this;\n\n  if (isUndefined(eventFullName)) {\n    this.each(function (i, ele) {\n      if (!isElement(ele) && !isDocument(ele) && !isWindow(ele)) return;\n      removeEvent(ele);\n    });\n  } else if (!isString(eventFullName)) {\n    for (var key in eventFullName) {\n      this.off(key, eventFullName[key]);\n    }\n  } else {\n    if (isFunction(selector)) {\n      callback = selector;\n      selector = '';\n    }\n\n    each(getSplitValues(eventFullName), function (i, eventFullName) {\n      var _a = parseEventName(eventFullName),\n          nameOriginal = _a[0],\n          namespaces = _a[1],\n          name = getEventNameBubbling(nameOriginal);\n\n      _this.each(function (i, ele) {\n        if (!isElement(ele) && !isDocument(ele) && !isWindow(ele)) return;\n        removeEvent(ele, name, namespaces, selector, callback);\n      });\n    });\n  }\n\n  return this;\n};\n\nfunction on(eventFullName, selector, data, callback, _one) {\n  var _this = this;\n\n  if (!isString(eventFullName)) {\n    for (var key in eventFullName) {\n      this.on(key, selector, data, eventFullName[key], _one);\n    }\n\n    return this;\n  }\n\n  if (!isString(selector)) {\n    if (isUndefined(selector) || isNull(selector)) {\n      selector = '';\n    } else if (isUndefined(data)) {\n      data = selector;\n      selector = '';\n    } else {\n      callback = data;\n      data = selector;\n      selector = '';\n    }\n  }\n\n  if (!isFunction(callback)) {\n    callback = data;\n    data = undefined;\n  }\n\n  if (!callback) return this;\n  each(getSplitValues(eventFullName), function (i, eventFullName) {\n    var _a = parseEventName(eventFullName),\n        nameOriginal = _a[0],\n        namespaces = _a[1],\n        name = getEventNameBubbling(nameOriginal),\n        isEventHover = nameOriginal in eventsHover,\n        isEventFocus = nameOriginal in eventsFocus;\n\n    if (!name) return;\n\n    _this.each(function (i, ele) {\n      if (!isElement(ele) && !isDocument(ele) && !isWindow(ele)) return;\n\n      var finalCallback = function finalCallback(event) {\n        if (event.target[\"___i\" + event.type]) return event.stopImmediatePropagation(); // Ignoring native event in favor of the upcoming custom one\n\n        if (event.namespace && !hasNamespaces(namespaces, event.namespace.split(eventsNamespacesSeparator))) return;\n        if (!selector && (isEventFocus && (event.target !== ele || event.___ot === name) || isEventHover && event.relatedTarget && ele.contains(event.relatedTarget))) return;\n        var thisArg = ele;\n\n        if (selector) {\n          var target = event.target;\n\n          while (!matches(target, selector)) {\n            if (target === ele) return;\n            target = target.parentNode;\n            if (!target) return;\n          }\n\n          thisArg = target;\n          event.___cd = true; // Delegate\n        }\n\n        if (event.___cd) {\n          Object.defineProperty(event, 'currentTarget', {\n            configurable: true,\n            get: function get() {\n              return thisArg;\n            }\n          });\n        }\n\n        Object.defineProperty(event, 'data', {\n          configurable: true,\n          get: function get() {\n            return data;\n          }\n        });\n        var returnValue = callback.call(thisArg, event, event.___td);\n\n        if (_one) {\n          removeEvent(ele, name, namespaces, selector, finalCallback);\n        }\n\n        if (returnValue === false) {\n          event.preventDefault();\n          event.stopPropagation();\n        }\n      };\n\n      finalCallback.guid = callback.guid = callback.guid || cash.guid++;\n      addEvent(ele, name, namespaces, selector, finalCallback);\n    });\n  });\n  return this;\n}\n\nfn.on = on;\n\nfunction one(eventFullName, selector, data, callback) {\n  return this.on(eventFullName, selector, data, callback, true);\n}\n\n;\nfn.one = one;\n\nfn.ready = function (callback) {\n  var cb = function cb() {\n    return setTimeout(callback, 0, cash);\n  };\n\n  if (doc.readyState !== 'loading') {\n    cb();\n  } else {\n    doc.addEventListener('DOMContentLoaded', cb);\n  }\n\n  return this;\n};\n\nfn.trigger = function (event, data) {\n  if (isString(event)) {\n    var _a = parseEventName(event),\n        nameOriginal = _a[0],\n        namespaces = _a[1],\n        name_1 = getEventNameBubbling(nameOriginal);\n\n    if (!name_1) return this;\n    var type = eventsMouseRe.test(name_1) ? 'MouseEvents' : 'HTMLEvents';\n    event = doc.createEvent(type);\n    event.initEvent(name_1, true, true);\n    event.namespace = namespaces.join(eventsNamespacesSeparator);\n    event.___ot = nameOriginal;\n  }\n\n  event.___td = data;\n  var isEventFocus = event.___ot in eventsFocus;\n  return this.each(function (i, ele) {\n    if (isEventFocus && isFunction(ele[event.___ot])) {\n      ele[\"___i\" + event.type] = true; // Ensuring the native event is ignored\n\n      ele[event.___ot]();\n\n      ele[\"___i\" + event.type] = false; // Ensuring the custom event is not ignored\n    }\n\n    ele.dispatchEvent(event);\n  });\n}; // @optional ./off.ts\n// @optional ./on.ts\n// @optional ./one.ts\n// @optional ./ready.ts\n// @optional ./trigger.ts\n// @require core/pluck.ts\n// @require core/variables.ts\n\n\nfunction getValue(ele) {\n  if (ele.multiple && ele.options) return pluck(filter.call(ele.options, function (option) {\n    return option.selected && !option.disabled && !option.parentNode.disabled;\n  }), 'value');\n  return ele.value || '';\n}\n\nvar queryEncodeSpaceRe = /%20/g,\n    queryEncodeCRLFRe = /\\r?\\n/g;\n\nfunction queryEncode(prop, value) {\n  return \"&\" + encodeURIComponent(prop) + \"=\" + encodeURIComponent(value.replace(queryEncodeCRLFRe, '\\r\\n')).replace(queryEncodeSpaceRe, '+');\n}\n\nvar skippableRe = /file|reset|submit|button|image/i,\n    checkableRe = /radio|checkbox/i;\n\nfn.serialize = function () {\n  var query = '';\n  this.each(function (i, ele) {\n    each(ele.elements || [ele], function (i, ele) {\n      if (ele.disabled || !ele.name || ele.tagName === 'FIELDSET' || skippableRe.test(ele.type) || checkableRe.test(ele.type) && !ele.checked) return;\n      var value = getValue(ele);\n\n      if (!isUndefined(value)) {\n        var values = isArray(value) ? value : [value];\n        each(values, function (i, value) {\n          query += queryEncode(ele.name, value);\n        });\n      }\n    });\n  });\n  return query.slice(1);\n};\n\nfunction val(value) {\n  if (!arguments.length) return this[0] && getValue(this[0]);\n  return this.each(function (i, ele) {\n    var isSelect = ele.multiple && ele.options;\n\n    if (isSelect || checkableRe.test(ele.type)) {\n      var eleValue_1 = isArray(value) ? map.call(value, String) : isNull(value) ? [] : [String(value)];\n\n      if (isSelect) {\n        each(ele.options, function (i, option) {\n          option.selected = eleValue_1.indexOf(option.value) >= 0;\n        }, true);\n      } else {\n        ele.checked = eleValue_1.indexOf(ele.value) >= 0;\n      }\n    } else {\n      ele.value = isUndefined(value) || isNull(value) ? '' : value;\n    }\n  });\n}\n\nfn.val = val;\n\nfn.clone = function () {\n  return this.map(function (i, ele) {\n    return ele.cloneNode(true);\n  });\n};\n\nfn.detach = function (comparator) {\n  filtered(this, comparator).each(function (i, ele) {\n    if (ele.parentNode) {\n      ele.parentNode.removeChild(ele);\n    }\n  });\n  return this;\n};\n\nvar fragmentRe = /^\\s*<(\\w+)[^>]*>/,\n    singleTagRe = /^<(\\w+)\\s*\\/?>(?:<\\/\\1>)?$/;\nvar containers = {\n  '*': div,\n  tr: tbody,\n  td: tr,\n  th: tr,\n  thead: table,\n  tbody: table,\n  tfoot: table\n}; //TODO: Create elements inside a document fragment, in order to prevent inline event handlers from firing\n//TODO: Ensure the created elements have the fragment as their parent instead of null, this also ensures we can deal with detatched nodes more reliably\n\nfunction parseHTML(html) {\n  if (!isString(html)) return [];\n  if (singleTagRe.test(html)) return [createElement(RegExp.$1)];\n  var fragment = fragmentRe.test(html) && RegExp.$1,\n      container = containers[fragment] || containers['*'];\n  container.innerHTML = html;\n  return cash(container.childNodes).detach().get();\n}\n\ncash.parseHTML = parseHTML;\n\nfn.empty = function () {\n  return this.each(function (i, ele) {\n    while (ele.firstChild) {\n      ele.removeChild(ele.firstChild);\n    }\n  });\n};\n\nfunction html(html) {\n  if (!arguments.length) return this[0] && this[0].innerHTML;\n  if (isUndefined(html)) return this;\n  return this.each(function (i, ele) {\n    if (!isElement(ele)) return;\n    ele.innerHTML = html;\n  });\n}\n\nfn.html = html;\n\nfn.remove = function (comparator) {\n  filtered(this, comparator).detach().off();\n  return this;\n};\n\nfunction text(text) {\n  if (isUndefined(text)) return this[0] ? this[0].textContent : '';\n  return this.each(function (i, ele) {\n    if (!isElement(ele)) return;\n    ele.textContent = text;\n  });\n}\n\n;\nfn.text = text;\n\nfn.unwrap = function () {\n  this.parent().each(function (i, ele) {\n    if (ele.tagName === 'BODY') return;\n    var $ele = cash(ele);\n    $ele.replaceWith($ele.children());\n  });\n  return this;\n};\n\nfn.offset = function () {\n  var ele = this[0];\n  if (!ele) return;\n  var rect = ele.getBoundingClientRect();\n  return {\n    top: rect.top + win.pageYOffset,\n    left: rect.left + win.pageXOffset\n  };\n};\n\nfn.offsetParent = function () {\n  return this.map(function (i, ele) {\n    var offsetParent = ele.offsetParent;\n\n    while (offsetParent && computeStyle(offsetParent, 'position') === 'static') {\n      offsetParent = offsetParent.offsetParent;\n    }\n\n    return offsetParent || docEle;\n  });\n};\n\nfn.position = function () {\n  var ele = this[0];\n  if (!ele) return;\n  var isFixed = computeStyle(ele, 'position') === 'fixed',\n      offset = isFixed ? ele.getBoundingClientRect() : this.offset();\n\n  if (!isFixed) {\n    var doc_1 = ele.ownerDocument;\n    var offsetParent = ele.offsetParent || doc_1.documentElement;\n\n    while ((offsetParent === doc_1.body || offsetParent === doc_1.documentElement) && computeStyle(offsetParent, 'position') === 'static') {\n      offsetParent = offsetParent.parentNode;\n    }\n\n    if (offsetParent !== ele && isElement(offsetParent)) {\n      var parentOffset = cash(offsetParent).offset();\n      offset.top -= parentOffset.top + computeStyleInt(offsetParent, 'borderTopWidth');\n      offset.left -= parentOffset.left + computeStyleInt(offsetParent, 'borderLeftWidth');\n    }\n  }\n\n  return {\n    top: offset.top - computeStyleInt(ele, 'marginTop'),\n    left: offset.left - computeStyleInt(ele, 'marginLeft')\n  };\n};\n\nfn.children = function (comparator) {\n  return filtered(cash(unique(pluck(this, function (ele) {\n    return ele.children;\n  }))), comparator);\n};\n\nfn.contents = function () {\n  return cash(unique(pluck(this, function (ele) {\n    return ele.tagName === 'IFRAME' ? [ele.contentDocument] : ele.tagName === 'TEMPLATE' ? ele.content.childNodes : ele.childNodes;\n  })));\n};\n\nfn.find = function (selector) {\n  return cash(unique(pluck(this, function (ele) {\n    return find(selector, ele);\n  })));\n}; // @require core/variables.ts\n// @require collection/filter.ts\n// @require traversal/find.ts\n\n\nvar HTMLCDATARe = /^\\s*<!(?:\\[CDATA\\[|--)|(?:\\]\\]|--)>\\s*$/g,\n    scriptTypeRe = /^$|^module$|\\/(java|ecma)script/i,\n    scriptAttributes = ['type', 'src', 'nonce', 'noModule'];\n\nfunction evalScripts(node, doc) {\n  var collection = cash(node);\n  collection.filter('script').add(collection.find('script')).each(function (i, ele) {\n    if (scriptTypeRe.test(ele.type) && docEle.contains(ele)) {\n      // The script type is supported // The element is attached to the DOM // Using `documentElement` for broader browser support\n      var script_1 = createElement('script');\n      script_1.text = ele.textContent.replace(HTMLCDATARe, '');\n      each(scriptAttributes, function (i, attr) {\n        if (ele[attr]) script_1[attr] = ele[attr];\n      });\n      doc.head.insertBefore(script_1, null);\n      doc.head.removeChild(script_1);\n    }\n  });\n} // @require ./eval_scripts.ts\n\n\nfunction insertElement(anchor, target, left, inside, evaluate) {\n  if (inside) {\n    // prepend/append\n    anchor.insertBefore(target, left ? anchor.firstChild : null);\n  } else {\n    // before/after\n    anchor.parentNode.insertBefore(target, left ? anchor : anchor.nextSibling);\n  }\n\n  if (evaluate) {\n    evalScripts(target, anchor.ownerDocument);\n  }\n} // @require ./insert_element.ts\n\n\nfunction insertSelectors(selectors, anchors, inverse, left, inside, reverseLoop1, reverseLoop2, reverseLoop3) {\n  each(selectors, function (si, selector) {\n    each(cash(selector), function (ti, target) {\n      each(cash(anchors), function (ai, anchor) {\n        var anchorFinal = inverse ? target : anchor,\n            targetFinal = inverse ? anchor : target,\n            indexFinal = inverse ? ti : ai;\n        insertElement(anchorFinal, !indexFinal ? targetFinal : targetFinal.cloneNode(true), left, inside, !indexFinal);\n      }, reverseLoop3);\n    }, reverseLoop2);\n  }, reverseLoop1);\n  return anchors;\n}\n\nfn.after = function () {\n  return insertSelectors(arguments, this, false, false, false, true, true);\n};\n\nfn.append = function () {\n  return insertSelectors(arguments, this, false, false, true);\n};\n\nfn.appendTo = function (selector) {\n  return insertSelectors(arguments, this, true, false, true);\n};\n\nfn.before = function () {\n  return insertSelectors(arguments, this, false, true);\n};\n\nfn.insertAfter = function (selector) {\n  return insertSelectors(arguments, this, true, false, false, false, false, true);\n};\n\nfn.insertBefore = function (selector) {\n  return insertSelectors(arguments, this, true, true);\n};\n\nfn.prepend = function () {\n  return insertSelectors(arguments, this, false, true, true, true, true);\n};\n\nfn.prependTo = function (selector) {\n  return insertSelectors(arguments, this, true, true, true, false, false, true);\n};\n\nfn.replaceWith = function (selector) {\n  return this.before(selector).remove();\n};\n\nfn.replaceAll = function (selector) {\n  cash(selector).replaceWith(this);\n  return this;\n};\n\nfn.wrapAll = function (selector) {\n  var structure = cash(selector),\n      wrapper = structure[0];\n\n  while (wrapper.children.length) {\n    wrapper = wrapper.firstElementChild;\n  }\n\n  this.first().before(structure);\n  return this.appendTo(wrapper);\n};\n\nfn.wrap = function (selector) {\n  return this.each(function (i, ele) {\n    var wrapper = cash(selector)[0];\n    cash(ele).wrapAll(!i ? wrapper : wrapper.cloneNode(true));\n  });\n};\n\nfn.wrapInner = function (selector) {\n  return this.each(function (i, ele) {\n    var $ele = cash(ele),\n        contents = $ele.contents();\n    contents.length ? contents.wrapAll(selector) : $ele.append(selector);\n  });\n};\n\nfn.has = function (selector) {\n  var comparator = isString(selector) ? function (i, ele) {\n    return find(selector, ele).length;\n  } : function (i, ele) {\n    return ele.contains(selector);\n  };\n  return this.filter(comparator);\n};\n\nfn.is = function (comparator) {\n  var compare = getCompareFunction(comparator);\n  return some.call(this, function (ele, i) {\n    return compare.call(ele, i, ele);\n  });\n};\n\nfn.next = function (comparator, _all, _until) {\n  return filtered(cash(unique(pluck(this, 'nextElementSibling', _all, _until))), comparator);\n};\n\nfn.nextAll = function (comparator) {\n  return this.next(comparator, true);\n};\n\nfn.nextUntil = function (until, comparator) {\n  return this.next(comparator, true, until);\n};\n\nfn.not = function (comparator) {\n  var compare = getCompareFunction(comparator);\n  return this.filter(function (i, ele) {\n    return (!isString(comparator) || isElement(ele)) && !compare.call(ele, i, ele);\n  });\n};\n\nfn.parent = function (comparator) {\n  return filtered(cash(unique(pluck(this, 'parentNode'))), comparator);\n};\n\nfn.index = function (selector) {\n  var child = selector ? cash(selector)[0] : this[0],\n      collection = selector ? this : cash(child).parent().children();\n  return indexOf.call(collection, child);\n};\n\nfn.closest = function (comparator) {\n  var filtered = this.filter(comparator);\n  if (filtered.length) return filtered;\n  var $parent = this.parent();\n  if (!$parent.length) return filtered;\n  return $parent.closest(comparator);\n};\n\nfn.parents = function (comparator, _until) {\n  return filtered(cash(unique(pluck(this, 'parentElement', true, _until))), comparator);\n};\n\nfn.parentsUntil = function (until, comparator) {\n  return this.parents(comparator, until);\n};\n\nfn.prev = function (comparator, _all, _until) {\n  return filtered(cash(unique(pluck(this, 'previousElementSibling', _all, _until))), comparator);\n};\n\nfn.prevAll = function (comparator) {\n  return this.prev(comparator, true);\n};\n\nfn.prevUntil = function (until, comparator) {\n  return this.prev(comparator, true, until);\n};\n\nfn.siblings = function (comparator) {\n  return filtered(cash(unique(pluck(this, function (ele) {\n    return cash(ele).parent().children().not(ele);\n  }))), comparator);\n}; // @optional ./children.ts\n// @optional ./closest.ts\n// @optional ./contents.ts\n// @optional ./find.ts\n// @optional ./has.ts\n// @optional ./is.ts\n// @optional ./next.ts\n// @optional ./next_all.ts\n// @optional ./next_until.ts\n// @optional ./not.ts\n// @optional ./parent.ts\n// @optional ./parents.ts\n// @optional ./parents_until.ts\n// @optional ./prev.ts\n// @optional ./prev_all.ts\n// @optional ./prev_until.ts\n// @optional ./siblings.ts\n// @optional attributes/index.ts\n// @optional collection/index.ts\n// @optional css/index.ts\n// @optional data/index.ts\n// @optional dimensions/index.ts\n// @optional effects/index.ts\n// @optional events/index.ts\n// @optional forms/index.ts\n// @optional manipulation/index.ts\n// @optional offset/index.ts\n// @optional traversal/index.ts\n// @require core/index.ts\n// @priority -100\n// @require ./cash.ts\n// @require ./variables.ts\n\n\nif (typeof exports !== 'undefined') {\n  // Node.js\n  module.exports = cash;\n} else {\n  // Browser\n  win['cash'] = win['$'] = cash;\n}\n})();","'use strict';\n\n(function () {\n  var out$ = typeof exports != 'undefined' && exports || typeof define != 'undefined' && {} || this || window;\n  if (typeof define !== 'undefined') define('save-svg-as-png', [], function () {\n    return out$;\n  });\n  out$.default = out$;\n\n  var xmlNs = 'http://www.w3.org/2000/xmlns/';\n  var xhtmlNs = 'http://www.w3.org/1999/xhtml';\n  var svgNs = 'http://www.w3.org/2000/svg';\n  var doctype = '<?xml version=\"1.0\" standalone=\"no\"?><!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\" \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\" [<!ENTITY nbsp \"&#160;\">]>';\n  var urlRegex = /url\\([\"']?(.+?)[\"']?\\)/;\n  var fontFormats = {\n    woff2: 'font/woff2',\n    woff: 'font/woff',\n    otf: 'application/x-font-opentype',\n    ttf: 'application/x-font-ttf',\n    eot: 'application/vnd.ms-fontobject',\n    sfnt: 'application/font-sfnt',\n    svg: 'image/svg+xml'\n  };\n\n  var isElement = function isElement(obj) {\n    return obj instanceof HTMLElement || obj instanceof SVGElement;\n  };\n  var requireDomNode = function requireDomNode(el) {\n    if (!isElement(el)) throw new Error('an HTMLElement or SVGElement is required; got ' + el);\n  };\n  var requireDomNodePromise = function requireDomNodePromise(el) {\n    return new Promise(function (resolve, reject) {\n      if (isElement(el)) resolve(el);else reject(new Error('an HTMLElement or SVGElement is required; got ' + el));\n    });\n  };\n  var isExternal = function isExternal(url) {\n    return url && url.lastIndexOf('http', 0) === 0 && url.lastIndexOf(window.location.host) === -1;\n  };\n\n  var getFontMimeTypeFromUrl = function getFontMimeTypeFromUrl(fontUrl) {\n    var formats = Object.keys(fontFormats).filter(function (extension) {\n      return fontUrl.indexOf('.' + extension) > 0;\n    }).map(function (extension) {\n      return fontFormats[extension];\n    });\n    if (formats) return formats[0];\n    console.error('Unknown font format for ' + fontUrl + '. Fonts may not be working correctly.');\n    return 'application/octet-stream';\n  };\n\n  var arrayBufferToBase64 = function arrayBufferToBase64(buffer) {\n    var binary = '';\n    var bytes = new Uint8Array(buffer);\n    for (var i = 0; i < bytes.byteLength; i++) {\n      binary += String.fromCharCode(bytes[i]);\n    }return window.btoa(binary);\n  };\n\n  var getDimension = function getDimension(el, clone, dim) {\n    var v = el.viewBox && el.viewBox.baseVal && el.viewBox.baseVal[dim] || clone.getAttribute(dim) !== null && !clone.getAttribute(dim).match(/%$/) && parseInt(clone.getAttribute(dim)) || el.getBoundingClientRect()[dim] || parseInt(clone.style[dim]) || parseInt(window.getComputedStyle(el).getPropertyValue(dim));\n    return typeof v === 'undefined' || v === null || isNaN(parseFloat(v)) ? 0 : v;\n  };\n\n  var getDimensions = function getDimensions(el, clone, width, height) {\n    if (el.tagName === 'svg') return {\n      width: width || getDimension(el, clone, 'width'),\n      height: height || getDimension(el, clone, 'height')\n    };else if (el.getBBox) {\n      var _el$getBBox = el.getBBox(),\n          x = _el$getBBox.x,\n          y = _el$getBBox.y,\n          _width = _el$getBBox.width,\n          _height = _el$getBBox.height;\n\n      return {\n        width: x + _width,\n        height: y + _height\n      };\n    }\n  };\n\n  var reEncode = function reEncode(data) {\n    return decodeURIComponent(encodeURIComponent(data).replace(/%([0-9A-F]{2})/g, function (match, p1) {\n      var c = String.fromCharCode('0x' + p1);\n      return c === '%' ? '%25' : c;\n    }));\n  };\n\n  var uriToBlob = function uriToBlob(uri) {\n    var byteString = window.atob(uri.split(',')[1]);\n    var mimeString = uri.split(',')[0].split(':')[1].split(';')[0];\n    var buffer = new ArrayBuffer(byteString.length);\n    var intArray = new Uint8Array(buffer);\n    for (var i = 0; i < byteString.length; i++) {\n      intArray[i] = byteString.charCodeAt(i);\n    }\n    return new Blob([buffer], { type: mimeString });\n  };\n\n  var query = function query(el, selector) {\n    if (!selector) return;\n    try {\n      return el.querySelector(selector) || el.parentNode && el.parentNode.querySelector(selector);\n    } catch (err) {\n      console.warn('Invalid CSS selector \"' + selector + '\"', err);\n    }\n  };\n\n  var detectCssFont = function detectCssFont(rule, href) {\n    // Match CSS font-face rules to external links.\n    // @font-face {\n    //   src: local('Abel'), url(https://fonts.gstatic.com/s/abel/v6/UzN-iejR1VoXU2Oc-7LsbvesZW2xOQ-xsNqO47m55DA.woff2);\n    // }\n    var match = rule.cssText.match(urlRegex);\n    var url = match && match[1] || '';\n    if (!url || url.match(/^data:/) || url === 'about:blank') return;\n    var fullUrl = url.startsWith('../') ? href + '/../' + url : url.startsWith('./') ? href + '/.' + url : url;\n    return {\n      text: rule.cssText,\n      format: getFontMimeTypeFromUrl(fullUrl),\n      url: fullUrl\n    };\n  };\n\n  var inlineImages = function inlineImages(el) {\n    return Promise.all(Array.from(el.querySelectorAll('image')).map(function (image) {\n      var href = image.getAttributeNS('http://www.w3.org/1999/xlink', 'href') || image.getAttribute('href');\n      if (!href) return Promise.resolve(null);\n      if (isExternal(href)) {\n        href += (href.indexOf('?') === -1 ? '?' : '&') + 't=' + new Date().valueOf();\n      }\n      return new Promise(function (resolve, reject) {\n        var canvas = document.createElement('canvas');\n        var img = new Image();\n        img.crossOrigin = 'anonymous';\n        img.src = href;\n        img.onerror = function () {\n          return reject(new Error('Could not load ' + href));\n        };\n        img.onload = function () {\n          canvas.width = img.width;\n          canvas.height = img.height;\n          canvas.getContext('2d').drawImage(img, 0, 0);\n          image.setAttributeNS('http://www.w3.org/1999/xlink', 'href', canvas.toDataURL('image/png'));\n          resolve(true);\n        };\n      });\n    }));\n  };\n\n  var cachedFonts = {};\n  var inlineFonts = function inlineFonts(fonts) {\n    return Promise.all(fonts.map(function (font) {\n      return new Promise(function (resolve, reject) {\n        if (cachedFonts[font.url]) return resolve(cachedFonts[font.url]);\n\n        var req = new XMLHttpRequest();\n        req.addEventListener('load', function () {\n          // TODO: it may also be worth it to wait until fonts are fully loaded before\n          // attempting to rasterize them. (e.g. use https://developer.mozilla.org/en-US/docs/Web/API/FontFaceSet)\n          var fontInBase64 = arrayBufferToBase64(req.response);\n          var fontUri = font.text.replace(urlRegex, 'url(\"data:' + font.format + ';base64,' + fontInBase64 + '\")') + '\\n';\n          cachedFonts[font.url] = fontUri;\n          resolve(fontUri);\n        });\n        req.addEventListener('error', function (e) {\n          console.warn('Failed to load font from: ' + font.url, e);\n          cachedFonts[font.url] = null;\n          resolve(null);\n        });\n        req.addEventListener('abort', function (e) {\n          console.warn('Aborted loading font from: ' + font.url, e);\n          resolve(null);\n        });\n        req.open('GET', font.url);\n        req.responseType = 'arraybuffer';\n        req.send();\n      });\n    })).then(function (fontCss) {\n      return fontCss.filter(function (x) {\n        return x;\n      }).join('');\n    });\n  };\n\n  var cachedRules = null;\n  var styleSheetRules = function styleSheetRules() {\n    if (cachedRules) return cachedRules;\n    return cachedRules = Array.from(document.styleSheets).map(function (sheet) {\n      try {\n        return { rules: sheet.cssRules, href: sheet.href };\n      } catch (e) {\n        console.warn('Stylesheet could not be loaded: ' + sheet.href, e);\n        return {};\n      }\n    });\n  };\n\n  var inlineCss = function inlineCss(el, options) {\n    var _ref = options || {},\n        selectorRemap = _ref.selectorRemap,\n        modifyStyle = _ref.modifyStyle,\n        modifyCss = _ref.modifyCss,\n        fonts = _ref.fonts,\n        excludeUnusedCss = _ref.excludeUnusedCss;\n\n    var generateCss = modifyCss || function (selector, properties) {\n      var sel = selectorRemap ? selectorRemap(selector) : selector;\n      var props = modifyStyle ? modifyStyle(properties) : properties;\n      return sel + '{' + props + '}\\n';\n    };\n    var css = [];\n    var detectFonts = typeof fonts === 'undefined';\n    var fontList = fonts || [];\n    styleSheetRules().forEach(function (_ref2) {\n      var rules = _ref2.rules,\n          href = _ref2.href;\n\n      if (!rules) return;\n      Array.from(rules).forEach(function (rule) {\n        if (typeof rule.style != 'undefined') {\n          if (query(el, rule.selectorText)) css.push(generateCss(rule.selectorText, rule.style.cssText));else if (detectFonts && rule.cssText.match(/^@font-face/)) {\n            var font = detectCssFont(rule, href);\n            if (font) fontList.push(font);\n          } else if (!excludeUnusedCss) {\n            css.push(rule.cssText);\n          }\n        }\n      });\n    });\n\n    return inlineFonts(fontList).then(function (fontCss) {\n      return css.join('\\n') + fontCss;\n    });\n  };\n\n  var downloadOptions = function downloadOptions() {\n    if (!navigator.msSaveOrOpenBlob && !('download' in document.createElement('a'))) {\n      return { popup: window.open() };\n    }\n  };\n\n  out$.prepareSvg = function (el, options, done) {\n    requireDomNode(el);\n\n    var _ref3 = options || {},\n        _ref3$left = _ref3.left,\n        left = _ref3$left === undefined ? 0 : _ref3$left,\n        _ref3$top = _ref3.top,\n        top = _ref3$top === undefined ? 0 : _ref3$top,\n        w = _ref3.width,\n        h = _ref3.height,\n        _ref3$scale = _ref3.scale,\n        scale = _ref3$scale === undefined ? 1 : _ref3$scale,\n        _ref3$responsive = _ref3.responsive,\n        responsive = _ref3$responsive === undefined ? false : _ref3$responsive,\n        _ref3$excludeCss = _ref3.excludeCss,\n        excludeCss = _ref3$excludeCss === undefined ? false : _ref3$excludeCss;\n\n    return inlineImages(el).then(function () {\n      var clone = el.cloneNode(true);\n      clone.style.backgroundColor = (options || {}).backgroundColor || el.style.backgroundColor;\n\n      var _getDimensions = getDimensions(el, clone, w, h),\n          width = _getDimensions.width,\n          height = _getDimensions.height;\n\n      if (el.tagName !== 'svg') {\n        if (el.getBBox) {\n          if (clone.getAttribute('transform') != null) {\n            clone.setAttribute('transform', clone.getAttribute('transform').replace(/translate\\(.*?\\)/, ''));\n          }\n          var svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg');\n          svg.appendChild(clone);\n          clone = svg;\n        } else {\n          console.error('Attempted to render non-SVG element', el);\n          return;\n        }\n      }\n\n      clone.setAttribute('version', '1.1');\n      clone.setAttribute('viewBox', [left, top, width, height].join(' '));\n      if (!clone.getAttribute('xmlns')) clone.setAttributeNS(xmlNs, 'xmlns', svgNs);\n      if (!clone.getAttribute('xmlns:xlink')) clone.setAttributeNS(xmlNs, 'xmlns:xlink', 'http://www.w3.org/1999/xlink');\n\n      if (responsive) {\n        clone.removeAttribute('width');\n        clone.removeAttribute('height');\n        clone.setAttribute('preserveAspectRatio', 'xMinYMin meet');\n      } else {\n        clone.setAttribute('width', width * scale);\n        clone.setAttribute('height', height * scale);\n      }\n\n      Array.from(clone.querySelectorAll('foreignObject > *')).forEach(function (foreignObject) {\n        foreignObject.setAttributeNS(xmlNs, 'xmlns', foreignObject.tagName === 'svg' ? svgNs : xhtmlNs);\n      });\n\n      if (excludeCss) {\n        var outer = document.createElement('div');\n        outer.appendChild(clone);\n        var src = outer.innerHTML;\n        if (typeof done === 'function') done(src, width, height);else return { src: src, width: width, height: height };\n      } else {\n        return inlineCss(el, options).then(function (css) {\n          var style = document.createElement('style');\n          style.setAttribute('type', 'text/css');\n          style.innerHTML = '<![CDATA[\\n' + css + '\\n]]>';\n\n          var defs = document.createElement('defs');\n          defs.appendChild(style);\n          clone.insertBefore(defs, clone.firstChild);\n\n          var outer = document.createElement('div');\n          outer.appendChild(clone);\n          var src = outer.innerHTML.replace(/NS\\d+:href/gi, 'xmlns:xlink=\"http://www.w3.org/1999/xlink\" xlink:href');\n\n          if (typeof done === 'function') done(src, width, height);else return { src: src, width: width, height: height };\n        });\n      }\n    });\n  };\n\n  out$.svgAsDataUri = function (el, options, done) {\n    requireDomNode(el);\n    return out$.prepareSvg(el, options).then(function (_ref4) {\n      var src = _ref4.src,\n          width = _ref4.width,\n          height = _ref4.height;\n\n      var svgXml = 'data:image/svg+xml;base64,' + window.btoa(reEncode(doctype + src));\n      if (typeof done === 'function') {\n        done(svgXml, width, height);\n      }\n      return svgXml;\n    });\n  };\n\n  out$.svgAsPngUri = function (el, options, done) {\n    requireDomNode(el);\n\n    var _ref5 = options || {},\n        _ref5$encoderType = _ref5.encoderType,\n        encoderType = _ref5$encoderType === undefined ? 'image/png' : _ref5$encoderType,\n        _ref5$encoderOptions = _ref5.encoderOptions,\n        encoderOptions = _ref5$encoderOptions === undefined ? 0.8 : _ref5$encoderOptions,\n        canvg = _ref5.canvg;\n\n    var convertToPng = function convertToPng(_ref6) {\n      var src = _ref6.src,\n          width = _ref6.width,\n          height = _ref6.height;\n\n      var canvas = document.createElement('canvas');\n      var context = canvas.getContext('2d');\n      var pixelRatio = window.devicePixelRatio || 1;\n\n      canvas.width = width * pixelRatio;\n      canvas.height = height * pixelRatio;\n      canvas.style.width = canvas.width + 'px';\n      canvas.style.height = canvas.height + 'px';\n      context.setTransform(pixelRatio, 0, 0, pixelRatio, 0, 0);\n\n      if (canvg) canvg(canvas, src);else context.drawImage(src, 0, 0);\n\n      var png = void 0;\n      try {\n        png = canvas.toDataURL(encoderType, encoderOptions);\n      } catch (e) {\n        if (typeof SecurityError !== 'undefined' && e instanceof SecurityError || e.name === 'SecurityError') {\n          console.error('Rendered SVG images cannot be downloaded in this browser.');\n          return;\n        } else throw e;\n      }\n      if (typeof done === 'function') done(png, canvas.width, canvas.height);\n      return Promise.resolve(png);\n    };\n\n    if (canvg) return out$.prepareSvg(el, options).then(convertToPng);else return out$.svgAsDataUri(el, options).then(function (uri) {\n      return new Promise(function (resolve, reject) {\n        var image = new Image();\n        image.onload = function () {\n          return resolve(convertToPng({\n            src: image,\n            width: image.width,\n            height: image.height\n          }));\n        };\n        image.onerror = function () {\n          reject('There was an error loading the data URI as an image on the following SVG\\n' + window.atob(uri.slice(26)) + 'Open the following link to see browser\\'s diagnosis\\n' + uri);\n        };\n        image.src = uri;\n      });\n    });\n  };\n\n  out$.download = function (name, uri, options) {\n    if (navigator.msSaveOrOpenBlob) navigator.msSaveOrOpenBlob(uriToBlob(uri), name);else {\n      var saveLink = document.createElement('a');\n      if ('download' in saveLink) {\n        saveLink.download = name;\n        saveLink.style.display = 'none';\n        document.body.appendChild(saveLink);\n        try {\n          var blob = uriToBlob(uri);\n          var url = URL.createObjectURL(blob);\n          saveLink.href = url;\n          saveLink.onclick = function () {\n            return requestAnimationFrame(function () {\n              return URL.revokeObjectURL(url);\n            });\n          };\n        } catch (e) {\n          console.error(e);\n          console.warn('Error while getting object URL. Falling back to string URL.');\n          saveLink.href = uri;\n        }\n        saveLink.click();\n        document.body.removeChild(saveLink);\n      } else if (options && options.popup) {\n        options.popup.document.title = name;\n        options.popup.location.replace(uri);\n      }\n    }\n  };\n\n  out$.saveSvg = function (el, name, options) {\n    var downloadOpts = downloadOptions(); // don't inline, can't be async\n    return requireDomNodePromise(el).then(function (el) {\n      return out$.svgAsDataUri(el, options || {});\n    }).then(function (uri) {\n      return out$.download(name, uri, downloadOpts);\n    });\n  };\n\n  out$.saveSvgAsPng = function (el, name, options) {\n    var downloadOpts = downloadOptions(); // don't inline, can't be async\n    return requireDomNodePromise(el).then(function (el) {\n      return out$.svgAsPngUri(el, options || {});\n    }).then(function (uri) {\n      return out$.download(name, uri, downloadOpts);\n    });\n  };\n})();","export const ICDS = `DISPLAY\nNO DATA\n`;\n","export const IDPS = `DISPLAY\nNO DATA\n`;\n","const rnaColor = 'rgb(255,230,153)';\nconst invAbasicColor = 'rgb(255,230,153)';\nexport const axolabsMap = {\n    'RNA': {\n        fullName: 'RNA nucleotides',\n        symbols: ['A', 'C', 'G', 'U'],\n        color: rnaColor,\n    },\n    'DNA': {\n        fullName: 'DNA nucleotides',\n        symbols: ['dA', 'dC', 'dG', 'dT'],\n        color: 'rgb(197,224,180)',\n    },\n    '2\\'-Fluoro': {\n        fullName: '2\\'-Fluoro nucleotides',\n        symbols: ['Af', 'Cf', 'Gf', 'Uf'],\n        color: 'rgb(68,114,196)',\n    },\n    '2\\'-O-Methyl': {\n        fullName: '2\\'-O-Methyl nucleotides',\n        symbols: ['a', 'c', 'g', 'u'],\n        color: 'rgb(166,166,166)',\n    },\n    '2\\'-O-MOE': {\n        fullName: '2\\'-O-MOE nucleotides (including 5-Methyl C)',\n        symbols: ['Am', 'Cm', 'Gm', 'Tm'],\n        color: 'rgb(112,48,160)',\n    },\n    'GNA': {\n        fullName: 'Glycol nucleic acid',\n        symbols: ['(GNA-A)', '(GNA-C)', '(GNA-G)', '(GNA-T)'],\n        color: 'rgb(255,192,0)',\n    },\n    'LNA': {\n        fullName: 'Locked nucleic acid (including 5-Methyl C)',\n        symbols: ['Ab', 'Cb', 'Gb', 'Tb'],\n        color: 'rgb(54,229,238)',\n    },\n    'UNA': {\n        fullName: 'Unlocked nucleotides',\n        symbols: ['Ao', 'Co', 'Go', 'Uo'],\n        color: 'rgb(255,192,0)',\n    },\n    'A': {\n        fullName: 'Adenine',\n        symbols: ['a', 'a', 'a', 'a'],\n        color: rnaColor,\n    },\n    'C': {\n        fullName: 'Cytosine',\n        symbols: ['c', 'c', 'c', 'c'],\n        color: rnaColor,\n    },\n    'G': {\n        fullName: 'Guanine',\n        symbols: ['g', 'g', 'g', 'g'],\n        color: rnaColor,\n    },\n    'U': {\n        fullName: 'Uracil',\n        symbols: ['u', 'u', 'u', 'u'],\n        color: rnaColor,\n    },\n    'X-New': {\n        fullName: '',\n        symbols: ['X', 'X', 'X', 'X'],\n        color: 'rgb(108,0,0)',\n    },\n    'Y-New': {\n        fullName: '',\n        symbols: ['Y', 'Y', 'Y', 'Y'],\n        color: 'rgb(210,146,146)',\n    },\n    'Z-New': {\n        fullName: '',\n        symbols: ['Z', 'Z', 'Z', 'Z'],\n        color: 'rgb(155,108,132)',\n    },\n    'InvAbasic': {\n        fullName: 'Inverted abasic capped',\n        symbols: ['(invabasic)', '(invabasic)', '(invabasic)', '(invabasic)'],\n        color: invAbasicColor,\n    },\n    '5\\'-vinylps': {\n        fullName: '5\\'-vinylphosphonate-2\\'-OMe-uridine',\n        symbols: ['(vinu)', '(vinu)', '(vinu)', '(vinu)'],\n        color: 'rgb(0,0,139)',\n    },\n    'InvAbasic(o)': {\n        fullName: 'Inverted abasic capped (overhang)',\n        symbols: ['(invabasic)', '(invabasic)', '(invabasic)', '(invabasic)'],\n        color: invAbasicColor,\n    },\n    '2\\'-OMe-U(o)': {\n        fullName: 'Nucleotide Uridine with 2’O-Methyl protection (overhang)',\n        symbols: ['mU', 'mU', 'mU', 'mU'],\n        color: 'rgb(65,233,80)',\n    },\n};\n","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\n/* Do not change these import lines. Datagrok will import API library in exactly the same manner */\nimport * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\n// @ts-ignore\nimport * as svg from 'save-svg-as-png';\nimport $ from 'cash-dom';\nimport { drawAxolabsPattern } from './drawAxolabsPattern';\nimport { axolabsMap } from './axolabsMap';\nconst baseChoices = Object.keys(axolabsMap);\nconst defaultBase = baseChoices[0];\nconst defaultPto = true;\nconst defaultSequenceLength = 23;\nconst maximalValidSequenceLength = 35;\nconst userStorageKey = 'SequenceTranslator';\nconst exampleMinWidth = '400px';\nfunction generateExample(sequenceLength, sequenceBasis) {\n    const uniqueSymbols = axolabsMap[sequenceBasis].symbols.join('');\n    return uniqueSymbols.repeat(Math.floor(sequenceLength / 4)) + uniqueSymbols.slice(0, sequenceLength % 4);\n}\nfunction findDuplicates(data) {\n    return Array.from(new Set(data)).filter((value) => data.indexOf(value) !== data.lastIndexOf(value));\n}\nfunction isCurrentUserCreatedThisPattern(patternName) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return yield grok.dapi.users.current().then((user) => {\n            const [firstName, lastName] = getUserName(patternName);\n            return (user.firstName != firstName || user.lastName != lastName);\n        });\n    });\n}\nfunction getShortName(patternName) {\n    let first = patternName.length + 1;\n    for (let i = 0; i < patternName.length; i++) {\n        if (patternName[i] == '(') {\n            first = i;\n            break;\n        }\n    }\n    return patternName.slice(0, first - 1);\n}\nfunction getUserName(patternName) {\n    let first = -1;\n    for (let i = 0; i < patternName.length; i++) {\n        if (patternName[i] == '(') {\n            first = i;\n            break;\n        }\n    }\n    return (first == -1) ? ['', ''] : patternName.slice(first + 9, patternName.length - 1).split(' ').slice(1);\n}\nfunction translateSequence(sequence, bases, ptoLinkages, startModification, endModification, firstPtoExist) {\n    let counter = -1;\n    let mainSequence = sequence.replace(/[AUGC]/g, function (x) {\n        counter++;\n        const indexOfSymbol = axolabsMap['RNA']['symbols'].indexOf(x);\n        const symbol = axolabsMap[bases[counter].value]['symbols'][indexOfSymbol];\n        return (ptoLinkages[counter].value) ? symbol + 's' : symbol;\n    });\n    if (mainSequence.slice(0, 5).split('mU').length == 3)\n        mainSequence = '(uu)' + mainSequence.slice(4);\n    if (mainSequence.slice(mainSequence.length - 7).split('mU').length == 3)\n        mainSequence = mainSequence.slice(0, mainSequence.length - 4) + '(uu)';\n    return startModification.value + (firstPtoExist ? 's' : '') + mainSequence + endModification.value;\n}\nfunction addColumnWithIds(tableName, columnName, patternName) {\n    const nameOfNewColumn = 'ID ' + patternName;\n    const columns = grok.shell.table(tableName).columns;\n    if (columns.contains(nameOfNewColumn))\n        columns.remove(nameOfNewColumn);\n    const columnWithIds = columns.byName(columnName);\n    return columns.addNewString(nameOfNewColumn).init((i) => columnWithIds.get(i) + '_' + patternName);\n}\nfunction addColumnWithTranslatedSequences(tableName, columnName, bases, ptoLinkages, startModification, endModification, firstPtoExist) {\n    const nameOfNewColumn = 'Axolabs ' + columnName;\n    const columns = grok.shell.table(tableName).columns;\n    if (columns.contains(nameOfNewColumn))\n        columns.remove(nameOfNewColumn);\n    const columnWithInputSequences = columns.byName(columnName);\n    return columns.addNewString(nameOfNewColumn).init((i) => {\n        return translateSequence(columnWithInputSequences.getString(i), bases, ptoLinkages, startModification, endModification, firstPtoExist);\n    });\n}\nexport function defineAxolabsPattern() {\n    const enumerateModifications = [defaultBase];\n    let maximalSsLength = defaultSequenceLength;\n    let maximalAsLength = defaultSequenceLength;\n    function updateAsModification() {\n        asModificationItems.innerHTML = '';\n        asPtoLinkages = asPtoLinkages.concat(Array(maximalAsLength - asBases.length).fill(fullyPto));\n        asBases = asBases.concat(Array(maximalAsLength - asBases.length).fill(sequenceBase));\n        let nucleotideCounter = 0;\n        for (let i = 0; i < asLength.value; i++) {\n            asPtoLinkages[i] = ui.boolInput('', asPtoLinkages[i].value, () => {\n                updateSvgScheme();\n                updateOutputExamples();\n            });\n            asBases[i] = ui.choiceInput('', asBases[i].value, baseChoices, (v) => {\n                if (!enumerateModifications.includes(v)) {\n                    enumerateModifications.push(v);\n                    isEnumerateModificationsDiv.append(ui.boolInput(v, true, (boolV) => {\n                        if (boolV) {\n                            if (!enumerateModifications.includes(v))\n                                enumerateModifications.push(v);\n                        }\n                        else {\n                            const index = enumerateModifications.indexOf(v, 0);\n                            if (index > -1)\n                                enumerateModifications.splice(index, 1);\n                        }\n                        updateSvgScheme();\n                    }).root);\n                }\n                updateAsModification();\n                updateSvgScheme();\n                updateOutputExamples();\n            });\n            if (asBases[i].value.slice(-3) != '(o)')\n                nucleotideCounter++;\n            asModificationItems.append(ui.divH([\n                ui.div([ui.label(asBases[i].value.slice(-3) == '(o)' ? '' : String(nucleotideCounter))], { style: { width: '20px' } }),\n                ui.block75([asBases[i]]),\n                ui.div([asPtoLinkages[i]]),\n            ], { style: { alignItems: 'center' } }));\n        }\n    }\n    function updateSsModification() {\n        ssModificationItems.innerHTML = '';\n        ssPtoLinkages = ssPtoLinkages.concat(Array(maximalSsLength - ssBases.length).fill(fullyPto));\n        ssBases = ssBases.concat(Array(maximalSsLength - ssBases.length).fill(sequenceBase));\n        let nucleotideCounter = 0;\n        for (let i = 0; i < ssLength.value; i++) {\n            ssPtoLinkages[i] = ui.boolInput('', ssPtoLinkages[i].value, () => {\n                updateSvgScheme();\n                updateOutputExamples();\n            });\n            ssBases[i] = ui.choiceInput('', ssBases[i].value, baseChoices, (v) => {\n                if (!enumerateModifications.includes(v)) {\n                    enumerateModifications.push(v);\n                    isEnumerateModificationsDiv.append(ui.boolInput(v, true, (boolV) => {\n                        if (boolV) {\n                            if (!enumerateModifications.includes(v))\n                                enumerateModifications.push(v);\n                        }\n                        else {\n                            const index = enumerateModifications.indexOf(v, 0);\n                            if (index > -1)\n                                enumerateModifications.splice(index, 1);\n                        }\n                        updateSvgScheme();\n                    }).root);\n                }\n                updateSsModification();\n                updateSvgScheme();\n                updateOutputExamples();\n            });\n            if (ssBases[i].value.slice(-3) != '(o)')\n                nucleotideCounter++;\n            ssModificationItems.append(ui.divH([\n                ui.div([ui.label(ssBases[i].value.slice(-3) == '(o)' ? '' : String(nucleotideCounter))], { style: { width: '20px' } }),\n                ui.block75([ssBases[i]]),\n                ui.div([ssPtoLinkages[i]]),\n            ], { style: { alignItems: 'center' } }));\n        }\n    }\n    function updateUiForNewSequenceLength() {\n        if (ssLength.value < maximalValidSequenceLength && asLength.value < maximalValidSequenceLength) {\n            if (ssLength.value > maximalSsLength)\n                maximalSsLength = ssLength.value;\n            if (asLength.value > maximalAsLength)\n                maximalAsLength = asLength.value;\n            updateSsModification();\n            updateAsModification();\n            updateSvgScheme();\n            updateInputExamples();\n            updateOutputExamples();\n        }\n        else {\n            ui.dialog('Sequence length is out of range')\n                .add(ui.divText('Sequence length should be less than ' +\n                maximalValidSequenceLength.toString() + ' due to UI constrains.'))\n                .add(ui.divText('Please change sequence length in order to define new pattern.'))\n                .show();\n        }\n    }\n    function updatePto(newPtoValue) {\n        for (let i = 0; i < ssPtoLinkages.length; i++)\n            ssPtoLinkages[i].value = newPtoValue;\n        for (let i = 0; i < asPtoLinkages.length; i++)\n            asPtoLinkages[i].value = newPtoValue;\n        updateSvgScheme();\n    }\n    function updateBases(newBasisValue) {\n        for (let i = 0; i < ssBases.length; i++)\n            ssBases[i].value = newBasisValue;\n        for (let i = 0; i < asBases.length; i++)\n            asBases[i].value = newBasisValue;\n        updateSvgScheme();\n    }\n    function updateInputExamples() {\n        ssInputExample.value = generateExample(ssLength.value, sequenceBase.value);\n        if (createAsStrand.value)\n            asInputExample.value = generateExample(asLength.value, sequenceBase.value);\n    }\n    function updateOutputExamples() {\n        ssOutputExample.value = translateSequence(ssInputExample.value, ssBases, ssPtoLinkages, ssFiveModification, ssThreeModification, firstSsPto.value);\n        if (createAsStrand.value) {\n            asOutputExample.value = translateSequence(asInputExample.value, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstAsPto.value);\n        }\n    }\n    function updateSvgScheme() {\n        svgDiv.innerHTML = '';\n        svgDiv.append(ui.span([\n            drawAxolabsPattern(getShortName(saveAs.value), createAsStrand.value, ssBases.slice(0, ssLength.value).map((e) => e.value), asBases.slice(0, asLength.value).map((e) => e.value), [firstSsPto.value].concat(ssPtoLinkages.slice(0, ssLength.value).map((e) => e.value)), [firstAsPto.value].concat(asPtoLinkages.slice(0, asLength.value).map((e) => e.value)), ssThreeModification.value, ssFiveModification.value, asThreeModification.value, asFiveModification.value, comment.value, enumerateModifications),\n        ]));\n    }\n    function detectDefaultBasis(array) {\n        const modeMap = {};\n        let maxEl = array[0];\n        let maxCount = 1;\n        for (let i = 0; i < array.length; i++) {\n            const el = array[i];\n            if (modeMap[el] == null)\n                modeMap[el] = 1;\n            else\n                modeMap[el]++;\n            if (modeMap[el] > maxCount) {\n                maxEl = el;\n                maxCount = modeMap[el];\n            }\n        }\n        return maxEl;\n    }\n    function parsePatternAndUpdateUi(newName) {\n        return __awaiter(this, void 0, void 0, function* () {\n            const pi = DG.TaskBarProgressIndicator.create('Loading pattern...');\n            yield grok.dapi.userDataStorage.get(userStorageKey, false).then((entities) => {\n                const obj = JSON.parse(entities[newName]);\n                sequenceBase.value = detectDefaultBasis(obj['asBases'].concat(obj['ssBases']));\n                createAsStrand.value = (obj['asBases'].length > 0);\n                saveAs.value = newName;\n                ssBases = [];\n                for (let i = 0; i < obj['ssBases'].length; i++)\n                    ssBases.push(ui.choiceInput('', obj['ssBases'][i], baseChoices));\n                asBases = [];\n                for (let i = 0; i < obj['asBases'].length; i++)\n                    asBases.push(ui.choiceInput('', obj['asBases'][i], baseChoices));\n                firstSsPto.value = obj['ssPtoLinkages'][0];\n                ssPtoLinkages = [];\n                for (let i = 1; i < obj['ssPtoLinkages'].length; i++)\n                    ssPtoLinkages.push(ui.boolInput('', obj['ssPtoLinkages'][i]));\n                firstAsPto.value = obj['asPtoLinkages'][0];\n                asPtoLinkages = [];\n                for (let i = 1; i < obj['asPtoLinkages'].length; i++)\n                    asPtoLinkages.push(ui.boolInput('', obj['asPtoLinkages'][i]));\n                ssLength.value = obj['ssBases'].length;\n                asLength.value = obj['asBases'].length;\n                ssThreeModification.value = obj['ssThreeModification'];\n                ssFiveModification.value = obj['ssFiveModification'];\n                asThreeModification.value = obj['asThreeModification'];\n                asFiveModification.value = obj['asFiveModification'];\n                comment.value = obj['comment'];\n            });\n            pi.close();\n        });\n    }\n    function checkWhetherAllValuesInColumnHaveTheSameLength(colName) {\n        const col = tables.value.columns.byName(colName);\n        let allLengthsAreTheSame = true;\n        for (let i = 1; i < col.length; i++) {\n            if (col.get(i - 1).length != col.get(i).length) {\n                allLengthsAreTheSame = false;\n                break;\n            }\n        }\n        if (!allLengthsAreTheSame) {\n            const dialog = ui.dialog('Sequences lengths mismatch');\n            $(dialog.getButton('OK')).hide();\n            dialog\n                .add(ui.divText('The sequence length should match the number of Raw sequences in the input file'))\n                .add(ui.divText('\\'ADD COLUMN\\' to see sequences lengths'))\n                .addButton('ADD COLUMN', () => {\n                tables.value.columns.addNewInt('Sequences lengths in ' + colName).init((j) => col.get(j).length);\n                grok.shell.info('Column with lengths added to \\'' + tables.value.name + '\\'');\n                dialog.close();\n                grok.shell.v = grok.shell.getTableView(tables.value.name);\n            })\n                .show();\n        }\n        return allLengthsAreTheSame;\n    }\n    function getCurrentUserName() {\n        return __awaiter(this, void 0, void 0, function* () {\n            return yield grok.dapi.users.current().then((user) => {\n                return ' (created by ' + user.firstName + ' ' + user.lastName + ')';\n            });\n        });\n    }\n    function postPatternToUserStorage() {\n        return __awaiter(this, void 0, void 0, function* () {\n            const author = yield getCurrentUserName();\n            if (!saveAs.stringValue.includes('(created by '))\n                saveAs.value = saveAs.stringValue + author;\n            return grok.dapi.userDataStorage.postValue(userStorageKey, saveAs.stringValue, JSON.stringify({\n                'ssBases': ssBases.slice(0, ssLength.value).map((e) => e.value),\n                'asBases': asBases.slice(0, asLength.value).map((e) => e.value),\n                'ssPtoLinkages': [firstSsPto.value].concat(ssPtoLinkages.slice(0, ssLength.value).map((e) => e.value)),\n                'asPtoLinkages': [firstAsPto.value].concat(asPtoLinkages.slice(0, asLength.value).map((e) => e.value)),\n                'ssThreeModification': ssThreeModification.value,\n                'ssFiveModification': ssFiveModification.value,\n                'asThreeModification': asThreeModification.value,\n                'asFiveModification': asFiveModification.value,\n                'comment': comment.value,\n            }), false).then(() => grok.shell.info('Pattern \\'' + saveAs.value + '\\' was successfully uploaded!'));\n        });\n    }\n    function updatePatternsList() {\n        return __awaiter(this, void 0, void 0, function* () {\n            grok.dapi.userDataStorage.get(userStorageKey, false).then((entities) => __awaiter(this, void 0, void 0, function* () {\n                const lstMy = [];\n                const lstOthers = [];\n                for (const ent of Object.keys(entities)) {\n                    if (yield isCurrentUserCreatedThisPattern(ent))\n                        lstOthers.push(ent);\n                    else\n                        lstMy.push(getShortName(ent));\n                }\n                let loadPattern = ui.choiceInput('Load Pattern', '', lstMy, (v) => parsePatternAndUpdateUi(v));\n                const myOrOthersPatternList = ui.choiceInput('', 'Mine', ['Mine', 'Others'], (v) => {\n                    const currentList = v == 'Mine' ? lstMy : lstOthers;\n                    loadPattern = ui.choiceInput('Load Pattern', '', currentList, (v) => parsePatternAndUpdateUi(v));\n                    loadPattern.root.append(myOrOthersPatternList.input);\n                    loadPattern.root.append(loadPattern.input);\n                    // @ts-ignore\n                    loadPattern.input.style.maxWidth = '100px';\n                    loadPattern.setTooltip('Apply Existing Pattern');\n                    loadPatternDiv.innerHTML = '';\n                    loadPatternDiv.append(loadPattern.root);\n                    loadPattern.root.append(ui.div([\n                        ui.button(ui.iconFA('trash-alt', () => { }), () => __awaiter(this, void 0, void 0, function* () {\n                            if (loadPattern.value == null)\n                                grok.shell.warning('Choose pattern to delete');\n                            else if (yield isCurrentUserCreatedThisPattern(saveAs.value))\n                                grok.shell.warning('Cannot delete pattern, created by other user');\n                            else {\n                                yield grok.dapi.userDataStorage.remove(userStorageKey, loadPattern.value, false)\n                                    .then(() => grok.shell.info('Pattern \\'' + loadPattern.value + '\\' deleted'));\n                            }\n                            yield updatePatternsList();\n                        })),\n                    ], 'ui-input-options'));\n                });\n                loadPattern.root.append(myOrOthersPatternList.input);\n                loadPattern.root.append(loadPattern.input);\n                // @ts-ignore\n                loadPattern.input.style.maxWidth = '100px';\n                loadPattern.setTooltip('Apply Existing Pattern');\n                loadPatternDiv.innerHTML = '';\n                loadPatternDiv.append(loadPattern.root);\n                loadPattern.root.append(ui.div([\n                    ui.button(ui.iconFA('trash-alt', () => { }), () => __awaiter(this, void 0, void 0, function* () {\n                        if (loadPattern.value == null)\n                            grok.shell.warning('Choose pattern to delete');\n                        else if (yield isCurrentUserCreatedThisPattern(saveAs.value))\n                            grok.shell.warning('Cannot delete pattern, created by other user');\n                        else {\n                            yield grok.dapi.userDataStorage.remove(userStorageKey, loadPattern.value, false)\n                                .then(() => grok.shell.info('Pattern \\'' + loadPattern.value + '\\' deleted'));\n                        }\n                        yield updatePatternsList();\n                    })),\n                ], 'ui-input-options'));\n            }));\n        });\n    }\n    function savePattern() {\n        return __awaiter(this, void 0, void 0, function* () {\n            yield grok.dapi.userDataStorage.get(userStorageKey, false)\n                .then((entities) => {\n                if (Object.keys(entities).includes(saveAs.value)) {\n                    const dialog = ui.dialog('Pattern already exists');\n                    $(dialog.getButton('OK')).hide();\n                    dialog\n                        .add(ui.divText('Pattern name \\'' + saveAs.value + '\\' already exists.'))\n                        .add(ui.divText('Replace pattern?'))\n                        .addButton('YES', () => __awaiter(this, void 0, void 0, function* () {\n                        yield grok.dapi.userDataStorage.remove(userStorageKey, saveAs.value, false)\n                            .then(() => postPatternToUserStorage());\n                        dialog.close();\n                    }))\n                        .show();\n                }\n                else\n                    postPatternToUserStorage();\n            });\n            yield updatePatternsList();\n        });\n    }\n    const inputSsColumnDiv = ui.div([]);\n    const inputAsColumnDiv = ui.div([]);\n    const inputIdColumnDiv = ui.div([]);\n    const ssModificationItems = ui.div([]);\n    const asModificationItems = ui.div([]);\n    const svgDiv = ui.div([]);\n    const asExampleDiv = ui.div([]);\n    const appAxolabsDescription = ui.div([]);\n    const loadPatternDiv = ui.div([]);\n    const asModificationDiv = ui.div([]);\n    const firstAsPtoDiv = ui.div([]);\n    const isEnumerateModificationsDiv = ui.divH([ui.boolInput(defaultBase, true, (v) => {\n            if (v) {\n                if (!enumerateModifications.includes(defaultBase))\n                    enumerateModifications.push(defaultBase);\n            }\n            else {\n                const index = enumerateModifications.indexOf(defaultBase, 0);\n                if (index > -1)\n                    enumerateModifications.splice(index, 1);\n            }\n            updateSvgScheme();\n            updateOutputExamples();\n        }).root]);\n    let ssBases = Array(defaultSequenceLength).fill(ui.choiceInput('', defaultBase, baseChoices));\n    let asBases = Array(defaultSequenceLength).fill(ui.choiceInput('', defaultBase, baseChoices));\n    let ssPtoLinkages = Array(defaultSequenceLength).fill(ui.boolInput('', defaultPto));\n    let asPtoLinkages = Array(defaultSequenceLength).fill(ui.boolInput('', defaultPto));\n    const ssLength = ui.intInput('SS Length', defaultSequenceLength, () => updateUiForNewSequenceLength());\n    const asLength = ui.intInput('AS Length', defaultSequenceLength, () => updateUiForNewSequenceLength());\n    const asLengthDiv = ui.div([asLength.root]);\n    function validateSsColumn(colName) {\n        const allLengthsAreTheSame = checkWhetherAllValuesInColumnHaveTheSameLength(colName);\n        const firstSequence = tables.value.columns.byName(colName).get(0);\n        if (allLengthsAreTheSame && firstSequence.length != ssLength.value)\n            ssLength.value = tables.value.columns.byName(colName).get(0).length;\n        ssInputExample.value = firstSequence;\n    }\n    function validateAsColumn(colName) {\n        const allLengthsAreTheSame = checkWhetherAllValuesInColumnHaveTheSameLength(colName);\n        const firstSequence = tables.value.columns.byName(colName).get(0);\n        if (allLengthsAreTheSame && firstSequence.length != asLength.value)\n            asLength.value = tables.value.columns.byName(colName).get(0).length;\n        asLengthDiv.innerHTML = '';\n        asLengthDiv.append(asLength.root);\n        asInputExample.value = firstSequence;\n    }\n    function validateIdsColumn(colName) {\n        const col = tables.value.columns.byName(colName);\n        if (col.type != DG.TYPE.INT)\n            grok.shell.error('Column should contain integers only');\n        else if (col.categories.length < col.length) {\n            const duplicates = findDuplicates(col.getRawData());\n            ui.dialog('Non-unique IDs')\n                .add(ui.divText('Press \\'OK\\' to select rows with non-unique values'))\n                .onOK(() => {\n                const selection = tables.value.selection;\n                selection.init((i) => duplicates.indexOf(col.get(i)) > -1);\n                grok.shell.v = grok.shell.getTableView(tables.value.name);\n                grok.shell.info('Rows are selected in table \\'' + tables.value.name + '\\'');\n            })\n                .show();\n        }\n    }\n    const tables = ui.tableInput('Tables', grok.shell.tables[0], grok.shell.tables, (t) => {\n        const inputSsColumn = ui.choiceInput('SS Column', '', t.columns.names(), (colName) => validateSsColumn(colName));\n        inputSsColumnDiv.innerHTML = '';\n        inputSsColumnDiv.append(inputSsColumn.root);\n        const inputAsColumn = ui.choiceInput('AS Column', '', t.columns.names(), (colName) => validateAsColumn(colName));\n        inputAsColumnDiv.innerHTML = '';\n        inputAsColumnDiv.append(inputAsColumn.root);\n        const inputIdColumn = ui.choiceInput('ID Column', '', t.columns.names(), (colName) => validateIdsColumn(colName));\n        inputIdColumnDiv.innerHTML = '';\n        inputIdColumnDiv.append(inputIdColumn.root);\n    });\n    const inputSsColumn = ui.choiceInput('SS Column', '', []);\n    inputSsColumnDiv.append(inputSsColumn.root);\n    const inputAsColumn = ui.choiceInput('AS Column', '', []);\n    inputAsColumnDiv.append(inputAsColumn.root);\n    const inputIdColumn = ui.choiceInput('ID Column', '', []);\n    inputIdColumnDiv.append(inputIdColumn.root);\n    updatePatternsList();\n    const sequenceBase = ui.choiceInput('Sequence Basis', defaultBase, baseChoices, (v) => {\n        updateBases(v);\n        updateOutputExamples();\n    });\n    const fullyPto = ui.boolInput('Fully PTO', defaultPto, (v) => {\n        firstSsPto.value = v;\n        firstAsPto.value = v;\n        updatePto(v);\n        updateOutputExamples();\n    });\n    const firstSsPto = ui.boolInput('First SS PTO', fullyPto.value, () => updateSvgScheme());\n    const firstAsPto = ui.boolInput('First AS PTO', fullyPto.value, () => updateSvgScheme());\n    firstAsPtoDiv.append(firstAsPto.root);\n    const createAsStrand = ui.boolInput('Create AS Strand', true, (v) => {\n        asModificationSection.hidden = (!v);\n        inputAsColumnDiv.hidden = (!v);\n        asLengthDiv.hidden = (!v);\n        asModificationDiv.hidden = (!v);\n        asExampleDiv.hidden = (!v);\n        firstAsPtoDiv.hidden = (!v);\n        updateSvgScheme();\n    });\n    const saveAs = ui.textInput('Save As', 'Pattern Name', () => updateSvgScheme());\n    saveAs.setTooltip('Name Of New Pattern');\n    const ssThreeModification = ui.stringInput('SS 3\\' Modification', '', () => {\n        updateSvgScheme();\n        updateOutputExamples();\n    });\n    ssThreeModification.setTooltip('Additional SS 3\\' Modification');\n    const ssFiveModification = ui.stringInput('SS 5\\' Modification', '', () => {\n        updateSvgScheme();\n        updateOutputExamples();\n    });\n    ssFiveModification.setTooltip('Additional SS 5\\' Modification');\n    const asThreeModification = ui.stringInput('AS 3\\' Modification', '', () => {\n        updateSvgScheme();\n        updateOutputExamples();\n    });\n    asThreeModification.setTooltip('Additional AS 3\\' Modification');\n    const asFiveModification = ui.stringInput('AS 5\\' Modification', '', () => {\n        updateSvgScheme();\n        updateOutputExamples();\n    });\n    asFiveModification.setTooltip('Additional AS 5\\' Modification');\n    asModificationDiv.append(asThreeModification.root);\n    asModificationDiv.append(asFiveModification.root);\n    const comment = ui.textInput('Comment', '', () => updateSvgScheme());\n    const savePatternButton = ui.button('Save', () => {\n        if (saveAs.value != '')\n            savePattern().then((r) => grok.shell.info('Pattern saved'));\n        else {\n            const name = ui.stringInput('Enter Name', '');\n            ui.dialog('Pattern Name')\n                .add(name.root)\n                .onOK(() => {\n                saveAs.value = name.value;\n                savePattern().then((r) => grok.shell.info('Pattern saved'));\n            })\n                .show();\n        }\n    });\n    const convertSequenceButton = ui.button('Convert Sequences', () => {\n        if (inputSsColumn.value == null || (createAsStrand.value && inputAsColumn.value == null))\n            grok.shell.info('Please select table and columns on which to apply pattern');\n        else if (ssLength.value != ssInputExample.value.length || asLength.value != asInputExample.value.length) {\n            const dialog = ui.dialog('Length Mismatch');\n            $(dialog.getButton('OK')).hide();\n            dialog\n                .add(ui.divText('Length of sequences in columns doesn\\'t match entered length. Update length value?'))\n                .addButton('YES', () => {\n                ssLength.value = tables.value.columns.byName(inputSsColumn.value).getString(0).length;\n                asLength.value = tables.value.columns.byName(inputAsColumn.value).getString(0).length;\n                dialog.close();\n            })\n                .show();\n        }\n        else {\n            if (inputIdColumn.value != null)\n                addColumnWithIds(tables.value.name, inputIdColumn.value, getShortName(saveAs.value));\n            addColumnWithTranslatedSequences(tables.value.name, inputSsColumn.value, ssBases, ssPtoLinkages, ssFiveModification, ssThreeModification, firstSsPto.value);\n            if (createAsStrand.value) {\n                addColumnWithTranslatedSequences(tables.value.name, inputAsColumn.value, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstAsPto.value);\n            }\n            grok.shell.v = grok.shell.getTableView(tables.value.name);\n            grok.shell.info(((createAsStrand.value) ? 'Columns were' : 'Column was') +\n                ' added to table \\'' + tables.value.name + '\\'');\n        }\n    });\n    const ssInputExample = ui.textInput('Sense Strand', generateExample(ssLength.value, sequenceBase.value), () => {\n        ssOutputExample.value = translateSequence(ssInputExample.value, ssBases, ssPtoLinkages, ssFiveModification, ssThreeModification, firstSsPto.value);\n    });\n    const ssOutputExample = ui.textInput(' ', translateSequence(ssInputExample.value, ssBases, ssPtoLinkages, ssThreeModification, ssFiveModification, firstSsPto.value));\n    ssInputExample.input.style.resize = 'none';\n    ssInputExample.input.style.minWidth = exampleMinWidth;\n    ssOutputExample.input.style.resize = 'none';\n    ssOutputExample.input.style.minWidth = exampleMinWidth;\n    // @ts-ignore\n    ssOutputExample.input.disabled = 'true';\n    ssOutputExample.root.append(ui.div([\n        ui.button(ui.iconFA('copy', () => { }), () => {\n            navigator.clipboard.writeText(ssOutputExample.value).then(() => grok.shell.info('Sequence was copied to clipboard'));\n        }),\n    ], 'ui-input-options'));\n    const asInputExample = ui.textInput('Antisense Strand', generateExample(asLength.value, sequenceBase.value), () => {\n        asOutputExample.value = translateSequence(asInputExample.value, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstSsPto.value);\n    });\n    const asOutputExample = ui.textInput(' ', translateSequence(asInputExample.value, asBases, asPtoLinkages, asFiveModification, asThreeModification, firstSsPto.value));\n    asInputExample.input.style.resize = 'none';\n    asInputExample.input.style.minWidth = exampleMinWidth;\n    asOutputExample.input.style.resize = 'none';\n    asOutputExample.input.style.minWidth = exampleMinWidth;\n    // @ts-ignore\n    asOutputExample.input.disabled = 'true';\n    asOutputExample.root.append(ui.div([\n        ui.button(ui.iconFA('copy', () => { }), () => {\n            navigator.clipboard.writeText(asOutputExample.value).then(() => grok.shell.info('Sequence was copied to clipboard'));\n        }),\n    ], 'ui-input-options'));\n    asExampleDiv.append(asInputExample.root);\n    asExampleDiv.append(asOutputExample.root);\n    updateUiForNewSequenceLength();\n    const exampleSection = ui.div([\n        ui.h1('Example'),\n        ssInputExample.root,\n        ssOutputExample.root,\n        asExampleDiv,\n    ], 'ui-form');\n    const inputsSection = ui.div([\n        ui.h1('Inputs'),\n        ui.divH([\n            tables.root,\n            inputSsColumnDiv,\n        ]),\n        ui.divH([\n            inputAsColumnDiv,\n            inputIdColumnDiv,\n        ]),\n        ui.buttonsInput([\n            convertSequenceButton,\n        ]),\n    ], 'ui-form');\n    const mainSection = ui.panel([\n        ui.block([\n            svgDiv,\n        ], { style: { overflowX: 'scroll' } }),\n        ui.button('Download', () => svg.saveSvgAsPng(document.getElementById('mySvg'), saveAs.value)),\n        isEnumerateModificationsDiv,\n        ui.div([\n            ui.div([\n                ui.divH([\n                    ui.h1('Pattern'),\n                    ui.div([\n                        ui.iconFA('question-circle', () => {\n                            appAxolabsDescription.innerHTML = '';\n                            appAxolabsDescription.append(info);\n                        }),\n                    ], { style: { padding: '2px' } }),\n                ]),\n                ui.divH([\n                    ui.div([\n                        ssLength.root,\n                        asLengthDiv,\n                        sequenceBase.root,\n                        comment.root,\n                        loadPatternDiv,\n                        saveAs.root,\n                        ui.buttonsInput([\n                            savePatternButton,\n                        ]),\n                    ], 'ui-form'),\n                    ui.div([\n                        createAsStrand.root,\n                        fullyPto.root,\n                        firstSsPto.root,\n                        firstAsPtoDiv,\n                        ssFiveModification.root,\n                        ssThreeModification.root,\n                        asModificationDiv,\n                    ], 'ui-form'),\n                ], 'ui-form'),\n            ], 'ui-form'),\n            inputsSection,\n            exampleSection,\n        ], { style: { flexWrap: 'wrap' } }),\n    ]);\n    const ssModificationSection = ui.panel([\n        ui.h1('Sense Strand'),\n        ui.divH([\n            ui.div([ui.divText('#')], { style: { width: '20px' } }),\n            ui.block75([ui.divText('Modification')]),\n            ui.div([ui.divText('PTO')], { style: { paddingRight: '8px' } }),\n        ]),\n        ssModificationItems,\n    ]);\n    const asModificationSection = ui.panel([\n        ui.h1('Antisense Strand'),\n        ui.divH([\n            ui.div([ui.divText('#')], { style: { width: '20px' } }),\n            ui.block75([ui.divText('Modification')]),\n            ui.div([ui.divText('PTO')], { style: { paddingRight: '8px' } }),\n        ]),\n        asModificationItems,\n    ]);\n    const info = ui.info([\n        ui.divText('\\n How to define new pattern:', { style: { 'font-weight': 'bolder' } }),\n        ui.divText('1. Choose table and columns with sense and antisense strands'),\n        ui.divText('2. Choose lengths of both strands by editing checkboxes below'),\n        ui.divText('3. Choose basis and PTO status for each nucleotide'),\n        ui.divText('4. Set additional modifications for sequence edges'),\n        ui.divText('5. Press \\'Convert Sequences\\' button'),\n        ui.divText('This will add the result column(s) to the right of the table'),\n    ], 'Create and apply Axolabs translation patterns.');\n    return ui.splitH([\n        ui.div([\n            appAxolabsDescription,\n            mainSection,\n        ]),\n        ui.box(ui.divH([\n            ssModificationSection,\n            asModificationSection,\n        ]), { style: { maxWidth: '360px' } }),\n    ]);\n}\n","import { axolabsMap } from './axolabsMap';\n// https://uxdesign.cc/star-rating-make-svg-great-again-d4ce4731347e\nfunction getPointsToDrawStar(centerX, centerY) {\n    const innerCirclePoints = 5; // a 5 point star\n    const innerRadius = 15 / innerCirclePoints;\n    const innerOuterRadiusRatio = 2; // outter circle is x2 the inner\n    const outerRadius = innerRadius * innerOuterRadiusRatio;\n    const angle = Math.PI / innerCirclePoints;\n    const angleOffsetToCenterStar = 60;\n    const totalNumberOfPoints = innerCirclePoints * 2; // 10 in a 5-points star\n    let points = '';\n    for (let i = 0; i < totalNumberOfPoints; i++) {\n        const r = (i % 2 == 0) ? outerRadius : innerRadius;\n        const currentX = centerX + Math.cos(i * angle + angleOffsetToCenterStar) * r;\n        const currentY = centerY + Math.sin(i * angle + angleOffsetToCenterStar) * r;\n        points += currentX + ',' + currentY + ' ';\n    }\n    return points;\n}\nfunction countOverhangsOnTheRightEdge(modifications) {\n    let i = 0;\n    while (i < modifications.length && modifications[i].slice(-3) == '(o)')\n        i++;\n    return (i == modifications.length - 1) ? 0 : i;\n}\nfunction getTextWidth(text, font) {\n    const context = document.createElement('canvas').getContext('2d');\n    // @ts-ignore\n    context.font = String(font);\n    // @ts-ignore\n    return 2 * context.measureText(text).width;\n}\nfunction getTextInsideCircle(bases, index, nucleotideCounter, numberOfNucleotides, enumerateModifications) {\n    return (bases[index].slice(-3) == '(o)') || !enumerateModifications.includes(bases[index]) ? '' :\n        ['A', 'G', 'C', 'U', 'T'].includes(bases[index]) ? bases[index] : String(numberOfNucleotides - nucleotideCounter);\n}\nfunction getFontColorVisibleOnBackground(rgbString) {\n    const rgbIntList = rgbString.match(/\\d+/g).map((e) => Number(e));\n    return (rgbIntList[0] * 0.299 + rgbIntList[1] * 0.587 + rgbIntList[2] * 0.114) > 186 ? '#33333' : '#ffffff';\n}\nfunction getBaseColor(base) {\n    return axolabsMap[base]['color'];\n}\nexport function drawAxolabsPattern(patternName, asExists, ssBases, asBases, ssPtoStatuses, asPtoStatuses, ssThreeModification, ssFiveModification, asThreeModification, asFiveModification, comment, enumerateModifications) {\n    function getEquidistantXForLegend(index) {\n        return Math.round((index + startFrom) * width / (uniqueBases.length + startFrom) + legendRadius);\n    }\n    function getXOfBaseCircles(index, rightOverhangs) {\n        return widthOfRightModification +\n            (resultingNumberOfNucleotidesInStrands - index + rightOverhangs + 1) * baseDiameter;\n    }\n    function getShiftToAlignNumberInsideCircle(bases, generalIndex, nucleotideIndex) {\n        return (nucleotideIndex < 10 || ['A', 'G', 'C', 'U', 'T'].\n            includes(bases[generalIndex])) ? shiftToAlignOneDigitNumberInsideCircle : shiftToAlignTwoDigitNumberInsideCircle;\n    }\n    const svg = {\n        xmlns: 'http://www.w3.org/2000/svg',\n        render: function (width, height) {\n            const e = document.createElementNS(this.xmlns, 'svg');\n            e.setAttribute('id', 'mySvg');\n            e.setAttribute('width', String(width));\n            e.setAttribute('height', String(height));\n            return e;\n        },\n        circle: function (x, y, radius, color) {\n            const e = document.createElementNS(this.xmlns, 'circle');\n            e.setAttribute('cx', String(x));\n            e.setAttribute('cy', String(y));\n            e.setAttribute('r', String(radius));\n            e.setAttribute('fill', color);\n            return e;\n        },\n        text: function (text, x, y, fontSize, color) {\n            const e = document.createElementNS(this.xmlns, 'text');\n            e.setAttribute('x', String(x));\n            e.setAttribute('y', String(y));\n            e.setAttribute('font-size', String(fontSize));\n            e.setAttribute('font-weight', 'normal');\n            e.setAttribute('font-family', 'Arial');\n            e.setAttribute('fill', color);\n            e.innerHTML = text;\n            return e;\n        },\n        star: function (x, y, fill) {\n            const e = document.createElementNS(this.xmlns, 'polygon');\n            e.setAttribute('points', getPointsToDrawStar(x, y));\n            e.setAttribute('fill', fill);\n            return e;\n        },\n    };\n    ssBases = ssBases.reverse();\n    ssPtoStatuses = ssPtoStatuses.reverse();\n    const baseRadius = 15;\n    const shiftToAlignTwoDigitNumberInsideCircle = -10;\n    const shiftToAlignOneDigitNumberInsideCircle = -5;\n    const legendRadius = 6;\n    const psLinkageRadius = 5;\n    const baseFontSize = 17;\n    const legendFontSize = 14;\n    const psLinkageColor = 'red';\n    const fontColor = 'var(--grey-6)';\n    const titleFontColor = 'black';\n    const modificationsColor = 'red';\n    const ssLeftText = 'SS: 5\\'';\n    const asLeftText = 'AS: 3\\'';\n    const ssRightText = '3\\'';\n    const asRightText = '5\\'';\n    const ssRightOverhangs = countOverhangsOnTheRightEdge(ssBases);\n    const asRightOverhangs = countOverhangsOnTheRightEdge(asBases);\n    const resultingNumberOfNucleotidesInStrands = Math.max(ssBases.length - ssRightOverhangs, asBases.length - asRightOverhangs);\n    const baseDiameter = 2 * baseRadius;\n    const widthOfBases = baseDiameter * (resultingNumberOfNucleotidesInStrands + Math.max(ssRightOverhangs, asRightOverhangs));\n    const widthOfLeftModification = Math.max(getTextWidth(ssThreeModification, baseFontSize), getTextWidth(asFiveModification, baseFontSize));\n    const widthOfRightModification = Math.max(getTextWidth(ssFiveModification, baseFontSize), getTextWidth(asThreeModification, baseFontSize));\n    const widthOfLeftText = Math.max(getTextWidth(ssLeftText, baseFontSize), getTextWidth(asLeftText, baseFontSize));\n    const widthOfRightText = Math.max(getTextWidth(ssRightText, baseFontSize), getTextWidth(asRightText, baseFontSize));\n    const width = widthOfLeftText + widthOfLeftModification + widthOfBases +\n        widthOfRightModification + widthOfRightText + baseDiameter;\n    const height = asExists ? 11 * baseRadius : 9 * baseRadius;\n    const xOfTitle = baseRadius; // Math.round(width / 4),\n    const uniqueBases = asExists ? [...new Set(ssBases.concat(asBases))] : [...new Set(ssBases)];\n    const isPtoExist = asExists ? [...new Set(ssPtoStatuses.concat(asPtoStatuses))].includes(true) :\n        [...new Set(ssPtoStatuses)].includes(true);\n    const startFrom = isPtoExist ? 1 : 0;\n    const xOfLeftTexts = 0;\n    const xOfLeftModifications = xOfLeftTexts + widthOfLeftText - 5;\n    const xOfSsRightModifications = ssRightOverhangs * baseDiameter + getXOfBaseCircles(-0.5, 0);\n    const xOfAsRightModifications = asRightOverhangs * baseDiameter + getXOfBaseCircles(-0.5, 0);\n    const xOfRightTexts = Math.max(xOfSsRightModifications, xOfAsRightModifications) +\n        widthOfLeftModification + baseDiameter * (Math.max(ssRightOverhangs, asRightOverhangs));\n    const yOfTitle = baseRadius;\n    const yOfSsTexts = 4 * baseRadius;\n    const yOfAsTexts = 7 * baseRadius;\n    const yOfComment = asExists ? 11 * baseRadius : 8.5 * baseRadius;\n    const yOfSsCircles = 3.5 * baseRadius;\n    const yOfAsCircles = 6.5 * baseRadius;\n    const yOfCirclesInLegends = asExists ? 9 * baseRadius : 6 * baseRadius;\n    const yOfTextLegend = asExists ? 9.5 * baseRadius - 3 : yOfAsCircles - 3;\n    const image = svg.render(width, height);\n    image.append(svg.text(ssLeftText, xOfLeftTexts, yOfSsTexts, baseFontSize, fontColor), asExists ? svg.text(asLeftText, xOfLeftTexts, yOfAsTexts, baseFontSize, fontColor) : '', svg.text(ssRightText, xOfRightTexts, yOfSsTexts, baseFontSize, fontColor), asExists ? svg.text(asRightText, xOfRightTexts, yOfAsTexts, baseFontSize, fontColor) : '', svg.text(ssFiveModification, xOfLeftModifications, yOfSsTexts, baseFontSize, modificationsColor), asExists ? svg.text(asThreeModification, xOfLeftModifications, yOfAsTexts, baseFontSize, modificationsColor) : '', svg.text(ssThreeModification, xOfSsRightModifications, yOfSsTexts, baseFontSize, modificationsColor), asExists ? svg.text(asFiveModification, xOfAsRightModifications, yOfAsTexts, baseFontSize, modificationsColor) : '', svg.text(comment, xOfLeftTexts, yOfComment, legendFontSize, fontColor), isPtoExist ? svg.star(baseRadius, yOfCirclesInLegends, psLinkageColor) : '', isPtoExist ? svg.text('ps linkage', 2 * baseRadius - 8, yOfTextLegend, legendFontSize, fontColor) : '');\n    let numberOfSsNucleotides = 0;\n    for (let i = 0; i < ssBases.length; i++) {\n        if (ssBases[i].slice(-3) != '(o)')\n            numberOfSsNucleotides++;\n    }\n    let nucleotideCounter = numberOfSsNucleotides;\n    for (let i = ssBases.length - 1; i > -1; i--) {\n        if (ssBases[i].slice(-3) != '(o)')\n            nucleotideCounter--;\n        image.append(svg.circle(getXOfBaseCircles(i, ssRightOverhangs), yOfSsCircles, baseRadius, getBaseColor(ssBases[i])), svg.text(getTextInsideCircle(ssBases, i, nucleotideCounter, numberOfSsNucleotides, enumerateModifications), getXOfBaseCircles(i, ssRightOverhangs) +\n            getShiftToAlignNumberInsideCircle(ssBases, ssBases.length - i, numberOfSsNucleotides - nucleotideCounter), yOfSsTexts, baseFontSize, getFontColorVisibleOnBackground(axolabsMap[ssBases[i]]['color'])), ssPtoStatuses[i] ?\n            svg.star(getXOfBaseCircles(i, ssRightOverhangs) + baseRadius, yOfSsTexts + psLinkageRadius, psLinkageColor) :\n            '');\n    }\n    image.append(ssPtoStatuses[ssBases.length] ?\n        svg.star(getXOfBaseCircles(ssBases.length, ssRightOverhangs) +\n            baseRadius, yOfSsTexts + psLinkageRadius, psLinkageColor) : '');\n    let numberOfAsNucleotides = 0;\n    for (let i = 0; i < asBases.length; i++) {\n        if (asBases[i].slice(-3) != '(o)')\n            numberOfAsNucleotides++;\n    }\n    if (asExists) {\n        let nucleotideCounter = numberOfAsNucleotides;\n        for (let i = asBases.length - 1; i > -1; i--) {\n            if (asBases[i].slice(-3) != '(o)')\n                nucleotideCounter--;\n            image.append(svg.circle(getXOfBaseCircles(i, asRightOverhangs), yOfAsCircles, baseRadius, getBaseColor(asBases[i])), svg.text(getTextInsideCircle(asBases, i, numberOfAsNucleotides - nucleotideCounter - 1, numberOfAsNucleotides, enumerateModifications), getXOfBaseCircles(i, asRightOverhangs) +\n                getShiftToAlignNumberInsideCircle(asBases, i, nucleotideCounter + 1), yOfAsTexts, baseFontSize, getFontColorVisibleOnBackground(axolabsMap[asBases[i]]['color'])), asPtoStatuses[i] ? svg.star(getXOfBaseCircles(i, asRightOverhangs) +\n                baseRadius, yOfAsTexts + psLinkageRadius, psLinkageColor) : '');\n        }\n        image.append(asPtoStatuses[asBases.length] ?\n            svg.star(getXOfBaseCircles(asBases.length, asRightOverhangs) +\n                baseRadius, yOfAsTexts + psLinkageRadius, psLinkageColor) : '');\n    }\n    const title = patternName + ' for ' +\n        String(numberOfSsNucleotides) + (asExists ? '/' + String(numberOfAsNucleotides) : '') + 'mer';\n    image.append(svg.text(title, xOfTitle, yOfTitle, baseFontSize, titleFontColor));\n    for (let i = 0; i < uniqueBases.length; i++) {\n        image.append(svg.circle(getEquidistantXForLegend(i), yOfCirclesInLegends, legendRadius, getBaseColor(uniqueBases[i])), svg.text(uniqueBases[i], getEquidistantXForLegend(i) +\n            legendRadius + 4, yOfTextLegend, legendFontSize, fontColor));\n    }\n    return image;\n}\n","export const SALTS_CSV = `DISPLAY,MOLWEIGHT\nno Data Added,100`;\n","export const SOURCES = `DISPLAY\nNO DATA\n`;\n","import { lcmsToGcrs } from './map';\nimport * as DG from 'datagrok-api/dg';\n//name: gcrsToLcms\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: LCMS}\nexport function gcrsToLcms(sequence) {\n    const df = DG.DataFrame.fromCsv(lcmsToGcrs);\n    const arr1 = df.getCol('GCRS').toList();\n    const arr2 = df.getCol('LCMS').toList();\n    const obj = {};\n    arr1.forEach((element, index) => obj[element] = arr2[index]);\n    for (let i = 0; i < arr1.length; i++) {\n        arr1[i] = arr1[i].replace('(', '\\\\(');\n        arr1[i] = arr1[i].replace(')', '\\\\)');\n    }\n    const regExp = new RegExp('(' + arr1.join('|') + ')', 'g');\n    return sequence.replace(regExp, function (code) { return obj[code]; });\n}\n//name: asoGapmersNucleotidesToBioSpring\n//input: string nucleotides {semType: DNA nucleotides}\n//output: string result {semType: BioSpring / Gapmers}\nexport function asoGapmersNucleotidesToBioSpring(nucleotides) {\n    let count = -1;\n    const objForEdges = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': '5*', 'A': '6*', 'C': '7*', 'G': '8*'\n    };\n    const objForCenter = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'T*', 'A': 'A*', 'C': '9*', 'G': 'G*'\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|T|C|G)/g, function (x) {\n        count++;\n        return (count > 4 && count < 15) ? objForCenter[x] : objForEdges[x];\n    }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?\n        nucleotides.length : 2 * count + 1);\n}\n//name: asoGapmersNucleotidesToGcrs\n//input: string nucleotides {semType: DNA nucleotides}\n//output: string result {semType: GCRS / Gapmers}\nexport function asoGapmersNucleotidesToGcrs(nucleotides) {\n    let count = -1;\n    const objForEdges = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'moeUnps',\n        'A': 'moeAnps', 'C': 'moe5mCnps', 'G': 'moeGnps'\n    };\n    const objForCenter = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'C': '5mCps', 'A': 'Aps', 'T': 'Tps', 'G': 'Gps' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|T|C|G)/g, function (x) {\n        count++;\n        if (count < 5)\n            return (count == 4) ? objForEdges[x].slice(0, -3) + 'ps' : objForEdges[x];\n        if (count < 15)\n            return (count == 14) ? objForCenter[x].slice(0, -2) + 'nps' : objForCenter[x];\n        return objForEdges[x];\n    }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?\n        nucleotides.length : -3);\n}\n//name: asoGapmersBioSpringToNucleotides\n//input: string nucleotides {semType: BioSpring / Gapmers}\n//output: string result {semType: DNA nucleotides}\nexport function asoGapmersBioSpringToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '*': '', '5': 'T', '6': 'A', '7': 'C', '8': 'G', '9': 'C' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|\\*|5|6|7|8|9)/g, function (x) { return obj[x]; });\n}\n//name: asoGapmersBioSpringToGcrs\n//input: string nucleotides {semType: BioSpring / Gapmers}\n//output: string result {semType: GCRS / Gapmers}\nexport function asoGapmersBioSpringToGcrs(nucleotides) {\n    let count = -1;\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '5*': 'moeUnps', '6*': 'moeAnps', '7*': 'moe5mCnps', '8*': 'moeGnps', '9*': '5mCps', 'A*': 'Aps', 'T*': 'Tps',\n        'G*': 'Gps', 'C*': 'Cps', '5': 'moeU', '6': 'moeA', '7': 'moe5mC', '8': 'moeG',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|5\\*|6\\*|7\\*|8\\*|9\\*|A\\*|T\\*|G\\*|C\\*|5|6|7|8)/g, function (x) {\n        count++;\n        return (count == 4) ? obj[x].slice(0, -3) + 'ps' : (count == 14) ? obj[x].slice(0, -2) + 'nps' : obj[x];\n    });\n}\n//name: asoGapmersGcrsToBioSpring\n//input: string nucleotides {semType: GCRS / Gapmers}\n//output: string result {semType: BioSpring / Gapmers}\nexport function asoGapmersGcrsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'moeT': '5', 'moeA': '6', 'moe5mC': '7', 'moeG': '8', 'moeU': '5', '5mC': '9', 'nps': '*', 'ps': '*', 'U': 'T',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|moeT|moeA|moe5mC|moeG|moeU|5mC|nps|ps|U)/g, function (x) { return obj[x]; });\n}\n//name: asoGapmersGcrsToNucleotides\n//input: string nucleotides {semType: GCRS / Gapmers}\n//output: string result {semType: DNA nucleotides}\nexport function asoGapmersGcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'moe': '', '5m': '', 'n': '', 'ps': '', 'U': 'T' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|moe|5m|n|ps|U)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToNucleotides\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaBioSpringToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'U', '2': 'A', '3': 'C', '4': 'G', '5': 'U', '6': 'A', '7': 'C', '8': 'G', '*': '' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToAxolabs\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: Axolabs / siRNA}\nexport function siRnaBioSpringToAxolabs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'Uf', '2': 'Af', '3': 'Cf', '4': 'Gf', '5': 'u', '6': 'a', '7': 'c', '8': 'g', '*': 's' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToGcrs\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: GCRS}\nexport function siRnaBioSpringToGcrs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'fU', '2': 'fA', '3': 'fC', '4': 'fG', '5': 'mU', '6': 'mA', '7': 'mC', '8': 'mG', '*': 'ps' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToGcrs\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: GCRS}\nexport function siRnaAxolabsToGcrs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': 'fU', 'Af': 'fA', 'Cf': 'fC', 'Gf': 'fG', 'u': 'mU', 'a': 'mA', 'c': 'mC', 'g': 'mG', 's': 'ps',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToBioSpring\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaAxolabsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': '1', 'Af': '2', 'Cf': '3', 'Gf': '4', 'u': '5', 'a': '6', 'c': '7', 'g': '8', 's': '*',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToNucleotides\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaAxolabsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': 'U', 'Af': 'A', 'Cf': 'C', 'Gf': 'G', 'u': 'U', 'a': 'A', 'c': 'C', 'g': 'G', 's': '',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToNucleotides\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaGcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G', 'ps': '',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToBioSpring\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaGcrsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': '1', 'fA': '2', 'fC': '3', 'fG': '4', 'mU': '5', 'mA': '6', 'mC': '7', 'mG': '8', 'ps': '*',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToAxolabs\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: Axolabs / siRNA}\nexport function siRnaGcrsToAxolabs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': 'Uf', 'fA': 'Af', 'fC': 'Cf', 'fG': 'Gf', 'mU': 'u', 'mA': 'a', 'mC': 'c', 'mG': 'g', 'ps': 's',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaNucleotideToBioSpringSenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaNucleotideToBioSpringSenseStrand(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '6*', 'U': '5*', 'G': '8*', 'C': '7*' };\n    const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '*6', 'U': '*5', 'G': '*8', 'C': '*7' };\n    const objForOddIndices = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '6', 'U': '5', 'G': '8', 'C': '7' };\n    const objForEvenIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': '2', 'U': '1', 'G': '4', 'C': '3' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count > nucleotides.length - 3)\n            return objForRightEdge[x];\n        return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];\n    });\n}\n//name: siRnaNucleotidesToGcrs\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: GCRS}\nexport function siRnaNucleotidesToGcrs(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'mAps', 'U': 'mUps', 'G': 'mGps', 'C': 'mCps' };\n    const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'psmA', 'U': 'psmU', 'G': 'psmG', 'C': 'psmC' };\n    const objForEvenIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'fA', 'U': 'fU', 'G': 'fG', 'C': 'fC' };\n    const objForOddIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'mA', 'U': 'mU', 'G': 'mG', 'C': 'mC' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count > nucleotides.length - 3)\n            return objForRightEdge[x];\n        return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];\n    });\n}\n//name: siRnaNucleotideToAxolabsSenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: Axolabs}\nexport function siRnaNucleotideToAxolabsSenseStrand(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };\n    const objForSomeIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count == 6 || (count > 7 && count < 11))\n            return objForSomeIndices[x];\n        if (count == nucleotides.length - 1)\n            return 'a';\n        return obj[x];\n    });\n}\n//name: siRnaNucleotideToAxolabsAntisenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: Axolabs}\nexport function siRnaNucleotideToAxolabsAntisenseStrand(nucleotides) {\n    let count = -1;\n    const objForSmallLinkages = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };\n    const objForBigLinkages = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Afs', 'U': 'Ufs', 'G': 'Gfs', 'C': 'Cfs' };\n    const objForSomeIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };\n    const obj = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count > 19 && count < 22)\n            return objForSmallLinkages[x];\n        if (count == 0)\n            return 'us';\n        if (count == 1)\n            return objForBigLinkages[x];\n        return (count == 5 || count == 7 || count == 8 || count == 13 || count == 15) ? objForSomeIndices[x] : obj[x];\n    });\n}\n//name: gcrsToNucleotides\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: RNA nucleotides}\nexport function gcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'mAps': 'A', 'mUps': 'U', 'mGps': 'G', 'mCps': 'C', 'fAps': 'A', 'fUps': 'U', 'fGps': 'G', 'fCps': 'C',\n        'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });\n}\n//name: gcrsToMermade12\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: Mermade 12 / siRNA}\nexport function gcrsToMermade12(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'mAps': 'e', 'mUps': 'h', 'mGps': 'g', 'mCps': 'f', 'fAps': 'i', 'fUps': 'l', 'fGps': 'k', 'fCps': 'j', 'fU': 'L',\n        'fA': 'I', 'fC': 'J', 'fG': 'K', 'mU': 'H', 'mA': 'E', 'mC': 'F', 'mG': 'G',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });\n}\n","import { map, stadardPhosphateLinkSmiles, SYNTHESIZERS, TECHNOLOGIES, MODIFICATIONS } from './map';\nimport { isValidSequence } from './sequence-codes-tools';\nimport { getNucleotidesMol } from './mol-transformations';\nexport function sequenceToMolV3000(sequence, inverted = false, oclRender = false, format) {\n    const obj = getObjectWithCodesAndSmiles(sequence, format);\n    let codes = sortByStringLengthInDescendingOrder(Object.keys(obj));\n    let i = 0;\n    const smilesCodes = [];\n    const codesList = [];\n    const links = ['s', 'ps', '*'];\n    const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];\n    const dropdowns = Object.keys(MODIFICATIONS);\n    codes = codes.concat(dropdowns);\n    while (i < sequence.length) {\n        const code = codes.find((s) => s == sequence.slice(i, i + s.length));\n        i += code.length;\n        inverted ? codesList.unshift(code) : codesList.push(code);\n    }\n    for (let i = 0; i < codesList.length; i++) {\n        if (dropdowns.includes(codesList[i])) {\n            smilesCodes.push((i >= codesList.length / 2) ?\n                MODIFICATIONS[codesList[i]].right : MODIFICATIONS[codesList[i]].left);\n            smilesCodes.push(stadardPhosphateLinkSmiles);\n        }\n        else {\n            if (links.includes(codesList[i]) ||\n                includesStandardLinkAlready.includes(codesList[i]) ||\n                (i < codesList.length - 1 && links.includes(codesList[i + 1])))\n                smilesCodes.push(obj[codesList[i]]);\n            else {\n                smilesCodes.push(obj[codesList[i]]);\n                smilesCodes.push(stadardPhosphateLinkSmiles);\n            }\n        }\n    }\n    return getNucleotidesMol(smilesCodes, oclRender);\n}\nexport function sequenceToSmiles(sequence, inverted = false, format) {\n    const obj = getObjectWithCodesAndSmiles(sequence, format);\n    let codes = sortByStringLengthInDescendingOrder(Object.keys(obj));\n    let i = 0;\n    let smiles = '';\n    const codesList = [];\n    const links = ['s', 'ps', '*'];\n    const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];\n    const dropdowns = Object.keys(MODIFICATIONS);\n    codes = codes.concat(dropdowns);\n    while (i < sequence.length) {\n        const code = codes.find((s) => s == sequence.slice(i, i + s.length));\n        i += code.length;\n        inverted ? codesList.unshift(code) : codesList.push(code);\n    }\n    for (let i = 0; i < codesList.length; i++) {\n        if (dropdowns.includes(codesList[i])) {\n            smiles += (i >= codesList.length / 2) ?\n                MODIFICATIONS[codesList[i]].right + stadardPhosphateLinkSmiles :\n                MODIFICATIONS[codesList[i]].left + stadardPhosphateLinkSmiles;\n        }\n        else {\n            if (links.includes(codesList[i]) ||\n                includesStandardLinkAlready.includes(codesList[i]) ||\n                (i < codesList.length - 1 && links.includes(codesList[i + 1])))\n                smiles += obj[codesList[i]];\n            else\n                smiles += obj[codesList[i]] + stadardPhosphateLinkSmiles;\n        }\n    }\n    smiles = smiles.replace(/OO/g, 'O');\n    return ((links.includes(codesList[codesList.length - 1]) &&\n        codesList.length > 1 &&\n        !includesStandardLinkAlready.includes(codesList[codesList.length - 2])) ||\n        dropdowns.includes(codesList[codesList.length - 1]) ||\n        includesStandardLinkAlready.includes(codesList[codesList.length - 1])) ?\n        smiles :\n        smiles.slice(0, smiles.length - stadardPhosphateLinkSmiles.length + 1);\n}\nfunction getObjectWithCodesAndSmiles(sequence, format) {\n    const obj = {};\n    if (format == null) {\n        for (const synthesizer of Object.keys(map)) {\n            for (const technology of Object.keys(map[synthesizer])) {\n                for (const code of Object.keys(map[synthesizer][technology]))\n                    obj[code] = map[synthesizer][technology][code].SMILES;\n            }\n        }\n    }\n    else {\n        for (const technology of Object.keys(map[format])) {\n            for (const code of Object.keys(map[format][technology]))\n                obj[code] = map[format][technology][code].SMILES;\n        }\n    }\n    // TODO: create object based from synthesizer type to avoid key(codes) duplicates\n    const output = isValidSequence(sequence, format);\n    if (output.synthesizer.includes(SYNTHESIZERS.MERMADE_12))\n        obj['g'] = map[SYNTHESIZERS.MERMADE_12][TECHNOLOGIES.SI_RNA]['g'].SMILES;\n    else if (output.synthesizer.includes(SYNTHESIZERS.AXOLABS))\n        obj['g'] = map[SYNTHESIZERS.AXOLABS][TECHNOLOGIES.SI_RNA]['g'].SMILES;\n    return obj;\n}\nfunction sortByStringLengthInDescendingOrder(array) {\n    return array.sort(function (a, b) { return b.length - a.length; });\n}\n","import * as DG from 'datagrok-api/dg';\nimport { getAllCodesOfSynthesizer } from './sequence-codes-tools';\nexport const SYNTHESIZERS = {\n    RAW_NUCLEOTIDES: 'Raw Nucleotides',\n    BIOSPRING: 'BioSpring Codes',\n    GCRS: 'Janssen GCRS Codes',\n    AXOLABS: 'Axolabs Codes',\n    MERMADE_12: 'Mermade 12',\n    LCMS: 'LCMS',\n};\nexport const TECHNOLOGIES = {\n    DNA: 'DNA',\n    RNA: 'RNA',\n    ASO_GAPMERS: 'For ASO Gapmers',\n    SI_RNA: 'For 2\\'-OMe and 2\\'-F modified siRNA',\n};\nexport const COL_NAMES = {\n    CHEMISTRY: 'Chemistry',\n    NUMBER: 'Number',\n    TYPE: 'Type',\n    CHEMISTRY_NAME: 'Chemistry Name',\n    INTERNAL_COMPOUND_ID: 'Internal compound ID',\n    IDP: 'IDP',\n    SEQUENCE: 'Sequence',\n    COMPOUND_NAME: 'Compound Name',\n    COMPOUND_COMMENTS: 'Compound Comments',\n    SALT: 'Salt',\n    EQUIVALENTS: 'Equivalents',\n    PURITY: 'Purity',\n    CPD_MW: 'Cpd MW',\n    SALT_MASS: 'Salt mass',\n    BATCH_MW: 'Batch MW',\n    SOURCE: 'Source',\n    ICD: 'ICD',\n    OWNER: 'Owner',\n};\n// interface CODES {\n// }\nexport const MODIFICATIONS = {\n    '(invabasic)': {\n        molecularWeight: 118.13,\n        left: 'O[C@@H]1C[C@@H]O[C@H]1CO',\n        right: 'O[C@@H]1C[C@@H]O[C@H]1CO',\n    },\n    '(GalNAc-2-JNJ)': {\n        molecularWeight: 1273.3,\n        left: 'C(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)NC(=O)CCCC(=O)NCC(O)CO',\n        right: 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)',\n    },\n};\nexport const stadardPhosphateLinkSmiles = 'OP(=O)(O)O';\nexport const map = {\n    'Raw Nucleotides': {\n        'DNA': {\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n        },\n        'RNA': {\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'U': {\n                'name': 'Uracil',\n                'weight': 306.17,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n        },\n    },\n    'BioSpring Codes': {\n        'For ASO Gapmers': {\n            '5': {\n                'name': '2\\'MOE-5Me-rU',\n                'weight': 378.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '6': {\n                'name': '2\\'MOE-rA',\n                'weight': 387.29,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '7': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '8': {\n                'name': '2\\'MOE-rG',\n                'weight': 403.28,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '9': {\n                'name': '5-Methyl-dC',\n                'weight': 303.21,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            '*': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n        },\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            '1': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            '2': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            '3': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            '4': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            '5': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            '6': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            '7': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            '8': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            '*': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n        },\n    },\n    'Axolabs Codes': {\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'Uf': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'Af': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'Cf': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'Gf': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'u': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'a': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'c': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'g': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            's': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n        },\n    },\n    'Janssen GCRS Codes': {\n        'For ASO Gapmers': {\n            'moeT': {\n                'name': '2\\'MOE-5Me-rU',\n                'weight': 378.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            'moeA': {\n                'name': '2\\'MOE-rA',\n                'weight': 387.29,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            'moe5mC': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '(5m)moeC': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            'moeG': {\n                'name': '2\\'MOE-rG',\n                'weight': 403.28,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '5mC': {\n                'name': '5-Methyl-dC',\n                'weight': 303.28,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            '(5m)C': {\n                'name': '5-Methyl-dC',\n                'weight': 303.28,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            'ps': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'dA': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'dC': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'dG': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'dT': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'rA': {\n                'name': 'Adenine',\n                'weight': 329.21,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](O)[C@@H]1O',\n            },\n            'rC': {\n                'name': 'Cytosine',\n                'weight': 305.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](O)[C@@H]1O',\n            },\n            'rG': {\n                'name': 'Guanine',\n                'weight': 345.21,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](O)[C@@H]1O',\n            },\n            'rU': {\n                'name': 'Uracil',\n                'weight': 306.17,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',\n            },\n        },\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'fU': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'fA': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'fC': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'fG': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'mU': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'mA': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'mC': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'mG': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n        },\n        'Others': {},\n    },\n    'Mermade 12': {\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'e': {\n                'name': '2\\'OMe-rA-ps',\n                'weight': 359.31,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'h': {\n                'name': '2\\'OMe-rU-ps',\n                'weight': 336.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'g': {\n                'name': '2\\'OMe-rG-ps',\n                'weight': 375.31,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'f': {\n                'name': '2\\'OMe-rC-ps',\n                'weight': 335.28,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'i': {\n                'name': '2\\'-fluoro-A-ps',\n                'weight': 347.27,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'l': {\n                'name': '2\\'-fluoro-U-ps',\n                'weight': 324.23,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'k': {\n                'name': '2\\'-fluoro-G-ps',\n                'weight': 363.26,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'j': {\n                'name': '2\\'-fluoro-C-ps',\n                'weight': 323.25,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'L': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'I': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'J': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'K': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'H': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'E': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'F': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'G': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n        },\n    },\n    // 'LCMS': {\n    //   'For 2\\'-OMe and 2\\'-F modified siRNA': {\n};\nexport const lcmsToGcrs = `LCMS, GCRS\nA, A\nC, C\n/5mC/, (5m)C\nG, G\nT, T\nrA, rA\nrC, rC\nrG, rG\nrU, rU\nmA, mA\nmC, mC\n/5mmC/, (5m)mC\nmG, mG\nmU, mU\nfA, fA\nfC, fC\n/5mfC/, (5m)fC\nfG, fG\nfU, fU\n/afA/, afA\n/afC/, afC\n/afG/, afG\n/afU/, afU\n+A, lna A\n+C, lna C\n+G, lna G\n+T, lna T\n/moeA/, moeA\n/moeC/, moeC\n/5mmoeC/, (5m)moeC\n/moeG/, moeG\n/moeT/, moeT\n/moeU/, moeU\n/xA/, Anp\n/xC/, Cnp\n/x5mC/, (5m)Cnp\n/xG/, Gnp\n/xT/, Tnp\n/xrA/, rAnp\n/xrC/, rCnp\n/xrG/, rGnp\n/xrU/, rUnp\n/xmA/, mAnp\n/xmC/, mCnp\n/x5mmC/, (5m)mCnp\n/xmG/, mGnp\n/xmU/, mUnp\n/xfA/, fAnp\n/xfC/, fCnp\n/xfG/, fGnp\n/xfT/, fTnp\n/xfU/, fUnp\n/xafA/, afAnp\n/xafC/, afCnp\n/xafG/, afGnp\n/xafU/, afUnp\n/xeA/, eAnp\n/xeC/, eCnp\n/xeG/, eGnp\n/xeU/, eUnp\n/xmoeA/, moeAnp\n/xmoeC/, moeCnp\n/x5mmoeC/, (5m)moeCnp\n/xmoeG/, moeGnp\n/xmoeU/, moeUnp\n/UNA-A/, (UNA-A)\n/UNA-C/, (UNA-C)\n/UNA-G/, (UNA-G)\n/UNA-T/, (UNA-T)\n/UNA-U/, (UNA-U)\n/GNA-A/, (GNA-A)\n/GNA-C/, (GNA-C)\n/GNA-G/, (GNA-G)\n/GNA-T/, (GNA-T)\n/GNA-U/, (GNA-U)\n/5CholTEG/, (5-CholTEG)\n/3CholTEG/, (TEGChol-3)\n/Toco/, Toco\n/Palm/, Palm\n/GalNAc/, GalNAc\n/GalNAc2/, GalNAc2\n/GalNAc3/, GalNAc3\n/GalNAc6/, GalNAc6\n/GalNAc7/, GalNAc7\n/GalNAc9/, GalNAc9\n/GalNAc14/, GalNAc14\n/NAG37/, NAG37\n/HEG/, (HEG)\n/TEG/, (TEG)\n/AmmC6/, (NHC6)\n/AmmC7/, (NHC7)\n/AmmC12/, (NHC12)\n/invAb/, (invabasic)\n/invdT/, (invdT)\n/VPmU/, (vinu)\n*, ps\n/2-C16U/, 2-C16U \n/2-C18w9U/, 2-C18w9U\n/JDi-Palm/, JDi-Palm\n/J2-CONC16U/, J2-CONC16U\n/J2-C3NC16U/, J2-C3NC16U\n/J-C15Ada/, J-C15Ada\n/J-2C15AdaU/, J-2C15AdaU\n/J-C16NC6/, J-C16NC6\n/R2-C6NH-U/, R2-C6NH-U\n/J-M1/, J-M1\n/J-B1/, J-B1\n/J-B2/, J-B2\n/J-M2/, J-M2\n/2-C16C/, 2-C16C\n/2-C16A/, 2-C16A\n/2-C16G/, 2-C16G\n/R2-C6NH-G/, R2-C6NH-G\n/R2-C6NH-C/, R2-C6NH-C\n/J2-CONC16A/, J2-CONC16A\n/J2-CONC16C/, J2-CONC16C\n/J2-CONC16G/, J2-CONC16G\n/J2-C15AdaC/, J2-C15AdaC\n/J2-M2U/, J2-M2U\n/J2-B2U/, J2-B2U\n/J2-C3NC16C/, J2-C3NC16C\n/J2-C3NC16G/, J2-C3NC16G\n/R2-C6NH-A/, R2-C6NH-A\n/J2-C15AdaA/, J2-C15AdaA\n/J2-C3NC16A/, J2-C3NC16A\n/J-C5-SER-1/, J-C5-SER-1\n/J-C16-SER-1/, J-C16-SER-1\n/J-A2/, J-A2\n/J-A1/, J-A1\n/J2-C15AdaG/, J2-C15AdaG\n/J-C16NAsp/, J-C16NAsp\n/J2-C16NC6U/, J2-C16NC6U\n/J-C5-REBO-1/, J-C5-REBO-1\n/J-C16-REBO-1/, J-C16-REBO-1\n/J-C16-IND-1/, J-C16-IND-1\n/J-C5-IND-1/, J-C5-IND-1\n/J-1C15Ada-2Man/, J-1C15Ada-2Man\n/JG-1C15Ada-23DiMan/, JG-1C15Ada-2,3DiMan\n/J-TriManPC/, J-TriManPC\n/J-triManPO/, J-triManPO\n/J-A4/, J-A4\n/J-Ara-1/, J-Ara-1\n/J-Ara-2/, J-Ara-2\n/J-AcCS/, J-AcCS\n/J-CbCS/, J-CbCS\n/J-MtCD/, J-MtCD`;\nfunction differenceOfTwoArrays(a, b) {\n    return a.filter((x) => !b.includes(x));\n}\nconst codesWithSmiles = getAllCodesOfSynthesizer(SYNTHESIZERS.GCRS);\nconst allGcrsCodes = DG.DataFrame.fromCsv(lcmsToGcrs).getCol('GCRS').toList();\nexport const gcrsCodesWithoutSmiles = differenceOfTwoArrays(allGcrsCodes, codesWithSmiles);\nfor (const e of gcrsCodesWithoutSmiles)\n    map[SYNTHESIZERS.GCRS]['Others'][e] = { 'SMILES': '' };\n","import * as OCL from 'openchemlib/full.js';\nconst PHOSHATE = `\nDatagrok monomer library Nucleotides\n\n  0  0  0  0  0  0              0 V3000\nM  V30 BEGIN CTAB\nM  V30 COUNTS 5 4 0 0 0\nM  V30 BEGIN ATOM\nM  V30 1 O -1.5 0 0 0\nM  V30 2 P 0 0 0 0\nM  V30 3 O 0 1 0 0\nM  V30 4 O 0 -1 0 0\nM  V30 5 O 1.5 0 0 0\nM  V30 END ATOM\nM  V30 BEGIN BOND\nM  V30 1 1 1 2\nM  V30 2 2 2 3\nM  V30 3 1 2 4\nM  V30 4 1 2 5\nM  V30 END BOND\nM  V30 END CTAB\nM  V30 BEGIN COLLECTION\nM  V30 END COLLECTION\nM  END`;\nconst THIOPHOSHATE = `\nDatagrok monomer library Nucleotides\n\n  0  0  0  0  0  0              0 V3000\nM  V30 BEGIN CTAB\nM  V30 COUNTS 5 4 0 0 0\nM  V30 BEGIN ATOM\nM  V30 1 O -1.5 0 0 0\nM  V30 2 P 0 0 0 0\nM  V30 3 O 0 1 0 0\nM  V30 4 S 0 -1 0 0\nM  V30 5 O 1.5 0 0 0\nM  V30 END ATOM\nM  V30 BEGIN BOND\nM  V30 1 1 1 2\nM  V30 2 2 2 3\nM  V30 3 1 2 4\nM  V30 4 1 2 5\nM  V30 END BOND\nM  V30 END CTAB\nM  V30 BEGIN COLLECTION\nM  V30 END COLLECTION\nM  END`;\nconst INVABASIC = `\nDatagrok monomer library Nucleotides\n\n  0  0  0  0  0  0              0 V3000\nM  V30 BEGIN CTAB\nM  V30 COUNTS 8 8 0 0 0\nM  V30 BEGIN ATOM\nM  V30 1 O 1.0934 -2.1636 0 0\nM  V30 2 C 1.8365 -1.4945 0 0 CFG=2\nM  V30 3 C 2.8147 -1.7024 0 0\nM  V30 4 C 3.3147 -0.8364 0 0 VAL=3\nM  V30 5 O 2.6455 -0.0932 0 0\nM  V30 6 C 1.732 -0.5 0 0 CFG=1\nM  V30 7 C 0.866 0 0 0\nM  V30 8 O 0.866 1 0 0\nM  V30 END ATOM\nM  V30 BEGIN BOND\nM  V30 1 1 2 1 CFG=1\nM  V30 2 1 2 3\nM  V30 3 1 3 4\nM  V30 4 1 4 5\nM  V30 5 1 6 5\nM  V30 6 1 2 6\nM  V30 7 1 6 7 CFG=3\nM  V30 8 1 7 8\nM  V30 END BOND\nM  V30 BEGIN COLLECTION\nM  V30 MDLV30/STEABS ATOMS=(2 2 6)\nM  V30 END COLLECTION\nM  V30 END CTAB\nM  END`;\nexport function getNucleotidesMol(smilesCodes, oclRender = false) {\n    const molBlocks = [];\n    for (let i = 0; i < smilesCodes.length - 1; i++) {\n        smilesCodes[i] == 'OP(=O)(O)O' ? molBlocks.push(PHOSHATE) :\n            smilesCodes[i] == 'OP(=O)(S)O' ? molBlocks.push(THIOPHOSHATE) :\n                smilesCodes[i] == 'O[C@@H]1C[C@@H]O[C@H]1CO' ? molBlocks.push(rotateNucleotidesV3000(INVABASIC)) :\n                    molBlocks.push(rotateNucleotidesV3000(smilesCodes[i]));\n    }\n    return linkV3000(molBlocks, false, oclRender);\n}\nexport function linkV3000(molBlocks, twoChains = false, oclRender = false) {\n    let macroMolBlock = '\\nDatagrok macromolecule handler\\n\\n';\n    macroMolBlock += '  0  0  0  0  0  0            999 V3000\\n';\n    macroMolBlock += 'M  V30 BEGIN CTAB\\n';\n    let atomBlock = '';\n    let bondBlock = '';\n    let collectionBlock = '';\n    const collection = [];\n    let natom = 0;\n    let nbond = 0;\n    let xShift = 0;\n    if (twoChains && molBlocks.length > 1)\n        molBlocks[1] = invertNucleotidesV3000(molBlocks[1]);\n    for (let i = 0; i < molBlocks.length; i++) {\n        molBlocks[i] = molBlocks[i].replaceAll('(-\\nM  V30 ', '(')\n            .replaceAll('-\\nM  V30 ', '').replaceAll(' )', ')');\n        const numbers = extractAtomsBondsNumbersV3000(molBlocks[i]);\n        const coordinates = extractAtomDataV3000(molBlocks[i]);\n        if (twoChains) {\n            const xShiftRight = Math.min(...coordinates.x);\n            const yShift = i == 0 ? Math.min(...coordinates.y) - 1 : Math.max(...coordinates.y) + 1;\n            for (let j = 0; j < coordinates.x.length; j++)\n                coordinates.x[j] -= xShiftRight;\n            for (let j = 0; j < coordinates.y.length; j++)\n                coordinates.y[j] -= yShift;\n        }\n        let indexAtoms = molBlocks[i].indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n        indexAtoms = molBlocks[i].indexOf('\\n', indexAtoms);\n        let index = indexAtoms;\n        let indexEnd = indexAtoms;\n        for (let j = 0; j < numbers.natom; j++) {\n            if (coordinates.atomIndex[j] != 1 || i == 0 || twoChains) {\n                //rewrite atom number\n                index = molBlocks[i].indexOf('V30', index) + 4;\n                indexEnd = molBlocks[i].indexOf(' ', index);\n                const atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;\n                molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);\n                //rewrite coordinates\n                index = molBlocks[i].indexOf(' ', index) + 1;\n                index = molBlocks[i].indexOf(' ', index) + 1;\n                indexEnd = molBlocks[i].indexOf(' ', index);\n                const totalShift = twoChains ? 0 : xShift - coordinates.x[0];\n                let coordinate = twoChains ?\n                    Math.round(10000 * coordinates.x[j]) / 10000 :\n                    Math.round(10000 * (parseFloat(molBlocks[i].substring(index, indexEnd)) + totalShift)) / 10000;\n                molBlocks[i] = molBlocks[i].slice(0, index) + coordinate + molBlocks[i].slice(indexEnd);\n                index = molBlocks[i].indexOf(' ', index) + 1;\n                indexEnd = molBlocks[i].indexOf(' ', index);\n                coordinate = twoChains ?\n                    Math.round(10000 * coordinates.y[j]) / 10000 :\n                    Math.round(10000 * (parseFloat(molBlocks[i].substring(index, indexEnd)))) / 10000;\n                molBlocks[i] = molBlocks[i].slice(0, index) + coordinate + molBlocks[i].slice(indexEnd);\n                index = molBlocks[i].indexOf('\\n', index) + 1;\n            }\n            else {\n                index = molBlocks[i].indexOf('M  V30', index) - 1;\n                indexEnd = molBlocks[i].indexOf('\\n', index + 1);\n                molBlocks[i] = molBlocks[i].slice(0, index) + molBlocks[i].slice(indexEnd);\n            }\n        }\n        const indexAtomsEnd = molBlocks[i].indexOf('M  V30 END ATOM');\n        atomBlock += molBlocks[i].substring(indexAtoms + 1, indexAtomsEnd);\n        let indexBonds = molBlocks[i].indexOf('M  V30 BEGIN BOND'); // V3000 index for bonds\n        indexBonds = molBlocks[i].indexOf('\\n', indexBonds);\n        index = indexBonds;\n        indexEnd = indexBonds;\n        for (let j = 0; j < numbers.nbond; j++) {\n            //rewrite bond number\n            index = molBlocks[i].indexOf('V30', index) + 4;\n            indexEnd = molBlocks[i].indexOf(' ', index);\n            const bondNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + nbond;\n            molBlocks[i] = molBlocks[i].slice(0, index) + bondNumber + molBlocks[i].slice(indexEnd);\n            //rewrite atom pair in bond\n            index = molBlocks[i].indexOf(' ', index) + 1;\n            index = molBlocks[i].indexOf(' ', index) + 1;\n            indexEnd = molBlocks[i].indexOf(' ', index);\n            let atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;\n            molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);\n            index = molBlocks[i].indexOf(' ', index) + 1;\n            indexEnd = Math.min(molBlocks[i].indexOf('\\n', index), molBlocks[i].indexOf(' ', index));\n            atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;\n            molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);\n            index = molBlocks[i].indexOf('\\n', index) + 1;\n        }\n        const indexBondEnd = molBlocks[i].indexOf('M  V30 END BOND');\n        bondBlock += molBlocks[i].substring(indexBonds + 1, indexBondEnd);\n        let indexCollection = molBlocks[i].indexOf('M  V30 MDLV30/STEABS ATOMS=('); // V3000 index for collections\n        while (indexCollection != -1) {\n            indexCollection += 28;\n            const collectionEnd = molBlocks[i].indexOf(')', indexCollection);\n            const collectionEntries = molBlocks[i].substring(indexCollection, collectionEnd).split(' ').slice(1);\n            collectionEntries.forEach((e) => {\n                collection.push(parseInt(e) + natom);\n            });\n            indexCollection = collectionEnd;\n            indexCollection = molBlocks[i].indexOf('M  V30 MDLV30/STEABS ATOMS=(', indexCollection);\n        }\n        natom += twoChains ? numbers.natom : numbers.natom - 1;\n        nbond += numbers.nbond;\n        xShift += twoChains ? 0 : coordinates.x[numbers.natom - 1] - coordinates.x[0];\n    }\n    const entries = 4;\n    const collNumber = Math.ceil(collection.length / entries);\n    if (oclRender) {\n        collectionBlock += 'M  V30 MDLV30/STEABS ATOMS=(' + collection.length;\n        for (let j = 0; j < collection.length; j++)\n            collectionBlock += ' ' + collection[j];\n        collectionBlock += ')\\n';\n    }\n    else {\n        collectionBlock += 'M  V30 MDLV30/STEABS ATOMS=(' + collection.length + ' -\\n';\n        for (let i = 0; i < collNumber; i++) {\n            collectionBlock += 'M  V30 ';\n            const entriesCurrent = i + 1 == collNumber ? collection.length - (collNumber - 1) * entries : entries;\n            for (let j = 0; j < entriesCurrent; j++) {\n                collectionBlock += (j + 1 == entriesCurrent) ?\n                    (i == collNumber - 1 ? collection[entries * i + j] + ')\\n' : collection[entries * i + j] + ' -\\n') :\n                    collection[entries * i + j] + ' ';\n            }\n        }\n    }\n    //generate file\n    twoChains ? natom : natom++;\n    macroMolBlock += 'M  V30 COUNTS ' + natom + ' ' + nbond + ' 0 0 0\\n';\n    macroMolBlock += 'M  V30 BEGIN ATOM\\n';\n    macroMolBlock += atomBlock;\n    macroMolBlock += 'M  V30 END ATOM\\n';\n    macroMolBlock += 'M  V30 BEGIN BOND\\n';\n    macroMolBlock += bondBlock;\n    macroMolBlock += 'M  V30 END BOND\\n';\n    macroMolBlock += 'M  V30 BEGIN COLLECTION\\n';\n    macroMolBlock += collectionBlock;\n    macroMolBlock += 'M  V30 END COLLECTION\\n';\n    macroMolBlock += 'M  V30 END CTAB\\n';\n    macroMolBlock += 'M  END\\n';\n    return macroMolBlock;\n}\nfunction rotateNucleotidesV3000(molecule) {\n    let molBlock = molecule.includes('M  END') ? molecule : OCL.Molecule.fromSmiles(molecule).toMolfileV3();\n    const coordinates = extractAtomDataV3000(molBlock);\n    const natom = coordinates.atomIndex.length;\n    const indexFivePrime = coordinates.atomIndex.indexOf(1);\n    const indexThreePrime = coordinates.atomIndex.indexOf(natom);\n    //fix 5 prime if inadequate\n    if (natom > 8)\n        fix5Prime(coordinates, indexFivePrime, indexThreePrime);\n    const xCenter = (coordinates.x[indexThreePrime] + coordinates.x[indexFivePrime]) / 2;\n    const yCenter = (coordinates.y[indexThreePrime] + coordinates.y[indexFivePrime]) / 2;\n    //place to center\n    for (let i = 0; i < natom; i++) {\n        coordinates.x[i] -= xCenter;\n        coordinates.y[i] -= yCenter;\n    }\n    let angle = 0;\n    if (coordinates.x[indexFivePrime] == 0)\n        angle = coordinates.y[indexFivePrime] > coordinates.y[indexThreePrime] ? Math.PI / 2 : 3 * Math.PI / 2;\n    else if (coordinates.y[indexFivePrime] == 0)\n        angle = coordinates.x[indexFivePrime] > coordinates.x[indexThreePrime] ? Math.PI : 0;\n    else {\n        const derivative = coordinates.y[indexFivePrime] / coordinates.x[indexFivePrime];\n        angle = derivative > 0 ? Math.PI - Math.atan(derivative) : Math.atan(derivative);\n    }\n    const cos = Math.cos(angle);\n    const sin = Math.sin(angle);\n    for (let i = 0; i < natom; i++) {\n        const xAdd = coordinates.x[i];\n        coordinates.x[i] = xAdd * cos - coordinates.y[i] * sin;\n        coordinates.y[i] = xAdd * sin + coordinates.y[i] * cos;\n    }\n    //place to right\n    const xShift = coordinates.x[indexFivePrime];\n    for (let i = 0; i < natom; i++)\n        coordinates.x[i] -= xShift;\n    //rewrite molBlock\n    let index = molBlock.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n    index = molBlock.indexOf('\\n', index);\n    let indexEnd = index;\n    for (let i = 0; i < natom; i++) {\n        index = molBlock.indexOf('V30', index) + 4;\n        index = molBlock.indexOf(' ', index) + 1;\n        index = molBlock.indexOf(' ', index) + 1;\n        indexEnd = molBlock.indexOf(' ', index) + 1;\n        indexEnd = molBlock.indexOf(' ', indexEnd);\n        molBlock = molBlock.slice(0, index) +\n            coordinates.x[i] + ' ' + coordinates.y[i] +\n            molBlock.slice(indexEnd);\n        index = molBlock.indexOf('\\n', index) + 1;\n    }\n    return molBlock;\n}\nfunction invertNucleotidesV3000(molecule) {\n    let molBlock = molecule.includes('M  END') ? molecule : OCL.Molecule.fromSmiles(molecule).toMolfileV3();\n    const coordinates = extractAtomDataV3000(molBlock);\n    const natom = coordinates.atomIndex.length;\n    const xCenter = (Math.max(...coordinates.x) + Math.min(...coordinates.x)) / 2;\n    const yCenter = (Math.max(...coordinates.y) + Math.min(...coordinates.y)) / 2;\n    //place to center\n    for (let i = 0; i < natom; i++) {\n        coordinates.x[i] -= xCenter;\n        coordinates.y[i] -= yCenter;\n    }\n    const angle = Math.PI;\n    const cos = Math.cos(angle);\n    const sin = Math.sin(angle);\n    for (let i = 0; i < natom; i++) {\n        const xAdd = coordinates.x[i];\n        coordinates.x[i] = xAdd * cos - coordinates.y[i] * sin;\n        coordinates.y[i] = xAdd * sin + coordinates.y[i] * cos;\n    }\n    //place back\n    const yShift = Math.max(...coordinates.y);\n    for (let i = 0; i < natom; i++) {\n        coordinates.x[i] += xCenter;\n        coordinates.y[i] -= yShift;\n    }\n    //rewrite molBlock\n    let index = molBlock.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n    index = molBlock.indexOf('\\n', index);\n    let indexEnd = index;\n    for (let i = 0; i < natom; i++) {\n        index = molBlock.indexOf('V30', index) + 4;\n        index = molBlock.indexOf(' ', index) + 1;\n        index = molBlock.indexOf(' ', index) + 1;\n        indexEnd = molBlock.indexOf(' ', index) + 1;\n        indexEnd = molBlock.indexOf(' ', indexEnd);\n        molBlock = molBlock.slice(0, index) +\n            coordinates.x[i] + ' ' + coordinates.y[i] +\n            molBlock.slice(indexEnd);\n        index = molBlock.indexOf('\\n', index) + 1;\n    }\n    return molBlock;\n}\nfunction fix5Prime(coordinates, indexFivePrime, indexThreePrime) {\n    const indexFivePrimeNeighbour = indexFivePrime + 1;\n    const xShift = coordinates.x[indexFivePrimeNeighbour];\n    const yShift = coordinates.y[indexFivePrimeNeighbour];\n    const base3PrimeX = coordinates.x[indexThreePrime] - xShift;\n    const base3PrimeY = coordinates.y[indexThreePrime] - yShift;\n    const base5PrimeX = coordinates.x[indexFivePrime] - xShift;\n    const base5PrimeY = coordinates.y[indexFivePrime] - yShift;\n    const rotated5PrimeX = base5PrimeX * Math.cos(Math.PI * 2 / 3) - base5PrimeY * Math.sin(Math.PI * 2 / 3);\n    const rotated5PrimeY = base5PrimeX * Math.sin(Math.PI * 2 / 3) + base5PrimeY * Math.cos(Math.PI * 2 / 3);\n    const dx = base5PrimeX - base3PrimeX;\n    const dy = base5PrimeY - base3PrimeY;\n    const dxRotated = rotated5PrimeX - base3PrimeX;\n    const dyRotated = rotated5PrimeY - base3PrimeY;\n    if (Math.sqrt(dyRotated * dyRotated + dxRotated * dxRotated) >= Math.sqrt(dy * dy + dx * dx)) {\n        coordinates.x[indexFivePrime] = rotated5PrimeX + xShift;\n        coordinates.y[indexFivePrime] = rotated5PrimeY + yShift;\n    }\n}\nfunction extractAtomsBondsNumbersV3000(molBlock) {\n    molBlock = molBlock.replaceAll('\\r', ''); //equalize old and new sdf standards\n    let index = molBlock.indexOf('COUNTS') + 7; // V3000 index for atoms and bonds number\n    let indexEnd = molBlock.indexOf(' ', index);\n    const atomsNumber = parseInt(molBlock.substring(index, indexEnd));\n    index = indexEnd + 1;\n    indexEnd = molBlock.indexOf(' ', index);\n    const bondsNumber = parseInt(molBlock.substring(index, indexEnd));\n    return { natom: atomsNumber, nbond: bondsNumber };\n}\nfunction extractAtomDataV3000(molBlock) {\n    const numbers = extractAtomsBondsNumbersV3000(molBlock);\n    let index = molBlock.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n    index = molBlock.indexOf('\\n', index);\n    let indexEnd = index;\n    const indexes = Array(numbers.natom);\n    const types = Array(numbers.natom);\n    const x = Array(numbers.natom);\n    const y = Array(numbers.natom);\n    for (let i = 0; i < numbers.natom; i++) {\n        index = molBlock.indexOf('V30', index) + 4;\n        indexEnd = molBlock.indexOf(' ', index);\n        indexes[i] = parseInt(molBlock.substring(index, indexEnd));\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        types[i] = molBlock.substring(index, indexEnd);\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        x[i] = parseFloat(molBlock.substring(index, indexEnd));\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        y[i] = parseFloat(molBlock.substring(index, indexEnd));\n        index = molBlock.indexOf('\\n', index) + 1;\n    }\n    return { atomIndex: indexes, atomType: types, x: x, y: y };\n}\n","import * as ui from 'datagrok-api/ui';\nimport { sequenceToMolV3000 } from '../structures-works/from-monomers';\nimport { linkV3000 } from '../structures-works/mol-transformations';\nimport { getFormat } from '../structures-works/sequence-codes-tools';\nexport function saveSdf(as, ss, oneEntity, fit3dx) {\n    const formatAs = getFormat(as);\n    const formatSs = getFormat(ss);\n    const molSS = sequenceToMolV3000(ss, false, false, formatSs);\n    const molAS = sequenceToMolV3000(as, true, false, formatAs);\n    let result;\n    if (oneEntity)\n        result = linkV3000([molSS, molAS], true, !fit3dx) + '\\n\\n$$$$\\n';\n    else {\n        result =\n            molSS + '\\n' +\n                `>  <Sequence>\\nSense Strand\\n\\n$$$$\\n` +\n                molAS + '\\n' +\n                `>  <Sequence>\\nAnti Sense\\n\\n$$$$\\n`;\n    }\n    const element = document.createElement('a');\n    element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(result));\n    element.setAttribute('download', ss.replace(/\\s/g, '') + '.sdf');\n    element.click();\n}\nexport function saveSenseAntiSense() {\n    const moleculeSvgDiv = ui.block([]);\n    const ssInput = ui.textInput('Sense Strand 5\\' ->3\\'', '');\n    const asInput = ui.textInput('Anti Sense 3\\' ->5\\'', '');\n    const saveOption = ui.switchInput('Save as one entity', true);\n    const save3dx = ui.switchInput('Save 3dx', true);\n    const saveBtn = ui.button('Save SDF', () => saveSdf(asInput.value, ssInput.value, saveOption.value, save3dx.value));\n    const saveSection = ui.panel([\n        ui.div([\n            ui.div([\n                ui.divH([ui.h1('Inputs')]),\n                ui.divV([\n                    ui.div([ssInput.root]),\n                    ui.div([asInput.root]),\n                    saveOption,\n                    save3dx,\n                    ui.buttonsInput([saveBtn]),\n                ], 'ui-form'),\n            ], 'ui-form'),\n        ], 'ui-form'),\n        moleculeSvgDiv,\n    ]);\n    return saveSection;\n}\n","import { map, SYNTHESIZERS, TECHNOLOGIES, MODIFICATIONS } from './map';\nimport { asoGapmersNucleotidesToBioSpring, asoGapmersNucleotidesToGcrs, asoGapmersBioSpringToNucleotides, asoGapmersBioSpringToGcrs, asoGapmersGcrsToNucleotides, asoGapmersGcrsToBioSpring, gcrsToMermade12, siRnaNucleotideToBioSpringSenseStrand, siRnaNucleotideToAxolabsSenseStrand, siRnaNucleotidesToGcrs, siRnaBioSpringToNucleotides, siRnaBioSpringToAxolabs, siRnaBioSpringToGcrs, siRnaAxolabsToNucleotides, siRnaAxolabsToBioSpring, siRnaAxolabsToGcrs, siRnaGcrsToNucleotides, siRnaGcrsToBioSpring, siRnaGcrsToAxolabs, gcrsToNucleotides, gcrsToLcms } from './converters';\nconst noTranslationTableAvailable = 'No translation table available';\nexport const undefinedInputSequence = 'Type of input sequence is undefined';\nexport function getFormat(sequence) {\n    const possibleSynthesizers = getListOfPossibleSynthesizersByFirstMatchedCode(sequence);\n    if (possibleSynthesizers.length == 0)\n        return null;\n    let outputIndex = 0;\n    const firstUniqueCharacters = ['r', 'd'];\n    const nucleotides = ['A', 'U', 'T', 'C', 'G'];\n    possibleSynthesizers.forEach((synthesizer) => {\n        const codes = getAllCodesOfSynthesizer(synthesizer);\n        while (outputIndex < sequence.length) {\n            const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));\n            if (matchedCode == null)\n                break;\n            if ( // for mistake pattern 'rAA'\n            outputIndex > 1 &&\n                nucleotides.includes(sequence[outputIndex]) &&\n                firstUniqueCharacters.includes(sequence[outputIndex - 2]))\n                break;\n            if ( // for mistake pattern 'ArA'\n            firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&\n                nucleotides.includes(sequence[outputIndex])) {\n                outputIndex++;\n                break;\n            }\n            outputIndex += matchedCode.length;\n        }\n    });\n    const indexOfFirstNotValidChar = (outputIndex == sequence.length) ? -1 : outputIndex;\n    if (indexOfFirstNotValidChar != -1)\n        return possibleSynthesizers[0];\n    const possibleTechnologies = getListOfPossibleTechnologiesByFirstMatchedCode(sequence, possibleSynthesizers[0]);\n    if (possibleTechnologies.length == 0)\n        return null;\n    outputIndex = 0;\n    possibleTechnologies.forEach((technology) => {\n        const codes = Object.keys(map[possibleSynthesizers[0]][technology]);\n        while (outputIndex < sequence.length) {\n            const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));\n            if (matchedCode == null)\n                break;\n            if ( // for mistake pattern 'rAA'\n            outputIndex > 1 &&\n                nucleotides.includes(sequence[outputIndex]) &&\n                firstUniqueCharacters.includes(sequence[outputIndex - 2]))\n                break;\n            if ( // for mistake pattern 'ArA'\n            firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&\n                nucleotides.includes(sequence[outputIndex])) {\n                outputIndex++;\n                break;\n            }\n            outputIndex += matchedCode.length;\n        }\n    });\n    return possibleSynthesizers[0];\n}\nexport function isValidSequence(sequence, format) {\n    const possibleSynthesizers = format == null ?\n        getListOfPossibleSynthesizersByFirstMatchedCode(sequence) :\n        [format];\n    // if (possibleSynthesizers.length > 1) {\n    //   const synthesizer = ui.choiceInput('Choose synthesizer from list: ', possibleSynthesizers[0],\n    //  possibleSynthesizers);\n    //   ui.dialog('Choose Synthesizer')\n    //     .add(ui.panel([synthesizer.root], {style: {fontWeight: 'bold'}}))\n    //     .onOK(() => possibleSynthesizers = [synthesizer.value])\n    //     .onCancel(() => {\n    //       possibleSynthesizers = [possibleSynthesizers[0]];\n    //       grok.shell.warning('Input sequence is expected to be in format ' + possibleSynthesizers[0]);\n    //     })\n    //     .show();\n    // } else if (possibleSynthesizers.length == 0)\n    if (possibleSynthesizers.length == 0)\n        return { indexOfFirstNotValidChar: 0, synthesizer: null, technology: null };\n    let outputIndex = 0;\n    const firstUniqueCharacters = ['r', 'd'];\n    const nucleotides = ['A', 'U', 'T', 'C', 'G'];\n    possibleSynthesizers.forEach((synthesizer) => {\n        const codes = getAllCodesOfSynthesizer(synthesizer);\n        while (outputIndex < sequence.length) {\n            const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));\n            if (matchedCode == null)\n                break;\n            if ( // for mistake pattern 'rAA'\n            outputIndex > 1 &&\n                nucleotides.includes(sequence[outputIndex]) &&\n                firstUniqueCharacters.includes(sequence[outputIndex - 2]))\n                break;\n            if ( // for mistake pattern 'ArA'\n            firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&\n                nucleotides.includes(sequence[outputIndex])) {\n                outputIndex++;\n                break;\n            }\n            outputIndex += matchedCode.length;\n        }\n    });\n    const indexOfFirstNotValidChar = (outputIndex == sequence.length) ? -1 : outputIndex;\n    if (indexOfFirstNotValidChar != -1) {\n        return {\n            indexOfFirstNotValidChar: indexOfFirstNotValidChar,\n            synthesizer: possibleSynthesizers,\n            technology: null,\n        };\n    }\n    const possibleTechnologies = getListOfPossibleTechnologiesByFirstMatchedCode(sequence, possibleSynthesizers[0]);\n    // if (possibleTechnologies.length > 1) {\n    //   const technology = ui.choiceInput('Choose technology from list: ', possibleTechnologies[0],\n    // possibleTechnologies);\n    //   ui.dialog('Choose Technology')\n    //     .add(ui.panel([technology.root], {style: {fontWeight: 'bold'}}))\n    //     .onOK(() => possibleTechnologies = [technology.value])\n    //     .onCancel(() => {\n    //       possibleTechnologies = [possibleTechnologies[0]];\n    //       grok.shell.warning('Input sequence is expected to be in format ' + possibleTechnologies[0]);\n    //     })\n    //     .show();\n    // } else if (possibleTechnologies.length == 0)\n    if (possibleTechnologies.length == 0)\n        return { indexOfFirstNotValidChar: 0, synthesizer: null, technology: null };\n    outputIndex = 0;\n    possibleTechnologies.forEach((technology) => {\n        const codes = Object.keys(map[possibleSynthesizers[0]][technology]);\n        while (outputIndex < sequence.length) {\n            const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));\n            if (matchedCode == null)\n                break;\n            if ( // for mistake pattern 'rAA'\n            outputIndex > 1 &&\n                nucleotides.includes(sequence[outputIndex]) &&\n                firstUniqueCharacters.includes(sequence[outputIndex - 2]))\n                break;\n            if ( // for mistake pattern 'ArA'\n            firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&\n                nucleotides.includes(sequence[outputIndex])) {\n                outputIndex++;\n                break;\n            }\n            outputIndex += matchedCode.length;\n        }\n    });\n    return {\n        indexOfFirstNotValidChar: indexOfFirstNotValidChar,\n        synthesizer: possibleSynthesizers,\n        technology: [possibleTechnologies[outputIndex]],\n    };\n}\nexport function getAllCodesOfSynthesizer(synthesizer) {\n    let codes = [];\n    for (const technology of Object.keys(map[synthesizer]))\n        codes = codes.concat(Object.keys(map[synthesizer][technology]));\n    return codes.concat(Object.keys(MODIFICATIONS)).concat(',');\n}\nfunction getListOfPossibleSynthesizersByFirstMatchedCode(sequence) {\n    const synthesizers = [];\n    Object.keys(map).forEach((synthesizer) => {\n        const codes = getAllCodesOfSynthesizer(synthesizer);\n        //TODO: get first non-dropdown code when there are two modifications\n        let start = 0;\n        for (let i = 0; i < sequence.length; i++) {\n            if (sequence[i] == ')' && i != sequence.length - 1) {\n                start = i + 1;\n                break;\n            }\n        }\n        if (codes.some((s) => s == sequence.slice(start, start + s.length)))\n            synthesizers.push(synthesizer);\n    });\n    return synthesizers;\n}\nfunction getListOfPossibleTechnologiesByFirstMatchedCode(sequence, synthesizer) {\n    const technologies = [];\n    Object.keys(map[synthesizer]).forEach((technology) => {\n        const codes = Object.keys(map[synthesizer][technology]).concat(Object.keys(MODIFICATIONS));\n        if (codes.some((s) => s == sequence.slice(0, s.length)))\n            technologies.push(technology);\n    });\n    return technologies;\n}\nexport function convertSequence(sequence, output) {\n    if (output.indexOfFirstNotValidChar != -1) {\n        return {\n            // type: '',\n            indexOfFirstNotValidChar: JSON.stringify(output),\n            Error: undefinedInputSequence,\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.RAW_NUCLEOTIDES)) { //&& output.technology!.includes(TECHNOLOGIES.DNA)) {\n        return {\n            type: SYNTHESIZERS.RAW_NUCLEOTIDES,\n            Nucleotides: sequence,\n            BioSpring: asoGapmersNucleotidesToBioSpring(sequence),\n            GCRS: asoGapmersNucleotidesToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.BIOSPRING) && output.technology.includes(TECHNOLOGIES.ASO_GAPMERS)) {\n        return {\n            type: SYNTHESIZERS.BIOSPRING + ' ' + TECHNOLOGIES.ASO_GAPMERS,\n            Nucleotides: asoGapmersBioSpringToNucleotides(sequence),\n            BioSpring: sequence,\n            GCRS: asoGapmersBioSpringToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.GCRS) && output.technology.includes(TECHNOLOGIES.ASO_GAPMERS)) {\n        return {\n            type: SYNTHESIZERS.GCRS + ' ' + TECHNOLOGIES.ASO_GAPMERS,\n            Nucleotides: asoGapmersGcrsToNucleotides(sequence),\n            BioSpring: asoGapmersGcrsToBioSpring(sequence),\n            Mermade12: gcrsToMermade12(sequence),\n            GCRS: sequence,\n            LCMS: gcrsToLcms(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.RAW_NUCLEOTIDES) && output.technology.includes(TECHNOLOGIES.RNA)) {\n        return {\n            type: SYNTHESIZERS.RAW_NUCLEOTIDES + ' ' + TECHNOLOGIES.RNA,\n            Nucleotides: sequence,\n            BioSpring: siRnaNucleotideToBioSpringSenseStrand(sequence),\n            Axolabs: siRnaNucleotideToAxolabsSenseStrand(sequence),\n            GCRS: siRnaNucleotidesToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.BIOSPRING) && output.technology.includes(TECHNOLOGIES.SI_RNA)) {\n        return {\n            type: SYNTHESIZERS.BIOSPRING + ' ' + TECHNOLOGIES.SI_RNA,\n            Nucleotides: siRnaBioSpringToNucleotides(sequence),\n            BioSpring: sequence,\n            Axolabs: siRnaBioSpringToAxolabs(sequence),\n            GCRS: siRnaBioSpringToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.AXOLABS)) {\n        return {\n            type: SYNTHESIZERS.AXOLABS + ' ' + TECHNOLOGIES.SI_RNA,\n            Nucleotides: siRnaAxolabsToNucleotides(sequence),\n            BioSpring: siRnaAxolabsToBioSpring(sequence),\n            Axolabs: sequence,\n            GCRS: siRnaAxolabsToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.GCRS) && output.technology.includes(TECHNOLOGIES.SI_RNA)) {\n        return {\n            type: SYNTHESIZERS.GCRS + ' ' + TECHNOLOGIES.SI_RNA,\n            Nucleotides: siRnaGcrsToNucleotides(sequence),\n            BioSpring: siRnaGcrsToBioSpring(sequence),\n            Axolabs: siRnaGcrsToAxolabs(sequence),\n            MM12: gcrsToMermade12(sequence),\n            GCRS: sequence,\n            LCMS: gcrsToLcms(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.GCRS)) {\n        return {\n            type: SYNTHESIZERS.GCRS,\n            Nucleotides: gcrsToNucleotides(sequence),\n            GCRS: sequence,\n            Mermade12: gcrsToMermade12(sequence),\n            LCMS: gcrsToLcms(sequence),\n        };\n    }\n    if (output.synthesizer.includes(SYNTHESIZERS.MERMADE_12)) {\n        return {\n            type: SYNTHESIZERS.MERMADE_12,\n            Nucleotides: noTranslationTableAvailable,\n            GCRS: noTranslationTableAvailable,\n            Mermade12: sequence,\n        };\n    }\n    return {\n        type: undefinedInputSequence,\n        Nucleotides: undefinedInputSequence,\n    };\n}\n","export const USERS_CSV = `DISPLAY\nNO DATA\n`;\n","module.exports = DG;","module.exports = OCL;","module.exports = grok;","module.exports = ui;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nvar _a;\n/* Do not change these import lines. Datagrok will import API library in exactly the same manner */\nimport * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\nimport * as OCL from 'openchemlib/full.js';\nimport $ from 'cash-dom';\nimport { defineAxolabsPattern } from './defineAxolabsPattern';\nimport { saveSenseAntiSense } from './structures-works/save-sense-antisense';\nimport { sequenceToSmiles, sequenceToMolV3000 } from './structures-works/from-monomers';\nimport { convertSequence, undefinedInputSequence, isValidSequence, getFormat } from './structures-works/sequence-codes-tools';\nimport { map, COL_NAMES, MODIFICATIONS } from './structures-works/map';\nimport { SALTS_CSV } from './salts';\nimport { USERS_CSV } from './users';\nimport { ICDS } from './ICDs';\nimport { SOURCES } from './sources';\nimport { IDPS } from './IDPs';\nexport const _package = new DG.Package();\nconst defaultInput = 'fAmCmGmAmCpsmU';\nconst sequenceWasCopied = 'Copied';\nconst tooltipSequence = 'Copy sequence';\n//name: Sequence Translator\n//tags: app\nexport function sequenceTranslator() {\n    const windows = grok.shell.windows;\n    windows.showProperties = false;\n    windows.showToolbox = false;\n    windows.showHelp = false;\n    function updateTableAndMolecule(sequence, inputFormat, isSet) {\n        moleculeSvgDiv.innerHTML = '';\n        outputTableDiv.innerHTML = '';\n        const pi = DG.TaskBarProgressIndicator.create('Rendering table and molecule...');\n        let errorsExist = false;\n        try {\n            sequence = sequence.replace(/\\s/g, '');\n            const output = isValidSequence(sequence, null);\n            if (isSet)\n                output.synthesizer = [inputFormat];\n            inputFormatChoiceInput.value = output.synthesizer[0];\n            const outputSequenceObj = convertSequence(sequence, output);\n            const tableRows = [];\n            for (const key of Object.keys(outputSequenceObj).slice(1)) {\n                const indexOfFirstNotValidChar = ('indexOfFirstNotValidChar' in outputSequenceObj) ?\n                    JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).indexOfFirstNotValidChar :\n                    -1;\n                if ('indexOfFirstNotValidChar' in outputSequenceObj) {\n                    const indexOfFirstNotValidChar = ('indexOfFirstNotValidChar' in outputSequenceObj) ?\n                        JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).indexOfFirstNotValidChar :\n                        -1;\n                    if (indexOfFirstNotValidChar != -1)\n                        errorsExist = true;\n                }\n                tableRows.push({\n                    'key': key,\n                    'value': ('indexOfFirstNotValidChar' in outputSequenceObj) ?\n                        ui.divH([\n                            ui.divText(sequence.slice(0, indexOfFirstNotValidChar), { style: { color: 'grey' } }),\n                            ui.tooltip.bind(ui.divText(sequence.slice(indexOfFirstNotValidChar), { style: { color: 'red' } }), 'Expected format: ' + JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).synthesizer +\n                                '. See tables with valid codes on the right'),\n                        ]) : //@ts-ignore\n                        ui.link(outputSequenceObj[key], () => navigator.clipboard.writeText(outputSequenceObj[key])\n                            .then(() => grok.shell.info(sequenceWasCopied)), tooltipSequence, ''),\n                });\n            }\n            if (errorsExist) {\n                const synthesizer = JSON.parse(outputSequenceObj.indexOfFirstNotValidChar).synthesizer.slice(0, -6);\n                asoGapmersGrid.onCellPrepare(function (gc) {\n                    gc.style.backColor = (gc.gridColumn.name == synthesizer) ? 0xFFF00000 : 0xFFFFFFFF;\n                });\n                omeAndFluoroGrid.onCellPrepare(function (gc) {\n                    gc.style.backColor = (gc.gridColumn.name == synthesizer) ? 0xFFF00000 : 0xFFFFFFFF;\n                });\n                switchInput.enabled = true;\n            }\n            else {\n                asoGapmersGrid.onCellPrepare(function (gc) { gc.style.backColor = 0xFFFFFFFF; });\n                omeAndFluoroGrid.onCellPrepare(function (gc) { gc.style.backColor = 0xFFFFFFFF; });\n            }\n            outputTableDiv.append(ui.div([\n                DG.HtmlTable.create(tableRows, (item) => [item.key, item.value], ['Code', 'Sequence']).root,\n            ]));\n            if (outputSequenceObj.type != undefinedInputSequence && outputSequenceObj.Error != undefinedInputSequence) {\n                const canvas = ui.canvas(300, 170);\n                canvas.addEventListener('click', () => {\n                    const canv = ui.canvas($(window).width(), $(window).height());\n                    const mol = sequenceToMolV3000(inputSequenceField.value.replace(/\\s/g, ''), false, true, output.synthesizer[0]);\n                    // @ts-ignore\n                    OCL.StructureView.drawMolecule(canv, OCL.Molecule.fromMolfile(mol), { suppressChiralText: true });\n                    ui.dialog('Molecule: ' + inputSequenceField.value)\n                        .add(canv)\n                        .showModal(true);\n                });\n                $(canvas).on('mouseover', () => $(canvas).css('cursor', 'zoom-in'));\n                $(canvas).on('mouseout', () => $(canvas).css('cursor', 'default'));\n                const mol = sequenceToMolV3000(inputSequenceField.value.replace(/\\s/g, ''), false, true, output.synthesizer[0]);\n                // @ts-ignore\n                OCL.StructureView.drawMolecule(canvas, OCL.Molecule.fromMolfile(mol), { suppressChiralText: true });\n                moleculeSvgDiv.append(canvas);\n            }\n            else\n                moleculeSvgDiv.innerHTML = '';\n        }\n        finally {\n            pi.close();\n        }\n    }\n    const inputFormatChoiceInput = ui.choiceInput('Input format: ', 'Janssen GCRS Codes', Object.keys(map), (format) => {\n        updateTableAndMolecule(inputSequenceField.value.replace(/\\s/g, ''), format, true);\n    });\n    const moleculeSvgDiv = ui.block([]);\n    const outputTableDiv = ui.div([]);\n    const inputSequenceField = ui.textInput('', defaultInput, (sequence) => updateTableAndMolecule(sequence, inputFormatChoiceInput.value, false));\n    const asoDf = DG.DataFrame.fromObjects([\n        { 'Name': '2\\'MOE-5Me-rU', 'BioSpring': '5', 'Janssen GCRS': 'moeT' },\n        { 'Name': '2\\'MOE-rA', 'BioSpring': '6', 'Janssen GCRS': 'moeA' },\n        { 'Name': '2\\'MOE-5Me-rC', 'BioSpring': '7', 'Janssen GCRS': 'moe5mC' },\n        { 'Name': '2\\'MOE-rG', 'BioSpring': '8', 'Janssen GCRS': 'moeG' },\n        { 'Name': '5-Methyl-dC', 'BioSpring': '9', 'Janssen GCRS': '5mC' },\n        { 'Name': 'ps linkage', 'BioSpring': '*', 'Janssen GCRS': 'ps' },\n        { 'Name': 'dA', 'BioSpring': 'A', 'Janssen GCRS': 'A, dA' },\n        { 'Name': 'dC', 'BioSpring': 'C', 'Janssen GCRS': 'C, dC' },\n        { 'Name': 'dG', 'BioSpring': 'G', 'Janssen GCRS': 'G, dG' },\n        { 'Name': 'dT', 'BioSpring': 'T', 'Janssen GCRS': 'T, dT' },\n        { 'Name': 'rA', 'BioSpring': '', 'Janssen GCRS': 'rA' },\n        { 'Name': 'rC', 'BioSpring': '', 'Janssen GCRS': 'rC' },\n        { 'Name': 'rG', 'BioSpring': '', 'Janssen GCRS': 'rG' },\n        { 'Name': 'rU', 'BioSpring': '', 'Janssen GCRS': 'rU' },\n    ]);\n    const asoGapmersGrid = DG.Viewer.grid(asoDf, { showRowHeader: false, showCellTooltip: false });\n    asoDf.onCurrentCellChanged.subscribe((_) => {\n        navigator.clipboard.writeText(asoDf.currentCell.value).then(() => grok.shell.info('Copied'));\n    });\n    const omeAndFluoroGrid = DG.Viewer.grid(DG.DataFrame.fromObjects([\n        { 'Name': '2\\'-fluoro-U', 'BioSpring': '1', 'Axolabs': 'Uf', 'Janssen GCRS': 'fU' },\n        { 'Name': '2\\'-fluoro-A', 'BioSpring': '2', 'Axolabs': 'Af', 'Janssen GCRS': 'fA' },\n        { 'Name': '2\\'-fluoro-C', 'BioSpring': '3', 'Axolabs': 'Cf', 'Janssen GCRS': 'fC' },\n        { 'Name': '2\\'-fluoro-G', 'BioSpring': '4', 'Axolabs': 'Gf', 'Janssen GCRS': 'fG' },\n        { 'Name': '2\\'OMe-rU', 'BioSpring': '5', 'Axolabs': 'u', 'Janssen GCRS': 'mU' },\n        { 'Name': '2\\'OMe-rA', 'BioSpring': '6', 'Axolabs': 'a', 'Janssen GCRS': 'mA' },\n        { 'Name': '2\\'OMe-rC', 'BioSpring': '7', 'Axolabs': 'c', 'Janssen GCRS': 'mC' },\n        { 'Name': '2\\'OMe-rG', 'BioSpring': '8', 'Axolabs': 'g', 'Janssen GCRS': 'mG' },\n        { 'Name': 'ps linkage', 'BioSpring': '*', 'Axolabs': 's', 'Janssen GCRS': 'ps' },\n    ]), { showRowHeader: false, showCellTooltip: false });\n    const overhangModificationsGrid = DG.Viewer.grid(DG.DataFrame.fromColumns([\n        DG.Column.fromStrings('Name', Object.keys(MODIFICATIONS)),\n    ]), { showRowHeader: false, showCellTooltip: false });\n    updateTableAndMolecule(defaultInput, inputFormatChoiceInput.value, true);\n    const appMainDescription = ui.info([\n        ui.divText('How to convert one sequence:', { style: { 'font-weight': 'bolder' } }),\n        ui.divText('Paste sequence into the text field below'),\n        ui.divText('\\n How to convert many sequences:', { style: { 'font-weight': 'bolder' } }),\n        ui.divText('1. Drag & drop an Excel or CSV file with sequences into Datagrok'),\n        ui.divText('2. Right-click on the column header, then see the \\'Convert\\' menu'),\n        ui.divText('This will add the result column to the right of the table'),\n    ], 'Convert oligonucleotide sequences between Nucleotides, BioSpring, Axolabs, Mermade 12 and GCRS representations.');\n    const codesTablesDiv = ui.splitV([\n        ui.box(ui.h2('ASO Gapmers'), { style: { maxHeight: '40px' } }),\n        asoGapmersGrid.root,\n        ui.box(ui.h2('2\\'-OMe and 2\\'-F siRNA'), { style: { maxHeight: '40px' } }),\n        omeAndFluoroGrid.root,\n        ui.box(ui.h2('Overhang modifications'), { style: { maxHeight: '40px' } }),\n        overhangModificationsGrid.root,\n    ], { style: { maxWidth: '350px' } });\n    const tabControl = ui.tabControl({\n        'MAIN': ui.box(ui.splitH([\n            ui.splitV([\n                ui.panel([\n                    appMainDescription,\n                    ui.div([\n                        ui.h1('Input sequence'),\n                        ui.div([\n                            inputSequenceField.root,\n                        ], 'input-base'),\n                    ], 'inputSequence'),\n                    ui.div([inputFormatChoiceInput], { style: { padding: '5px 0' } }),\n                    ui.block([\n                        ui.h1('Output'),\n                        outputTableDiv,\n                    ]),\n                    moleculeSvgDiv,\n                ], 'sequence'),\n            ]),\n            codesTablesDiv,\n        ], { style: { height: '100%', width: '100%' } })),\n        'AXOLABS': defineAxolabsPattern(),\n        'SDF': saveSenseAntiSense(),\n    });\n    const v = grok.shell.newView('Sequence Translator', [tabControl]);\n    v.box = true;\n    const switchInput = ui.switchInput('Codes', true, (v) => (v) ?\n        $(codesTablesDiv).show() :\n        $(codesTablesDiv).hide());\n    const topPanel = [\n        ui.iconFA('download', () => {\n            const result = sequenceToMolV3000(inputSequenceField.value.replace(/\\s/g, ''), false, false, inputFormatChoiceInput.value);\n            const element = document.createElement('a');\n            element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(result));\n            element.setAttribute('download', inputSequenceField.value.replace(/\\s/g, '') + '.mol');\n            element.click();\n        }, 'Save .mol file'),\n        ui.iconFA('copy', () => {\n            navigator.clipboard.writeText(sequenceToSmiles(inputSequenceField.value.replace(/\\s/g, ''), false, inputFormatChoiceInput.value))\n                .then(() => grok.shell.info(sequenceWasCopied));\n        }, 'Copy SMILES'),\n        switchInput.root,\n    ];\n    tabControl.onTabChanged.subscribe((_) => v.setRibbonPanels([(tabControl.currentPane.name == 'MAIN') ? topPanel : []]));\n    v.setRibbonPanels([topPanel]);\n}\nfunction saveTableAsSdFile(table) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (!table.columns.contains('Compound Name')) {\n            grok.shell.warning('File saved without columns \\'' +\n                [COL_NAMES.COMPOUND_NAME, COL_NAMES.COMPOUND_COMMENTS, COL_NAMES.CPD_MW,\n                    COL_NAMES.SALT_MASS, COL_NAMES.BATCH_MW].join('\\', \\''));\n        }\n        const structureColumn = table.col(COL_NAMES.SEQUENCE);\n        const typeColumn = table.col(COL_NAMES.TYPE);\n        let result = '';\n        for (let i = 0; i < table.rowCount; i++) {\n            const format = getFormat(structureColumn.get(i));\n            result += (typeColumn.get(i) == 'SS') ?\n                sequenceToMolV3000(structureColumn.get(i), false, true, format) + '\\n' + `>  <Sequence>\\nSense Strand\\n\\n` :\n                sequenceToMolV3000(structureColumn.get(i), true, true, format) + '\\n' + `>  <Sequence>\\nAnti Sense\\n\\n`;\n            for (const col of table.columns) {\n                if (col.name != COL_NAMES.SEQUENCE)\n                    result += `>  <${col.name}>\\n${col.get(i)}\\n\\n`;\n            }\n            result += '$$$$\\n\\n';\n        }\n        const element = document.createElement('a');\n        element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(result));\n        element.setAttribute('download', table.name + '.sdf');\n        element.click();\n    });\n}\nconst weightsObj = {};\nfor (const synthesizer of Object.keys(map)) {\n    for (const technology of Object.keys(map[synthesizer])) {\n        for (const code of Object.keys(map[synthesizer][technology]))\n            (_a = weightsObj[code]) !== null && _a !== void 0 ? _a : map[synthesizer][technology][code].weight;\n    }\n}\nfor (const [key, value] of Object.entries(MODIFICATIONS))\n    weightsObj[key] = value.molecularWeight;\nfunction sortByStringLengthInDescendingOrder(array) {\n    return array.sort(function (a, b) { return b.length - a.length; });\n}\nfunction stringifyItems(items) {\n    return '[\"' + items.join('\", \"') + '\"]';\n}\nfunction molecularWeight(sequence, weightsObj) {\n    const codes = sortByStringLengthInDescendingOrder(Object.keys(weightsObj)).concat(Object.keys(MODIFICATIONS));\n    let weight = 0;\n    let i = 0;\n    while (i < sequence.length) {\n        const matchedCode = codes.find((s) => s == sequence.slice(i, i + s.length));\n        weight += weightsObj[sequence.slice(i, i + matchedCode.length)];\n        i += matchedCode.length;\n    }\n    return weight - 61.97;\n}\n//tags: autostart\nexport function autostartOligoSdFileSubscription() {\n    grok.events.onViewAdded.subscribe((v) => {\n        if (v.type == 'TableView' && v.dataFrame.columns.contains(COL_NAMES.TYPE))\n            oligoSdFile(v.dataFrame);\n    });\n}\nexport function oligoSdFile(table) {\n    const saltsDf = DG.DataFrame.fromCsv(SALTS_CSV);\n    const usersDf = DG.DataFrame.fromCsv(USERS_CSV);\n    const sourcesDf = DG.DataFrame.fromCsv(SOURCES);\n    const icdsDf = DG.DataFrame.fromCsv(ICDS);\n    const idpsDf = DG.DataFrame.fromCsv(IDPS);\n    function addColumns(t, saltsDf) {\n        if (t.columns.contains(COL_NAMES.COMPOUND_NAME))\n            return grok.shell.error('Columns already exist!');\n        const sequence = t.col(COL_NAMES.SEQUENCE);\n        const salt = t.col(COL_NAMES.SALT);\n        const equivalents = t.col(COL_NAMES.EQUIVALENTS);\n        t.columns.addNewString(COL_NAMES.COMPOUND_NAME).init((i) => sequence.get(i));\n        t.columns.addNewString(COL_NAMES.COMPOUND_COMMENTS).init((i) => (i > 0 && i % 2 == 0) ?\n            sequence.getString(i) + '; duplex of SS: ' + sequence.getString(i - 2) + ' and AS: ' + sequence.getString(i - 1) :\n            sequence.getString(i));\n        const molWeightCol = saltsDf.col('MOLWEIGHT');\n        const saltNamesList = saltsDf.col('DISPLAY').toList();\n        t.columns.addNewFloat(COL_NAMES.CPD_MW)\n            .init((i) => molecularWeight(sequence.get(i), weightsObj));\n        t.columns.addNewFloat(COL_NAMES.SALT_MASS).init((i) => {\n            const saltRowIndex = saltNamesList.indexOf(salt.get(i));\n            const mw = molWeightCol.get(saltRowIndex);\n            return mw * equivalents.get(i);\n        });\n        t.columns.addNewCalculated(COL_NAMES.BATCH_MW, '${' + COL_NAMES.CPD_MW + '} + ${' + COL_NAMES.SALT_MASS + '}', DG.COLUMN_TYPE.FLOAT, false);\n        addColumnsPressed = true;\n        return newDf = t;\n    }\n    let newDf;\n    let addColumnsPressed = false;\n    const d = ui.div([\n        ui.icons.edit(() => {\n            d.innerHTML = '';\n            if (table.col(COL_NAMES.IDP).type != DG.COLUMN_TYPE.STRING)\n                table.changeColumnType(COL_NAMES.IDP, DG.COLUMN_TYPE.STRING);\n            d.append(ui.link('Add Columns', () => {\n                addColumns(table, saltsDf);\n                grok.shell.tableView(table.name).grid.columns.setOrder(Object.values(COL_NAMES));\n            }, 'Add columns: \\'' + [COL_NAMES.COMPOUND_NAME, COL_NAMES.COMPOUND_COMMENTS, COL_NAMES.CPD_MW,\n                COL_NAMES.SALT_MASS, COL_NAMES.BATCH_MW].join('\\', \\''), ''), ui.button('Save SD file', () => saveTableAsSdFile(addColumnsPressed ? newDf : table)));\n            const view = grok.shell.getTableView(table.name);\n            view.table.col(COL_NAMES.TYPE).setTag(DG.TAGS.CHOICES, '[\"AS\", \"SS\", \"Duplex\"]');\n            view.table.col(COL_NAMES.OWNER).setTag(DG.TAGS.CHOICES, stringifyItems(usersDf.columns.byIndex(0).toList()));\n            view.table.col(COL_NAMES.SALT).setTag(DG.TAGS.CHOICES, stringifyItems(saltsDf.columns.byIndex(0).toList()));\n            view.table.col(COL_NAMES.SOURCE).setTag(DG.TAGS.CHOICES, stringifyItems(sourcesDf.columns.byIndex(0).toList()));\n            view.table.col(COL_NAMES.ICD).setTag(DG.TAGS.CHOICES, stringifyItems(icdsDf.columns.byIndex(0).toList()));\n            view.table.col(COL_NAMES.IDP).setTag(DG.TAGS.CHOICES, stringifyItems(idpsDf.columns.byIndex(0).toList()));\n            grok.events.onContextMenu.subscribe((args) => {\n                if ([COL_NAMES.TYPE, COL_NAMES.OWNER, COL_NAMES.SALT, COL_NAMES.SOURCE, COL_NAMES.ICD, COL_NAMES.IDP]\n                    .includes(args.args.context.table.currentCol.name)) {\n                    args.args.menu.item('Fill Column With Value', () => {\n                        const v = args.args.context.table.currentCell.value;\n                        args.args.context.table.currentCell.column.init(v);\n                    });\n                }\n            });\n        }),\n    ]);\n    grok.shell.v.setRibbonPanels([[d]]);\n}\n"],"names":[],"sourceRoot":""}
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":""}