diff --git a/.Dockerfile b/.Dockerfile index aba8a16..b01c0b8 100644 --- a/.Dockerfile +++ b/.Dockerfile @@ -30,7 +30,7 @@ RUN mkdir -p /home/appuser/logs COPY static ./static COPY templates ./templates COPY tests ./tests -COPY xi_web_api ./xi_web_api +COPY xiview_server ./xiview_server COPY .env . COPY default.database.ini . COPY logging.ini . diff --git a/.env b/.env index 221c6d1..d81ef52 100644 --- a/.env +++ b/.env @@ -1,3 +1,3 @@ PYTHONHASHSEED=0 -FLASK_APP="xi_web_api/pride_loader.py" +FLASK_APP="xiview_server/pride_loader.py" XI2XIVIEWLOADER_SETTINGS=config \ No newline at end of file diff --git a/logging.ini b/logging.ini index 603757a..e3c27b0 100644 --- a/logging.ini +++ b/logging.ini @@ -15,7 +15,12 @@ handlers=fileHandler, console_handler class=FileHandler level=DEBUG formatter=simpleFormatter -args=('logs/xi_web_api.log',) +args=('logs/xiview_server.log',) + +[handler_console_handler] +class = StreamHandler +formatter = simpleFormatter +args = (sys.stdout,) [handler_console_handler] class = StreamHandler diff --git a/setup.cfg b/setup.cfg index fbe0f97..9894735 100644 --- a/setup.cfg +++ b/setup.cfg @@ -1,7 +1,7 @@ [tool:pytest] pep8maxlinelength = 100 flake8-max-line-length = 100 -#addopts = --cov=xi_web_api --cov-report html --cov-branch --cov-fail-under=90 --flake8 +#addopts = --cov=xiview_server --cov-report html --cov-branch --cov-fail-under=90 --flake8 [flake8] ignore = F403,E226,F405,W503 diff --git a/static/network.html b/static/network.html index 4883812..7376e1b 100644 --- a/static/network.html +++ b/static/network.html @@ -165,8 +165,8 @@ // diff --git a/static/pride.css b/static/pride.css index bca8b36..f3e9756 100644 --- a/static/pride.css +++ b/static/pride.css @@ -92,4 +92,8 @@ #xiNetButtonBar > span.layoutLabel.noBreak.sectionDividerLeft { border-left: 0; +} + +#helpDropdownPlaceholder > div > ul > li:nth-child(1) { + display: none !important; } \ No newline at end of file diff --git a/static/xiview.js b/static/xiview.js index c29bbf0..cdb8ef4 100644 --- a/static/xiview.js +++ b/static/xiview.js @@ -1,243777 +1,2 @@ -(function webpackUniversalModuleDefinition(root, factory) { - if(typeof exports === 'object' && typeof module === 'object') - module.exports = factory(); - else if(typeof define === 'function' && define.amd) - define([], factory); - else if(typeof exports === 'object') - exports["xiview"] = factory(); - else - root["xiview"] = factory(); -})(self, () => { -return /******/ (() => { // webpackBootstrap -/******/ var __webpack_modules__ = ({ - -/***/ "./CLMS-model/src/crosslink.js": -/*!*************************************!*\ - !*** ./CLMS-model/src/crosslink.js ***! - \*************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ Crosslink: () => (/* binding */ Crosslink) -/* harmony export */ }); -class Crosslink { - constructor(id, fromProtein, fromResidue, toProtein, toResidue) { - this.id = id; - this.matches_pp = []; - this.filteredMatches_pp = []; - - this.fromProtein = fromProtein; - this.fromResidue = fromResidue; - this.toProtein = toProtein; - this.toResidue = toResidue; - } - - isDecoyLink() { - return (this.fromProtein.is_decoy === true || - (this.toProtein && this.toProtein.is_decoy === true)); - } - - isSelfLink() { - return this.fromProtein && this.toProtein && this.fromProtein.targetProteinID === this.toProtein.targetProteinID; // mjg - } - - isLinearLink() { - return this.matches_pp[0].match.isNotCrosslinked(); - } - - isMonoLink() { - return this.matches_pp[0].match.isMonoLink(); - } - - getMeta(metaField) { - if (arguments.length === 0) { - return this.meta; - } - return this.meta ? this.meta[metaField] : undefined; - } - - setMeta(metaField, value) { - if (arguments.length === 2) { - this.meta = this.meta || {}; - this.meta[metaField] = value; - } - } -} - - -/***/ }), - -/***/ "./CLMS-model/src/old-load-spectrum.js": -/*!*********************************************!*\ - !*** ./CLMS-model/src/old-load-spectrum.js ***! - \*********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ oldLoadSpectrum: () => (/* binding */ oldLoadSpectrum) -/* harmony export */ }); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! d3 */ "./node_modules/d3/d3.js"); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(d3__WEBPACK_IMPORTED_MODULE_0__); - - -const oldLoadSpectrum = function (match, randId) { - if (match.spectrum && match.spectrum.pks) { - const formatted_data = {}; - - formatted_data.sequence1 = match.matchedPeptides[0].seq_mods; - formatted_data.linkPos1 = match.linkPos1 - 1; - if (match.matchedPeptides[1]) { - formatted_data.sequence2 = match.matchedPeptides[1].seq_mods; - formatted_data.linkPos2 = match.linkPos2 - 1; - } - formatted_data.crossLinkerModMass = match.crosslinkerModMass(); - formatted_data.modifications = window.compositeModelInst.get("clmsModel").get("modifications"); - formatted_data.precursorCharge = match.precursorCharge; - formatted_data.fragmentTolerance = match.fragmentTolerance(); - //formatted_data.customConfig = CLMSUI.compositeModelInst.get("clmsModel").get("searches").get(match.searchId).customsettings.split('\n'); - - const ions = match.ionTypes(); - formatted_data.ionTypes = ions.map(function (ion) { - return ion.type.replace("Ion", ""); - }).join(";"); - formatted_data.precursorMZ = match.expMZ(); - formatted_data.requestID = match.id; - - console.log("loadSpectrum match:" + match.id); - - d3__WEBPACK_IMPORTED_MODULE_0___default().json("./php/peakList.php?upload=" + match.searchId + "-" + randId + "&spid=" + match.spectrumId, function (error, json) { - if (error) { - console.log("error getting peak list", json); - } else { - d3__WEBPACK_IMPORTED_MODULE_0___default().select("#range-error").text(""); - - - console.log(json); - const peakArray = []; - const peakCount = json.mz.length; - for (let i = 0; i < peakCount; i++) { - peakArray.push([json.mz[i], json.intensity[i]]); - } - - formatted_data.peakList = peakArray; //JSON.parse(text).map(function(p){ return [p.mz, p.intensity]; }); - console.log(formatted_data); - window.xiSPEC.setData(formatted_data); - } - }); - } -}; - - -/***/ }), - -/***/ "./CLMS-model/src/pride-load-spectrum.js": -/*!***********************************************!*\ - !*** ./CLMS-model/src/pride-load-spectrum.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ prideLoadSpectrum: () => (/* binding */ prideLoadSpectrum) -/* harmony export */ }); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! d3 */ "./node_modules/d3/d3.js"); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(d3__WEBPACK_IMPORTED_MODULE_0__); - - -const prideLoadSpectrum = function (match, randId) { - // if (match.spectrum && match.spectrum.pks) { - const formatted_data = {}; - - const modMap = new Map(); - function createModSequence(peptide) { - let seqMods = ""; - const pepLen = peptide.base_seq.length; - for (let i = 0; i < pepLen; i++) { - seqMods += peptide.base_seq[i]; - if (peptide.mod_pos.indexOf(i) !== -1){ - const modIndex = peptide.mod_pos.indexOf(i); - const modName = "(" + peptide.mod_masses[modIndex] + ")"; - seqMods += modName; - if (!modMap.has(modName)) { - modMap.set(modName, peptide.mod_masses[modIndex]); - } - } - } - - return seqMods; - } - - console.log(createModSequence(match.matchedPeptides[0])); - - formatted_data.sequence1 = createModSequence(match.matchedPeptides[0]); - formatted_data.linkPos1 = match.linkPos1 - 1; - if (match.matchedPeptides[1]) { - formatted_data.sequence2 = createModSequence(match.matchedPeptides[1]); - formatted_data.linkPos2 = match.linkPos2 - 1; - } - formatted_data.crossLinkerModMass = match.crosslinkerModMass(); - - const modifications = []; - modMap.forEach(function (value, key) { - modifications.push({id: key, mass: value, aminoAcids: ["*"]}); - }); - - formatted_data.modifications = modifications; - formatted_data.precursorCharge = match.precursorCharge; - formatted_data.fragmentTolerance = match.fragmentTolerance(); - - const ions = match.ionTypes(); - formatted_data.ionTypes = ions.map(function (ion) { - return ion.type.replace("Ion", ""); - }).join(";"); - formatted_data.precursorMZ = match.expMZ(); - formatted_data.requestID = match.id; - - console.log("prideLoadSpectrum match:" + match.id); - - d3__WEBPACK_IMPORTED_MODULE_0___default().json("./get_peaklist?id=" + match.spectrumId + "&sd_ref=" + match.identification.sd_ref + "&upload_id=" + match.searchId, function (error, json) { - if (error) { - console.log("error getting peak list", json); - } else { - d3__WEBPACK_IMPORTED_MODULE_0___default().select("#range-error").text(""); - - - console.log(json); - const peakArray = []; - const peakCount = json.mz.length; - for (let i = 0; i < peakCount; i++) { - peakArray.push([json.mz[i], json.intensity[i]]); - } - - formatted_data.peakList = peakArray; //JSON.parse(text).map(function(p){ return [p.mz, p.intensity]; }); - console.log(formatted_data); - window.compositeModelInst.get("xispec_wrapper").setData(formatted_data); - } - }); - // } -}; - - -/***/ }), - -/***/ "./CLMS-model/src/search-results-model.js": -/*!************************************************!*\ - !*** ./CLMS-model/src/search-results-model.js ***! - \************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ SearchResultsModel: () => (/* binding */ SearchResultsModel) -/* harmony export */ }); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! d3 */ "./node_modules/d3/d3.js"); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(d3__WEBPACK_IMPORTED_MODULE_0__); -/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); -/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); -/* harmony import */ var _spectrum_match_pride_spectrum_match__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./spectrum-match/pride-spectrum-match */ "./CLMS-model/src/spectrum-match/pride-spectrum-match.js"); -/* harmony import */ var _spectrum_match_xi2_spectrum_match__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./spectrum-match/xi2-spectrum-match */ "./CLMS-model/src/spectrum-match/xi2-spectrum-match.js"); -/* harmony import */ var _spectrum_match_old_spectrum_match__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./spectrum-match/old-spectrum-match */ "./CLMS-model/src/spectrum-match/old-spectrum-match.js"); - - - - - - -//import {Peptide} from "./peptide"; - -class SearchResultsModel extends backbone__WEBPACK_IMPORTED_MODULE_1__.Model { - - constructor(attributes, options) { - super(attributes, options); - } - - //http://stackoverflow.com/questions/19835163/backbone-model-collection-property-not-empty-on-new-model-creation - defaults() { - return { - participants: new Map(), //map - matches: [], - crosslinks: new Map(), //map - scoreExtent: null, - searches: new Map(), - decoysPresent: false, - ambiguousPresent: false, - unvalidatedPresent: false, - crosslinksPresent: false, - linearsPresent: false, // TODO - scoreSets: new Set(), - selectedScoreSet: null - }; - } - - //our SpectrumMatches are constructed from the rawMatches and peptides arrays in this json - parseJSON(json) { - if (json) { - const self = this; - this.set("sid", json.sid); - if (this.get("serverFlavour") === "PRIDE") { - //modifications - // short term hack - index mod names by accession - const modificationNames = new Map(); - // for (let mod of json.modifications){ - // modificationNames.set(mod.accession, mod.mod_name); - // } - this.set("modificationNames", modificationNames); - this.set("primaryScore", {score_name:"Match Score"}); - } else if (this.get("serverFlavour") === "XI2") { - this.set("decoysPresent", true); - this.set("primaryScore", json.primary_score); - } else if (this.get("serverFlavour") === "XIVIEW.ORG") { - this.set("primaryScore", {score_name:"Match Score"}); - //modifications - var modifications = []; - var modCount = json.modifications.length; - for (var m = 0; m < modCount; m++) { - var mod = json.modifications[m]; - modifications.push({ - aminoAcids: mod.residues.split(""), - id: mod.mod_name, - mass: mod.mass - }); - } - this.set("modifications", modifications); - } - - //search meta data - const searches = new Map(); - for (let propertyName in json.searches) { - const search = json.searches[propertyName]; - searches.set(propertyName, search); - } - this.set("searches", searches); - - const getResiduesFromEnzymeDescription = function (regexMatch, residueSet) { - if (regexMatch && regexMatch.length > 1) { - const resArray = regexMatch[1].split(","); - const resCount = resArray.length; - for (let r = 0; r < resCount; r++) { - residueSet.add({ - aa: resArray[r], - postConstraint: regexMatch[2] ? regexMatch[2].split(",") : null - }); - } - } - }; - - //enzyme specificity - // TODO _ seems like theres a duplication problem here if multiple searches are aggregated - - //eliminate duplication first - // const enzymeDescriptions = new Set(); - // for (let search of searches.values()) { - // for (let enzyme of search.enzymes) { - // enzymeDescriptions.add(enzyme.description); - // } - // } - // - // const postAaSet = new Set(); - // const aaConstrainedCTermSet = new Set(); - // const aaConstrainedNTermSet = new Set(); - // - // for (let enzymeDescription of enzymeDescriptions) { - // const postAARegex = /PostAAConstrainedDigestion:DIGESTED:(.*?);ConstrainingAminoAcids:(.*?);/g; - // const postAAMatch = postAARegex.exec(enzymeDescription); - // getResiduesFromEnzymeDescription(postAAMatch, postAaSet); - // - // const cTermRegex = /CTERMDIGEST:(.*?);/g; - // const ctMatch = cTermRegex.exec(enzymeDescription); - // getResiduesFromEnzymeDescription(ctMatch, aaConstrainedCTermSet); - // - // const nTermRegex = /NTERMDIGEST:(.*?);/g; - // const ntMatch = nTermRegex.exec(enzymeDescription); - // getResiduesFromEnzymeDescription(ntMatch, aaConstrainedNTermSet); - // } - // - // const addEnzymeSpecificityResidues = function (residueSet, type) { - // const resArray = Array.from(residueSet.values()); - // const resCount = resArray.length; - // for (let r = 0; r < resCount; r++) { - // enzymeSpecificity.push({ - // aa: resArray[r].aa, - // type: type, - // postConstraint: resArray[r].postConstraint - // }); - // } - // }; - - const enzymeSpecificity = []; - // addEnzymeSpecificityResidues(postAaSet, "DIGESTIBLE"); //"Post AA constrained"); - // addEnzymeSpecificityResidues(aaConstrainedCTermSet, "DIGESTIBLE"); // "AA constrained c-term"); - // addEnzymeSpecificityResidues(aaConstrainedNTermSet, "DIGESTIBLE"); // "AA constrained n-term"); - this.set("enzymeSpecificity", enzymeSpecificity); - - //crosslink specificity - /*var linkableResSet = new Set(); - for (var s = 0; s < searchCount; s++) { - var search = searchArray[s]; - var crosslinkers = search.crosslinkers || []; - var crosslinkerCount = crosslinkers.length; - for (var cl = 0; cl < crosslinkerCount; cl++) { - var crosslinkerDescription = crosslinkers[cl].description; - var linkedAARegex = /LINKEDAMINOACIDS:(.*?)(?:;|$)/g; - var result = null; - while ((result = linkedAARegex.exec(crosslinkerDescription)) !== null) { - var resArray = result[1].split(','); - var resCount = resArray.length; - for (var r = 0; r < resCount; r++) { - var resRegex = /([A-Z])(.*)?/ - var resMatch = resRegex.exec(resArray[r]); - if (resMatch) { - linkableResSet.add(resMatch[1]); - } - } - } - } - } - this.set("crosslinkerSpecificity", CLMS.arrayFromMapValues(linkableResSet));*/ - - const linkableResSets = {}; - for (let search of searches.values()) { - const crosslinkers = search.crosslinkers || []; - - crosslinkers.forEach(function (crosslinker) { - const crosslinkerDescription = crosslinker.description; - const crosslinkerName = crosslinker.name; - const linkedAARegex = /LINKEDAMINOACIDS:(.*?)(?:;|$)/g; // capture both sets if > 1 set - // //console.log("cld", crosslinkerDescription); - let resSet = linkableResSets[crosslinkerName]; - - if (!resSet) { - resSet = { - searches: new Set(), - linkables: [], - name: crosslinkerName, - id: +crosslinker.id - }; - linkableResSets[crosslinkerName] = resSet; - } - resSet.searches.add(search.id); - - let result = null; - let i = 0; - while ((result = linkedAARegex.exec(crosslinkerDescription)) !== null) { - if (!resSet.linkables[i]) { - resSet.linkables[i] = new Set(); - } - - const resArray = result[1].split(","); - resArray.forEach(function (res) { - const resRegex = /(cterm|nterm|[A-Z])(.*)?/i; - const resMatch = resRegex.exec(res); - if (resMatch) { - resSet.linkables[i].add(resMatch[1].toUpperCase()); - } - }); - i++; - } - - if (i === 0) { - resSet.linkables.push(new Set(["*"])); // in case non-covalent - } - - resSet.heterobi = resSet.heterobi || (i > 1); - }); - } - - //console.log("CROSS", linkableResSets); - this.set("crosslinkerSpecificity", linkableResSets); - - //saved config should end up including filter settings not just xiNET layout - this.set("xiNETLayout", json.xiNETLayout); - const spectrumSources = new Map(); - if (this.get("serverFlavour") === "XI2") { - //spectrum sources - let specSource; - for (let propertyName in json.spectrumSources) { - specSource = json.spectrumSources[propertyName]; - spectrumSources.set(+specSource.id, specSource.name); - } - - //peak list files - const peakListFiles = new Map(); - let plFile; - for (let propertyName in json.peakListFiles) { - plFile = json.peakListFiles[propertyName]; - peakListFiles.set(+plFile.id, plFile.name); - } - this.set("peakListFiles", peakListFiles); - } else if (this.get("serverFlavour") === "XIVIEW.ORG") { - //spectrum sources - var specSource; - var specCount = json.spectra.length; - for (var sp = 0; sp < specCount; sp++) { - specSource = json.spectra[sp]; - spectrumSources.set(specSource.up_id + "_" + specSource.id, specSource); - } - } - this.set("spectrumSources", spectrumSources); - - const participants = this.get("participants"); - const peptides = new Map(); - if (this.get("serverFlavour") === "PRIDE") { - if (!this.isAggregatedData()) { - if (json.proteins) { - for (let participant of json.proteins) { - this.initProtein(participant, json); - participants.set(participant.id, participant); - } - } - //peptides - if (json.peptides) { - for (let peptide of json.peptides) { - SearchResultsModel.commonRegexes.notUpperCase.lastIndex = 0; - peptide.sequence = peptide.base_seq;//seq_mods.replace(SearchResultsModel.commonRegexes.notUpperCase, ""); - peptides.set(peptide.u_id + "_" + peptide.id, peptide); // concat upload_id and peptide.id - for (var p = 0; p < peptide.prt.length; p++) { - if (peptide.is_decoy[p]) { - const protein = participants.get(peptide.prt[p]); - if (!protein) { - console.error("Protein not found for peptide (not aggregated data)", peptide, peptide.prt[p]); - } - protein.is_decoy = true; - this.set("decoysPresent", true); - } - } - } - } - } else { - var tempParticipants = new Map(); - if (json.proteins) { - for (let participant of json.proteins) { - this.initProtein(participant, json); - tempParticipants.set(participant.id, participant); - } - } - //peptides - if (json.peptides) { - for (let peptide of json.peptides) { - SearchResultsModel.commonRegexes.notUpperCase.lastIndex = 0; - peptide.sequence = peptide.seq_mods.replace(SearchResultsModel.commonRegexes.notUpperCase, ""); - peptides.set(peptide.u_id + "_" + peptide.id, peptide); // concat upload_id and peptide.id - - for (var p = 0; p < peptide.prt.length; p++) { - const protein = tempParticipants.get(peptide.prt[p]); - if (!protein) { - console.error("Protein not found for peptide (aggregated data)", peptide, peptide.prt[p]); - } - if (peptide.is_decoy[p]) { - const decoyId = "DECOY_" + protein.accession; - protein.is_decoy = true; - protein.id = decoyId; - // how to get prot acc after id has been changed? - peptide.prt[p] = decoyId; - this.set("decoysPresent", true); - } else { - // fix ids for target in aggregated data - protein.id = protein.accession; - peptide.prt[p] = protein.accession; - - } - - } - } - } - - for (let participant of tempParticipants.values()) { - participants.set(participant.id, participant); - } - - } - } else if (this.get("serverFlavour") === "XI2") { - - if (json.proteins) { - for (let protein of json.proteins) { - this.initProtein(protein); - participants.set(protein.id, protein); - } - } - - //peptides - if (json.peptides) { - const peptideArray = json.peptides; - const pepCount = peptideArray.length; - let peptide; - for (let pep = 0; pep < pepCount; pep++) { - SearchResultsModel.commonRegexes.notUpperCase.lastIndex = 0; - peptide = peptideArray[pep]; - peptide.sequence = peptide.seq_mods.replace(SearchResultsModel.commonRegexes.notUpperCase, ""); - peptides.set(peptide.search_id + "_" + peptide.id, peptide); - } - } - - } else if (this.get("serverFlavour") === "XIVIEW.ORG") { - var tempParticipants = new Map(); - - if (json.proteins) { - for (let participant of json.proteins) { - this.initProtein(participant, json); - tempParticipants.set(participant.id, participant); - } - } - //peptides - if (json.peptides) { - for (let peptide of json.peptides) { - - SearchResultsModel.commonRegexes.notUpperCase.lastIndex = 0; - peptide.sequence = peptide.seq_mods.replace(SearchResultsModel.commonRegexes.notUpperCase, ""); - peptides.set(peptide.u_id + "_" + peptide.id, peptide); // concat upload_id and peptide.id - - for (var p = 0; p < peptide.prt.length; p++) { - const protein = tempParticipants.get(peptide.prt[p]); - if (!protein) { - console.error("Protein not found for peptide (aggregated data)", peptide, peptide.prt[p]); - } - if (peptide.is_decoy[p]) { - const decoyId = "DECOY_" + protein.accession; - protein.is_decoy = true; - protein.id = decoyId; - // how to get prot acc after id has been changed? - peptide.prt[p] = decoyId; - this.set("decoysPresent", true); - } else { - // fix ids for target in aggregated data - protein.id = protein.accession; - peptide.prt[p] = protein.accession; - - } - - } - } - } - - for (let participant of tempParticipants.values()) { - participants.set(participant.id, participant); - } - } - - this.initDecoyLookup(); - - const crosslinks = this.get("crosslinks"); - - let minScore = undefined; - let maxScore = undefined; - - // moved from modelUtils 05/08/19 - // Connect searches to proteins, and add the protein set as a property of a search in the clmsModel, MJG 17/05/17 - var searchMap = this.getProteinSearchMap(json.peptides, json.matches); - this.get("searches").forEach(function (value, key) { - value.participantIDSet = searchMap[key]; - }); - - if (json.matches) { - var matches = this.get("matches"); - - var l = json.matches.length; - for (var i = 0; i < l; i++) { - let match; - if (this.get("serverFlavour") === "PRIDE") { - match = new _spectrum_match_pride_spectrum_match__WEBPACK_IMPORTED_MODULE_2__.PrideSpectrumMatch(this, participants, crosslinks, peptides, json.matches[i]); - } else if (this.get("serverFlavour") === "XI2") { - match = new _spectrum_match_xi2_spectrum_match__WEBPACK_IMPORTED_MODULE_3__.Xi2SpectrumMatch(this, participants, crosslinks, peptides, json.matches[i]); - } else if (this.get("serverFlavour") === "XIVIEW.ORG") { - match = new _spectrum_match_old_spectrum_match__WEBPACK_IMPORTED_MODULE_4__.OldSpectrumMatch(this, participants, crosslinks, peptides, json.matches[i]); - } - matches.push(match); - - if (maxScore === undefined || match.score() > maxScore) { - maxScore = match.score(); - } else if (minScore === undefined || match.score() < minScore) { - minScore = match.score(); - } - } - } - - console.log("score sets:", this.get("scoreSets")); - - this.set("minScore", minScore); - this.set("maxScore", maxScore); - - const participantArray = Array.from(participants.values()); - // only count real participants towards participant count (which is used as cut-off further on) - const targetParticipantArray = participantArray.filter(function (p) { - return !p.is_decoy; - }); - - for (let participant of targetParticipantArray) { - participant.uniprot = json.interactors ? json.interactors[participant.accession.split("-")[0]] : null; - } - - window.vent.trigger("uniprotDataParsed", self); - } - - } - - // Connect searches to proteins - getProteinSearchMap(peptideArray, rawMatchArray) { - const pepMap = d3__WEBPACK_IMPORTED_MODULE_0__.map(peptideArray, function (peptide) { - return peptide.id; - }); - const searchMap = {}; - rawMatchArray = rawMatchArray || []; - rawMatchArray.forEach(function (rawMatch) { - const peptideIDs = rawMatch.pi ? rawMatch.pi : [rawMatch.pi1, rawMatch.pi2]; - peptideIDs.forEach(function (pepID) { - if (pepID) { - const prots = pepMap.get(pepID).prt; - let searchToProts = searchMap[rawMatch.primaryDataSetId]; - if (!searchToProts) { - const newSet = d3__WEBPACK_IMPORTED_MODULE_0__.set(); - searchMap[rawMatch.primaryDataSetId] = newSet; - searchToProts = newSet; - } - prots.forEach(function (prot) { - searchToProts.add(prot); - }); - } - }); - }); - return searchMap; - } - - //adds some attributes we want to protein object - initProtein(protObj, json) { - if (!protObj.crosslinks) { - protObj.crosslinks = []; - } - // check serverFlavour - if (this.get("serverFlavour") === "PRIDE") { - protObj.is_decoy = false; - } - else if (this.get("serverFlavour") === "XIVIEW.ORG") { - protObj.is_decoy = false; - var accCheck = protObj.accession.match(SearchResultsModel.commonRegexes.uniprotAccession); - if (protObj.seq_mods) { - SearchResultsModel.commonRegexes.notUpperCase.lastIndex = 0; - protObj.sequence = protObj.seq_mods.replace(SearchResultsModel.commonRegexes.notUpperCase, ""); - } else if (accCheck != null && json.interactors[protObj.accession]) { - protObj.sequence = json.interactors[protObj.accession].sequence; - } else { - protObj.sequence = ""; - } - } - protObj.size = protObj.sequence.length; - - protObj.form = 0; - - if ((!protObj.name || protObj.name.trim() === '{"","protein description"}') && protObj.accession){ - protObj.name = protObj.accession; - } - protObj.getMeta = function (metaField) { - if (arguments.length === 0) { - return this.meta; - } - return this.meta ? this.meta[metaField] : undefined; - }.bind(protObj); - - protObj.setMeta = function (metaField, value) { - if (arguments.length === 2) { - this.meta = this.meta || {}; - this.meta[metaField] = value; - } - }.bind(protObj); - } - - getDigestibleResiduesAsFeatures(participant) { - const digestibleResiduesAsFeatures = []; - - const sequence = participant.sequence; - const seqLength = sequence.length; - const specificity = this.get("enzymeSpecificity"); - - const specifCount = specificity.length; - for (let i = 0; i < specifCount; i++) { - const spec = specificity[i]; - for (let s = 0; s < seqLength; s++) { - if (sequence[s] === spec.aa) { - if (!spec.postConstraint || !sequence[s + 1] || spec.postConstraint.indexOf(sequence[s + 1]) === -1) { - digestibleResiduesAsFeatures.push({ - begin: s + 1, - end: s + 1, - name: "DIGESTIBLE", - protID: participant.id, - id: participant.id + " " + spec.type + (s + 1), - category: "AA", - type: "DIGESTIBLE" - }); - } - } - } - } - //console.log("sp:", specificity, "df:", digestibleResiduesAsFeatures); - return digestibleResiduesAsFeatures; - } - - getCrosslinkableResiduesAsFeatures(participant, reactiveGroup) { - const crosslinkableResiduesAsFeatures = []; - - const sequence = participant.sequence; - const seqLength = sequence.length; - const linkedResSets = this.get("crosslinkerSpecificity"); - - const temp = d3__WEBPACK_IMPORTED_MODULE_0__.values(linkedResSets); - for (let cl = 0; cl < temp.length; cl++) { - // resSet = {searches: new Set(), linkables: [], name: crosslinkerName}; - const crosslinkerLinkedResSet = temp[cl]; - const linkables = crosslinkerLinkedResSet.linkables; - - //for (var l = 0 ; l < linkables.length; l++) { - if (linkables[reactiveGroup - 1]) { - const linkableSet = linkables[reactiveGroup - 1]; - const linkableArr = []; - linkableSet.forEach(v => linkableArr.push(v)); - const specifCount = linkableArr.length; - for (let i = 0; i < specifCount; i++) { - const spec = linkableArr[i]; - for (let s = 0; s < seqLength; s++) { - if (sequence[s] === spec) { - crosslinkableResiduesAsFeatures.push({ - begin: s + 1, - end: s + 1, - name: "CROSSLINKABLE-" + reactiveGroup, - protID: participant.id, - id: participant.id + " Crosslinkable residue" + (s + 1) + "[group " + reactiveGroup + "]", - category: "AA", - type: "CROSSLINKABLE-" + reactiveGroup - }); - } - } - } - } - } - - console.log("reactiveGroup:", reactiveGroup, "sp:", linkedResSets, "clf:", crosslinkableResiduesAsFeatures); - return crosslinkableResiduesAsFeatures; - } - - initDecoyLookup(prefixes) { - // Make map of reverse/random decoy proteins to real proteins - prefixes = prefixes || ["REV_", "RAN_", "DECOY_", "DECOY:", "reverse_", "REV", "RAN"]; - const prots = Array.from(this.get("participants").values()); - const nameMap = d3__WEBPACK_IMPORTED_MODULE_0__.map(); - const accessionMap = d3__WEBPACK_IMPORTED_MODULE_0__.map(); - prots.forEach(function (prot) { - nameMap.set(prot.name, prot.id); - accessionMap.set(prot.accession, prot.id); - prot.targetProteinID = prot.id; // this gets overwritten for decoys in next bit, mjg - }); - - const decoys = prots.filter(function (p) { - return p.is_decoy; - }); - decoys.forEach(function (decoyProt) { - prefixes.forEach(function (pre) { - const targetProtIDByName = nameMap.get(decoyProt.name.substring(pre.length)); - if (decoyProt.accession) { - const targetProtIDByAccession = accessionMap.get(decoyProt.accession.substring(pre.length)); - if (targetProtIDByAccession) { - decoyProt.targetProteinID = targetProtIDByAccession; // mjg - } - } else if (targetProtIDByName) { - decoyProt.targetProteinID = targetProtIDByName; // mjg - } - }); - }); - - this.targetProteinCount = prots.length - decoys.length; - } - - isAggregatedData() { - return this.get("searches").size > 1; - } - - getSearchRandomId(match) { - const searchId = match.searchId; - const searchMap = this.get("searches"); - const searchData = searchMap.get(searchId); - return searchData.random_id; - } -} - -SearchResultsModel.attributeOptions = - [ - { - linkFunc: function (link) { - return [link.filteredMatches_pp.length]; - }, - unfilteredLinkFunc: function (link) { - return [link.matches_pp.length]; - }, - id: "MatchCount", - label: "Crosslink Match Count", - decimalPlaces: 0 - }, - { - linkFunc: function (link) { - return link.filteredMatches_pp.map(function (m) { - return m.match.score(); - }); - }, - unfilteredLinkFunc: function (link) { - return link.matches_pp.map(function (m) { - return m.match.score(); - }); - }, - id: "Score", - label: "Match Score", - decimalPlaces: 2, - matchLevel: true - }, - { - linkFunc: function (link) { - const scores = link.filteredMatches_pp.map(function (m) { - return m.match.score(); - }); - return [Math.max.apply(Math, scores)]; - }, - unfilteredLinkFunc: function (link) { - const scores = link.matches_pp.map(function (m) { - return m.match.score(); - }); - return [Math.max.apply(Math, scores)]; - }, - id: "Highest Score", - label: "Highest Match Score per Crosslink", - decimalPlaces: 2, - matchLevel: false - }, - { - linkFunc: function (link) { - return link.filteredMatches_pp.map(function (m) { - return m.match.precursorMZ; - }); - }, - unfilteredLinkFunc: function (link) { - return link.matches_pp.map(function (m) { - return m.match.precursorMZ; - }); - }, - id: "MZ", - label: "Match Precursor m/z", - decimalPlaces: 4, - matchLevel: true - }, - { - linkFunc: function (link) { - return link.filteredMatches_pp.map(function (m) { - return m.match.precursorCharge; - }); - }, - unfilteredLinkFunc: function (link) { - return link.matches_pp.map(function (m) { - return m.match.precursorCharge; - }); - }, - id: "Charge", - label: "Match Precursor Charge (z)", - decimalPlaces: 0, - matchLevel: true - }, - { - linkFunc: function (link) { - return link.filteredMatches_pp.map(function (m) { - return m.match.calcMass(); - }); - }, - unfilteredLinkFunc: function (link) { - return link.matches_pp.map(function (m) { - return m.match.calcMass(); - }); - }, - id: "CalcMass", - label: "Match Calculated Mass (m)", - decimalPlaces: 4, - matchLevel: true - }, - { - linkFunc: function (link) { - return link.filteredMatches_pp.map(function (m) { - return m.match.massError(); - }); - }, - unfilteredLinkFunc: function (link) { - return link.matches_pp.map(function (m) { - return m.match.massError(); - }); - }, - id: "MassError", - label: "Match Mass Error", - decimalPlaces: 4, - matchLevel: true - }, - { - linkFunc: function (link) { - return link.filteredMatches_pp.map(function (m) { - return m.match.missingPeaks(); - }); - }, - unfilteredLinkFunc: function (link) { - return link.matches_pp.map(function (m) { - return m.match.missingPeaks(); - }); - }, - id: "MissingPeaks", - label: "Missing Peaks", - decimalPlaces: 0, - matchLevel: true - }, - { - linkFunc: function (link) { - return link.filteredMatches_pp.map(function (m) { - return Math.min(m.pepPos[0].length, m.pepPos[1].length); - }); - }, - unfilteredLinkFunc: function (link) { - return link.matches_pp.map(function (m) { - return Math.min(m.pepPos[0].length, m.pepPos[1].length); - }); - }, - id: "SmallPeptideLen", - label: "Match Smaller Peptide Length (AA)", - decimalPlaces: 0, - matchLevel: true - }, - { - linkFunc: function (link) { - return link.filteredMatches_pp.map(function (m) { - const p = m.match.precursor_intensity; - return isNaN(p) ? undefined : p; - }); - }, - unfilteredLinkFunc: function (link) { - return link.matches_pp.map(function (m) { - const p = m.match.precursor_intensity; - return isNaN(p) ? undefined : p; - }); - }, - id: "PrecursorIntensity", - label: "Match Precursor Intensity", - decimalPlaces: 0, - matchLevel: true, - valueFormat: d3__WEBPACK_IMPORTED_MODULE_0__.format(".1e"), - logAxis: true, - logStart: 1000 - }, - { - linkFunc: function (link) { - return link.filteredMatches_pp.map(function (m) { - return m.match.elution_time_start; - }); - }, - unfilteredLinkFunc: function (link) { - return link.matches_pp.map(function (m) { - return m.match.elution_time_start; - }); - }, - id: "ElutionTimeStart", - label: "Elution Time Start", - decimalPlaces: 2, - matchLevel: true - }, - { - linkFunc: function (link) { - return link.filteredMatches_pp.map(function (m) { - return m.match.elution_time_end; - }); - }, - unfilteredLinkFunc: function (link) { - return link.matches_pp.map(function (m) { - return m.match.elution_time_end; - }); - }, - id: "ElutionTimeEnd", - label: "Elution Time End", - decimalPlaces: 2, - matchLevel: true - }, - { - //watch out for the 'this' reference - linkFunc: function (link) { - //return link.isLinearLink() ? [] : [this.model.getSingleCrosslinkDistance(link, null, null, option)]; - return link.isLinearLink() ? [] : [link.getMeta("distance")]; - }, - unfilteredLinkFunc: function (link) { - //return link.isLinearLink() ? [] : [this.model.getSingleCrosslinkDistance(link, null, null, option)]; - return link.isLinearLink() ? [] : [link.getMeta("distance")]; - }, - id: "Distance", - label: "Crosslink Cα-Cα Distance (Å)", - decimalPlaces: 2, - maxVal: 90, - }, - { - linkFunc: function (link) { - return link.filteredMatches_pp.map(function (m) { - return m.match.experimentalMissedCleavageCount(); - }); - }, - unfilteredLinkFunc: function (link) { - return link.matches_pp.map(function (m) { - return m.match.experimentalMissedCleavageCount(); - }); - }, - id: "ExpMissedCleavages", - label: "Experimental Max. Missed Cleavages", - decimalPlaces: 0, - matchLevel: true - }, - { - linkFunc: function (link) { - return link.filteredMatches_pp.map(function (m) { - return m.match.searchMissedCleavageCount(); - }); - }, - unfilteredLinkFunc: function (link) { - return link.matches_pp.map(function (m) { - return m.match.searchMissedCleavageCount(); - }); - }, - id: "SearchMissedCleavages", - label: "Search Max. Missed Cleavages", - decimalPlaces: 0, - matchLevel: true - }, - { - linkFunc: function (link) { - return link.filteredMatches_pp.map(function (m) { - return m.match.modificationCount(); - }); - }, - unfilteredLinkFunc: function (link) { - return link.matches_pp.map(function (m) { - return m.match.modificationCount(); - }); - }, - id: "ModificationCount", - label: "Modification Count", - decimalPlaces: 0, - matchLevel: true - }, - ]; - -SearchResultsModel.commonRegexes = { - uniprotAccession: /[OPQ][0-9][A-Z0-9]{3}[0-9]|[A-NR-Z][0-9]([A-Z][A-Z0-9]{2}[0-9]){1,2}/, - notUpperCase: /[^A-Z]/g, - decoyNames: /(REV_)|(RAN_)|(DECOY_)|(DECOY:)|(reverse_)/, -}; - - -/***/ }), - -/***/ "./CLMS-model/src/spectrum-match/old-spectrum-match.js": -/*!*************************************************************!*\ - !*** ./CLMS-model/src/spectrum-match/old-spectrum-match.js ***! - \*************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ OldSpectrumMatch: () => (/* binding */ OldSpectrumMatch) -/* harmony export */ }); -/* harmony import */ var _crosslink__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../crosslink */ "./CLMS-model/src/crosslink.js"); - - -class OldSpectrumMatch { - constructor(containingModel, participants, crosslinks, peptides, identification) { - - this.containingModel = containingModel; //containing BB model - this.spectrumId = +identification.sp; - this.searchId = identification.si.toString(); - this.primaryDataSetId = this.si; - this.precursor_intensity = null; - this.id = this.searchId + "_" + identification.id; - this.precursorMZ = +identification.e_mz; // experimental MZ, accessor for this att is called expMZ() - this.calc_mz = +identification.c_mz; - - this._scores = identification.sc; - var scoreSets = Object.keys(this._scores); - var scoreSetCount = scoreSets.length; - for (var s = 0; s < scoreSetCount; s++) { - var scoreSet = scoreSets[s]; - this.containingModel.get("scoreSets").add(scoreSet); - } - - this.passThreshold = (identification.pass == "t"); - if (identification.ions) { - var ionTypes = identification.ions.split(";"); - var ionTypeCount = ionTypes.length; - var ions = []; - for (var it = 0; it < ionTypeCount; it++) { - var ionType = ionTypes[it]; - ions.push({"type": (ionType.charAt(0).toUpperCase() + ionType.slice(1) + "Ion")}); - } - this.ions = ions; - } - - this.spectrum = this.containingModel.get("spectrumSources").get(this.searchId + "_" + this.spectrumId); - if (this.spectrum) { - this.scanNumber = +this.spectrum.sn; - } - - this.precursorCharge = +identification.pc_c; - // if (this.precursorCharge == -1) { //dodgy? - // this.precursorCharge = undefined; - // } - - this.matchedPeptides = []; - this.matchedPeptides[0] = peptides.get(this.searchId + "_" + identification.pi1); - if (!this.matchedPeptides[0]) { - alert("peptide error (missing peptide evidence?) for:" + identification.pi1); - } else { - if (this.matchedPeptides[0].is_decoy.indexOf("1") != -1) { - this.is_decoy = true; - this.containingModel.set("decoysPresent", true); - } - } - // following will be inadequate for trimeric and higher order cross-links - if (identification.pi2) { - this.matchedPeptides[1] = peptides.get(this.searchId + "_" + identification.pi2); - if (!this.matchedPeptides[1]) { - alert("peptide error (missing peptide evidence?) for:" + +identification.pi2); - } else if (this.matchedPeptides[1].is_decoy.indexOf("1") != -1) { - this.is_decoy = true; - this.containingModel.set("decoysPresent", true); - } - } - //if the match is ambiguous it will relate to many crosslinks - this.crosslinks = []; - this.linkPos1 = +this.matchedPeptides[0].linkSite; - if (this.matchedPeptides[1]) { - this.linkPos2 = this.matchedPeptides[1].linkSite; - } - - if (this.linkPos1 == -1) { - //its a linear - this.containingModel.set("linearsPresent", true); - for (var i = 0; i < this.matchedPeptides[0].prt.length; i++) { - p1ID = this.matchedPeptides[0].prt[i]; - this.associateWithLink(participants, crosslinks, p1ID); - } - if (this.matchedPeptides[1]) { - for (var i = 0; i < this.matchedPeptides[1].prt.length; i++) { - p1ID = this.matchedPeptides[1].prt[i]; - this.associateWithLink(participants, crosslinks, p1ID); - } - } - return; - } - - this.couldBelongToBetweenLink = false; - this.couldBelongToSelfLink = false; - - var self = this; - - // the protein IDs and residue numers we eventually want to get:- - var p1ID, p2ID, res1, res2; - //used along the way:- - var iProt, jProt; - - //loop to produce all alternative linkage site combinations - //(position1 count * position2 count alternative) - if (this.matchedPeptides[1]) { - for (var i = 0; i < this.matchedPeptides[0].pos.length; i++) { - for (var j = 0; j < this.matchedPeptides[1].pos.length; j++) { - - if (i > 0 || j > 0) { - this.containingModel.set("ambiguousPresent", true); - } - - //some files are not puting in duplicate protein ids in ambig links - //in this case use last one - // if (i < this.matchedPeptides[0].prt.length) { - p1ID = this.matchedPeptides[0].prt[i]; - // } else { - // p1ID = this.matchedPeptides[0].prt[this.matchedPeptides[0].prt.length - 1]; - // } - // if (j < this.matchedPeptides[1].prt.length) { - p2ID = this.matchedPeptides[1].prt[j]; - // } else { - // p2ID = this.matchedPeptides[1].prt[this.matchedPeptides[1].prt.length - 1]; - // } - - // * residue numbering starts at 1 * - res1 = +this.matchedPeptides[0].pos[i] - 1 + this.linkPos1; - res2 = +this.matchedPeptides[1].pos[j] - 1 + this.linkPos2; - - this.associateWithLink(participants, crosslinks, p1ID, p2ID, res1, res2, this.matchedPeptides[0].pos[i] - 0, this.matchedPeptides[0].sequence.length, this.matchedPeptides[1].pos[j], this.matchedPeptides[1].sequence.length); - } - } - } else { - for (var i = 0; i < this.matchedPeptides[0].pos.length; i++) { - if (i > 0) { - this.containingModel.set("ambiguousPresent", true); - } - p1ID = this.matchedPeptides[0].prt[i]; - // * residue numbering starts at 1 * - res1 = +this.matchedPeptides[0].pos[i] - 1 + this.linkPos1; - this.associateWithLink(participants, crosslinks, p1ID, null, res1, null, this.matchedPeptides[0].pos[i] - 0, this.matchedPeptides[0].sequence.length, null, null); - } - } - //identify homodimers: if peptides overlap its a homodimer - this.confirmedHomomultimer = false; - this.overlap = []; - if (this.isAmbig() == false && p1ID == p2ID) { //todo: fix potential problem here regarding ambiguous homo-multimer link - - if (this.matchedPeptides[0].sequence && this.matchedPeptides[1].sequence) { - - var pep1length = this.matchedPeptides[0].sequence.length; - var pep2length = this.matchedPeptides[1].sequence.length; - var pep1_start = +this.matchedPeptides[0].pos[0]; - var pep2_start = +this.matchedPeptides[1].pos[0]; - var pep1_end = pep1_start + (pep1length - 1); - var pep2_end = pep2_start + (pep2length - 1); - if (pep1_start >= pep2_start && pep1_start <= pep2_end) { - this.confirmedHomomultimer = true; - this.overlap[0] = pep1_start - 1; - if (pep1_end < pep2_end) { - this.overlap[1] = pep1_end; - } else { - this.overlap[1] = pep2_end; - } - } else if (pep2_start >= pep1_start && pep2_start <= pep1_end) { - this.confirmedHomomultimer = true; - this.overlap[0] = pep2_start - 1; - if (pep2_end < pep1_end) { - this.overlap[1] = pep2_end; - } else { - this.overlap[1] = pep1_end; - } - } - } else if (res1 === res2) { - this.confirmedHomomultimer = true; - this.overlap[0] = res1 - 1; - this.overlap[1] = res2; - } - } - } - - associateWithLink(proteins, crosslinks, p1ID, p2ID, res1, res2, //following params may be null :- - pep1_start, pep1_length, pep2_start, pep2_length) { - - // we don't want two different ID's, e.g. one thats "33-66" and one thats "66-33" - //following puts lower protein_ID first in link_ID - - //todo: this end swapping thing, its a possible source of confusion - - let fromProt, toProt; - - if (!p2ID || p2ID == "" || p2ID == "-" || p2ID == "n/a") { //its a linear peptide (no crosslinker of any product type)) - this.containingModel.set("linearsPresent", true); - fromProt = proteins.get(p1ID); - if (!fromProt) { - alert("FAIL: not protein with ID " + p1ID); - } - } else if (p1ID <= p2ID) { - fromProt = proteins.get(p1ID); - toProt = proteins.get(p2ID); - if (!fromProt) { - alert("FAIL: not protein with ID " + p1ID); - } - if (!toProt) { - alert("FAIL: not protein with ID " + p2ID); - } - } else { - fromProt = proteins.get(p2ID); - toProt = proteins.get(p1ID); - if (!fromProt) { - alert("FAIL: not protein with ID " + p2ID); - } - if (!toProt) { - alert("FAIL: not protein with ID " + p1ID); - } - } - - if (fromProt && toProt && fromProt.targetProteinID === toProt.targetProteinID) { - this.couldBelongToSelfLink = true; - } else if (!this.isMonoLink()) { - this.couldBelongToBetweenLink = true; - } - - // again, order id string by prot id or by residue if self-link - let endsReversedInResLinkId = false; - let crosslinkID; - if (this.isNotCrosslinked()) { - crosslinkID = p1ID + "_linears"; - } else if (p1ID === p2ID || p2ID === null) { - if ((res1 - 0) < (res2 - 0) || res2 === null) { - crosslinkID = p1ID + "_" + res1 + "-" + p2ID + "_" + res2; - } else { - crosslinkID = p2ID + "_" + res2 + "-" + p1ID + "_" + res1; - endsReversedInResLinkId = true; - } - } else if (p1ID < p2ID) { - crosslinkID = p1ID + "_" + res1 + "-" + p2ID + "_" + res2; - } else { - crosslinkID = p2ID + "_" + res2 + "-" + p1ID + "_" + res1; - endsReversedInResLinkId = true; - } - - //get or create residue link - let resLink = crosslinks.get(crosslinkID); - if (typeof resLink == "undefined") { - //to and from proteins were already swapped over above - - //WATCH OUT - residues need to be in correct order - if (!p2ID) { - resLink = new _crosslink__WEBPACK_IMPORTED_MODULE_0__.Crosslink(crosslinkID, fromProt, - res1, null, null, this.containingModel); - } else if (p1ID === p2ID) { - if ((res1 - 0) < (res2 - 0)) { - resLink = new _crosslink__WEBPACK_IMPORTED_MODULE_0__.Crosslink(crosslinkID, fromProt, res1, toProt, res2, this.containingModel); - } else { - resLink = new _crosslink__WEBPACK_IMPORTED_MODULE_0__.Crosslink(crosslinkID, fromProt, res2, toProt, res1, this.containingModel); - } - } else if (p1ID === fromProt.id) { - resLink = new _crosslink__WEBPACK_IMPORTED_MODULE_0__.Crosslink(crosslinkID, fromProt, res1, toProt, res2, this.containingModel); - } else { - //WATCH OUT - residues need to be in correct oprder - resLink = new _crosslink__WEBPACK_IMPORTED_MODULE_0__.Crosslink(crosslinkID, fromProt, res2, toProt, res1, this.containingModel); - } - crosslinks.set(crosslinkID, resLink); - - fromProt.crosslinks.push(resLink); - if (toProt && (toProt !== fromProt)) { - toProt.crosslinks.push(resLink); - } - } - - const peptidePositions = []; - if (endsReversedInResLinkId === false) { - peptidePositions.push({ - start: pep1_start, - length: pep1_length - }); - peptidePositions.push({ - start: pep2_start, - length: pep2_length - }); - } else { - peptidePositions.push({ - start: pep2_start, - length: pep2_length - }); - peptidePositions.push({ - start: pep1_start, - length: pep1_length - }); - } - resLink.matches_pp.push({ - match: this, - pepPos: peptidePositions - }); - this.crosslinks.push(resLink); - } - - isAmbig() { - return this.matchedPeptides[0].pos.length > 1 || - (this.matchedPeptides[1] && this.matchedPeptides[1].pos.length > 1); - } - - isDecoy() { - if (this.is_decoy) { - return this.is_decoy; - } else { - //its from csv not database, for simplicity lets just look at first crosslink //todo - look at again - return this.crosslinks[0].isDecoyLink(); - } - } - - isNotCrosslinked() { - return this.linkPos1 === -1; - } - - isMonoLink() { - return this.linkPos1 !== -1 && (this.matchedPeptides.length === 1 || this.linkPos2 == -1 || this.matchedPeptides[1].pos[0] == -1); - } - - runName() { - if (this.spectrum) { - return this.spectrum.file; - } - } - - peakListFileName() { - if (this.spectrum) { - return this.spectrum.file; - } - } - - group() { - var group = this.containingModel.get("searches").get(this.searchId).group; - return group; - } - - expMZ() { - return this.precursorMZ; - } - - - expMass() { - return this.precursorMZ * this.precursorCharge - (this.precursorCharge * OldSpectrumMatch.protonMass); - } - - calcMZ() { - return this.calc_mz;// (this.calc_mass + (this.precursorCharge * SpectrumMatch.protonMass)) / this.precursorCharge; - } - - calcMass() { - return (this.precursorCharge * this.calc_mz) - (this.precursorCharge * OldSpectrumMatch.protonMass); //this.calc_mass; - } - - massError() { - return ((this.expMass() - this.calcMass()) / this.calcMass()) * 1000000; - } - - missingPeaks() { - const errorMZ = this.expMZ() - this.calcMZ(); - const errorM = errorMZ * this.precursorCharge; - //how many peaks assumed missing/miss-assigned - return Math.round(errorM / OldSpectrumMatch.C13_MASS_DIFFERENCE); - } - - ionTypes() { - return this.ions; - } - - ionTypesString() { - return JSON.stringify(this.ionTypes()); - } - - crosslinkerModMass() { - var clModMass = +this.matchedPeptides[0].clModMass; - if (this.matchedPeptides[1]) { - clModMass = clModMass + (+this.matchedPeptides[1].clModMass); - } - return clModMass; - } - - fragmentTolerance() { - if (this.spectrum) { - var fragTolArr = this.spectrum.ft.split(" "); - return { - "tolerance": fragTolArr[0], - "unit": fragTolArr[1] - }; - } - } - - fragmentToleranceString() { - var fragTol = this.fragmentTolerance(); - if (fragTol) { - return fragTol.tolerance + " " + fragTol.unit; - } - } - - score() { - //return this._scores.score; - var scoreSets = this.containingModel.get("scoreSets"); - //if (scoreSets.size == 1) { - var scoreSet = scoreSets.keys().next().value; - var s = this._scores[scoreSet]; - //console.log("!", s); - return s; - //} - } - - modificationCount() { - function peptideModCount(peptide) { - let count = 0; - const sequence = peptide.seq_mods; - const pepLen = sequence.length; - for (let i = 0; i < pepLen - 1; i++) { - const a = sequence[i]; - const b = sequence[i + 1]; - if ((a >= "A" && a <= "Z") && (b < "A" || b > "Z")) count++; - } - return count; - } - - const modCount1 = peptideModCount(this.matchedPeptides[0]); - if (this.matchedPeptides[1]) { - const modCount2 = peptideModCount(this.matchedPeptides[1]); - if (modCount2 > modCount1) { - return modCount2; - } - } - return modCount1; - } -} - -OldSpectrumMatch.protonMass = 1.007276466879; -OldSpectrumMatch.C13_MASS_DIFFERENCE = 1.0033548; - - -/***/ }), - -/***/ "./CLMS-model/src/spectrum-match/pride-spectrum-match.js": -/*!***************************************************************!*\ - !*** ./CLMS-model/src/spectrum-match/pride-spectrum-match.js ***! - \***************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ PrideSpectrumMatch: () => (/* binding */ PrideSpectrumMatch) -/* harmony export */ }); -/* harmony import */ var _crosslink__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../crosslink */ "./CLMS-model/src/crosslink.js"); -/* harmony import */ var _spectrum_match__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./spectrum-match */ "./CLMS-model/src/spectrum-match/spectrum-match.js"); - - - -class PrideSpectrumMatch extends _spectrum_match__WEBPACK_IMPORTED_MODULE_1__.SpectrumMatch{ - constructor(containingModel, participants, crosslinks, peptides, identification) { - super(); - this.containingModel = containingModel; //containing BB model - this.identification = identification; - this.primaryDataSetId = identification.si; - this.precursor_intensity = null; - this.spectrumId = identification.sp; - this.searchId = identification.si.toString(); - this.id = this.searchId + "_" + identification.id; - this.precursorMZ = +identification.pc_mz; // experimental MZ, accessor for this att is called expMZ() - this.calc_mz = +identification.c_mz; - this._scores = identification.sc; - var scoreSets = Object.keys(this._scores); - var scoreSetCount = scoreSets.length; - for (var s = 0; s < scoreSetCount; s++) { - var scoreSet = scoreSets[s]; - this.containingModel.get("scoreSets").add(scoreSet); - } - - this.passThreshold = !!identification.pass; - if (identification.ions) { - var ionTypes = identification.ions.split(";"); - var ionTypeCount = ionTypes.length; - var ions = []; - for (var it = 0; it < ionTypeCount; it++) { - var ionType = ionTypes[it]; - ions.push({"type": (ionType.charAt(0).toUpperCase() + ionType.slice(1) + "Ion")}); - } - this.ions = ions; - } else { - this.ions = [{type:"bIon"}, {type:"yIon"}]; - } - - this.spectrum = this.containingModel.get("spectrumSources").get(this.searchId + "_" + this.spectrumId); - - this.precursorCharge = +identification.pc_c; - if (this.precursorCharge === -1) { - this.precursorCharge = undefined; - } - - this.matchedPeptides = []; - this.matchedPeptides[0] = peptides.get(this.searchId + "_" + identification.pi1); - if (!this.matchedPeptides[0]) { - alert("peptide error (missing peptide evidence?) for:" + identification.pi1); - } else { - if (this.matchedPeptides[0].is_decoy.indexOf("1") != -1) { - this.is_decoy = true; - this.containingModel.set("decoysPresent", true); - } - } - // following will be inadequate for trimeric and higher order cross-links - if (identification.pi2) { - this.matchedPeptides[1] = peptides.get(this.searchId + "_" + identification.pi2); - if (!this.matchedPeptides[1]) { - alert("peptide error (missing peptide evidence?) for:" + +identification.pi2); - } else if (this.matchedPeptides[1].is_decoy.indexOf("1") != -1) { - this.is_decoy = true; - this.containingModel.set("decoysPresent", true); - } - } - //if the match is ambiguous it will relate to many crosslinks - this.crosslinks = []; - this.linkPos1 = +this.matchedPeptides[0].linkSite; - if (this.matchedPeptides[1]) { - this.linkPos2 = this.matchedPeptides[1].linkSite; - } - - // the protein IDs and residue numers we eventually want to get:- - let p1ID, p2ID, res1, res2; - - if (this.isNotCrosslinked()) { - //its a linear - this.containingModel.set("linearsPresent", true); - for (let i = 0; i < this.matchedPeptides[0].prt.length; i++) { - p1ID = this.matchedPeptides[0].prt[i]; - this.associateWithLink(participants, crosslinks, p1ID); - } - if (this.matchedPeptides[1]) { - for (let i = 0; i < this.matchedPeptides[1].prt.length; i++) { - p1ID = this.matchedPeptides[1].prt[i]; - this.associateWithLink(participants, crosslinks, p1ID); - } - } - return; - } - - this.couldBelongToBetweenLink = false; - this.couldBelongToSelfLink = false; - - //loop to produce all alternative linkage site combinations - //(position1 count * position2 count alternative) - for (let i = 0; i < this.matchedPeptides[0].pos.length; i++) { - for (let j = 0; j < this.matchedPeptides[1].pos.length; j++) { - - if (i > 0 || j > 0) { - this.containingModel.set("ambiguousPresent", true); - } - - //some files (must be csv) are not puting in duplicate protein ids in ambig links - //in this case use last one - if (i < this.matchedPeptides[0].prt.length) { - p1ID = this.matchedPeptides[0].prt[i]; - } else { - p1ID = this.matchedPeptides[0].prt[this.matchedPeptides[0].prt.length - 1]; - } - if (j < this.matchedPeptides[1].prt.length) { - p2ID = this.matchedPeptides[1].prt[j]; - } else { - p2ID = this.matchedPeptides[1].prt[this.matchedPeptides[1].prt.length - 1]; - } - - // * residue numbering starts at 1 * - res1 = +this.matchedPeptides[0].pos[i] - 1 + this.linkPos1; - res2 = +this.matchedPeptides[1].pos[j] - 1 + this.linkPos2; - - this.associateWithLink(participants, crosslinks, p1ID, p2ID, res1, res2, this.matchedPeptides[0].pos[i] - 0, this.matchedPeptides[0].sequence.length, this.matchedPeptides[1].pos[j], this.matchedPeptides[1].sequence.length); - } - } - - //identify homodimers: if peptides overlap its a homodimer - this.confirmedHomomultimer = false; - this.overlap = []; - if (this.isAmbig() === false && p1ID === p2ID) { //todo: potential problem re ambiguous homo-multimer link (compare current behaviour to xiNET paper product type fig) - - if (this.matchedPeptides[0].sequence && this.matchedPeptides[1].sequence) { - - const pep1length = this.matchedPeptides[0].sequence.length; - const pep2length = this.matchedPeptides[1].sequence.length; - const pep1_start = +this.matchedPeptides[0].pos[0]; - const pep2_start = +this.matchedPeptides[1].pos[0]; - const pep1_end = pep1_start + (pep1length - 1); - const pep2_end = pep2_start + (pep2length - 1); - if (pep1_start >= pep2_start && pep1_start <= pep2_end) { - this.confirmedHomomultimer = true; - this.overlap[0] = pep1_start - 1; - if (pep1_end < pep2_end) { - this.overlap[1] = pep1_end; - } else { - this.overlap[1] = pep2_end; - } - } else if (pep2_start >= pep1_start && pep2_start <= pep1_end) { - this.confirmedHomomultimer = true; - this.overlap[0] = pep2_start - 1; - if (pep2_end < pep1_end) { - this.overlap[1] = pep2_end; - } else { - this.overlap[1] = pep1_end; - } - } - } else if (res1 === res2) { - this.confirmedHomomultimer = true; - this.overlap[0] = res1 - 1; - this.overlap[1] = res2; - } - } - } - - isNotCrosslinked() { - return this.linkPos1 === -1; - } - - isMonoLink() { - return this.linkPos1 !== -1 && (this.matchedPeptides.length === 1 || this.linkPos2 == -1 || this.matchedPeptides[1].pos[0] == -1); - } - - runName() { - if (this.spectrum) { - return this.spectrum.file; - } - } - - peakListFileName() { - if (this.spectrum) { - return this.spectrum.file; - } - } - - group() { - return -1; // temp - var group = this.containingModel.get("searches").get(this.searchId).group; - return group; - } - - expMZ() { - return this.precursorMZ; - } - - - expMass() { - return this.precursorMZ * this.precursorCharge - (this.precursorCharge * PrideSpectrumMatch.protonMass); - } - - calcMZ() { - return this.calc_mz;// (this.calc_mass + (this.precursorCharge * PrideSpectrumMatch.protonMass)) / this.precursorCharge; - } - - calcMass() { - return (this.precursorCharge * this.calc_mz) - (this.precursorCharge * PrideSpectrumMatch.protonMass); //this.calc_mass; - } - - missingPeaks() { - const errorMZ = this.expMZ() - this.calcMZ(); - const errorM = errorMZ * this.precursorCharge; - //how many peaks assumed missing/miss-assigned - return Math.round(errorM / PrideSpectrumMatch.C13_MASS_DIFFERENCE); - } - - massError() { - return ((this.expMass() - this.calcMass()) / this.calcMass()) * 1000000; - } - - ionTypes() { - return this.ions; - } - - ionTypesString() { - return JSON.stringify(this.ionTypes()); - } - - crosslinkerModMass() { - var clModMass = +this.matchedPeptides[0].cl_modmass; - if (this.matchedPeptides[1]) { - clModMass = clModMass + (+this.matchedPeptides[1].cl_modmass); - } - return clModMass; - } - - fragmentTolerance() { - if (this.spectrum) { - var fragTolArr = this.spectrum.ft.split(" "); - return { - "tolerance": fragTolArr[0], - "unit": fragTolArr[1] - }; - } - } - - fragmentToleranceString() { - var fragTol = this.fragmentTolerance(); - if (fragTol) { - return fragTol.tolerance + " " + fragTol.unit; - } - } - - score() { - //return this._scores.score; - var scoreSets = this.containingModel.get("scoreSets"); - //if (scoreSets.size == 1) { - var scoreSet = scoreSets.keys().next().value; - var s = this._scores[scoreSet]; - //console.log("!", s); - return s; - //} - } - - modificationCount() { - return -1; //temp - const modCount1 = this.matchedPeptides[0].mod_pos.length; - if (this.matchedPeptides[1]) { - const modCount2 = this.matchedPeptides[1].mod_pos.length; - if (modCount2 > modCount1) { - return modCount2; - } - } - return modCount1; - } - - get pepSeq1_base() { - return this.matchedPeptides[0].sequence; - } - - get pepSeq2_base() { - if (this.matchedPeptides[1]) { - return this.matchedPeptides[1].sequence; - } else { - return ""; - } - } - - get pepSeq1_mods() { - return this.pepSeq1_base; - } - - get pepSeq2_mods() { - return this.pepSeq2_base; - } - - get psmId() { - return this.identification.id; - } - - get datasetId() { - return this.searchId; - } - - get scanNumber() { - // if (this.spectrum) { - return this.spectrumId; - // } - } -} - -PrideSpectrumMatch.protonMass = 1.007276466879; -PrideSpectrumMatch.C13_MASS_DIFFERENCE = 1.0033548; - - -/***/ }), - -/***/ "./CLMS-model/src/spectrum-match/spectrum-match.js": -/*!*********************************************************!*\ - !*** ./CLMS-model/src/spectrum-match/spectrum-match.js ***! - \*********************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ SpectrumMatch: () => (/* binding */ SpectrumMatch) -/* harmony export */ }); -/* harmony import */ var _crosslink__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../crosslink */ "./CLMS-model/src/crosslink.js"); - - -class SpectrumMatch { - - constructor() { - - } - - associateWithLink(proteins, crosslinks, p1ID, p2ID, res1, res2, //following params may be null :- - pep1_start, pep1_length, pep2_start, pep2_length) { - - // we don't want two different ID's, e.g. one that's "33-66" and one that's "66-33" - //following puts lower protein_ID first in link_ID - - //todo: this end swapping thing, its a possible source of confusion - - let fromProt, toProt; - - if (this.isNotCrosslinked()) {//!p2ID || p2ID === "" || p2ID === '-' || p2ID === 'n/a') { //its a linear peptide (no crosslinker of any product type)) - this.containingModel.set("linearsPresent", true); - fromProt = proteins.get(p1ID); - if (!fromProt) { - alert("FAIL: not protein with ID " + p1ID); - } - } else if (p1ID <= p2ID) { - fromProt = proteins.get(p1ID); - toProt = proteins.get(p2ID); - if (!fromProt) { - alert("FAIL: not protein with ID " + p1ID); - } - if (!toProt) { - alert("FAIL: not protein with ID " + p2ID); - } - } else { - fromProt = proteins.get(p2ID); - toProt = proteins.get(p1ID); - if (!fromProt) { - alert("FAIL: not protein with ID " + p2ID); - } - if (!toProt) { - alert("FAIL: not protein with ID " + p1ID); - } - } - - if (fromProt && toProt && fromProt.targetProteinID === toProt.targetProteinID) { - this.couldBelongToSelfLink = true; - } else if (!this.isMonoLink()) { - this.couldBelongToBetweenLink = true; - } - - // again, order id string by prot id or by residue if self-link - let endsReversedInResLinkId = false; - let crosslinkID; - if (this.isNotCrosslinked()) { - crosslinkID = p1ID + "_linears"; - } else if (p1ID === p2ID || p2ID === null) { - if ((res1 - 0) < (res2 - 0) || res2 === null) { - crosslinkID = p1ID + "_" + res1 + "-" + p2ID + "_" + res2; - } else { - crosslinkID = p2ID + "_" + res2 + "-" + p1ID + "_" + res1; - endsReversedInResLinkId = true; - } - } else if (p1ID < p2ID) { - crosslinkID = p1ID + "_" + res1 + "-" + p2ID + "_" + res2; - } else { - crosslinkID = p2ID + "_" + res2 + "-" + p1ID + "_" + res1; - endsReversedInResLinkId = true; - } - - //get or create residue link - let resLink = crosslinks.get(crosslinkID); - if (typeof resLink == "undefined") { - //to and from proteins were already swapped over above - - //WATCH OUT - residues need to be in correct order - if (this.isNotCrosslinked()) { - resLink = new _crosslink__WEBPACK_IMPORTED_MODULE_0__.Crosslink(crosslinkID, fromProt, - res1, null, null, this.containingModel); - } else if (p1ID === p2ID) { - if ((res1 - 0) < (res2 - 0)) { - resLink = new _crosslink__WEBPACK_IMPORTED_MODULE_0__.Crosslink(crosslinkID, fromProt, res1, toProt, res2, this.containingModel); - } else { - resLink = new _crosslink__WEBPACK_IMPORTED_MODULE_0__.Crosslink(crosslinkID, fromProt, res2, toProt, res1, this.containingModel); - } - } else if (p1ID === fromProt.id) { - resLink = new _crosslink__WEBPACK_IMPORTED_MODULE_0__.Crosslink(crosslinkID, fromProt, res1, toProt, res2, this.containingModel); - } else { - //WATCH OUT - residues need to be in correct oprder - resLink = new _crosslink__WEBPACK_IMPORTED_MODULE_0__.Crosslink(crosslinkID, fromProt, res2, toProt, res1, this.containingModel); - } - crosslinks.set(crosslinkID, resLink); - - fromProt.crosslinks.push(resLink); - if (toProt && (toProt !== fromProt)) { - toProt.crosslinks.push(resLink); - } - } - - const peptidePositions = []; - if (endsReversedInResLinkId === false) { - peptidePositions.push({ - start: pep1_start, - length: pep1_length - }); - peptidePositions.push({ - start: pep2_start, - length: pep2_length - }); - } else { - peptidePositions.push({ - start: pep2_start, - length: pep2_length - }); - peptidePositions.push({ - start: pep1_start, - length: pep1_length - }); - } - resLink.matches_pp.push({ - match: this, - pepPos: peptidePositions - }); - this.crosslinks.push(resLink); - } - - isAmbig() { - return this.matchedPeptides[0].pos.length > 1 || - (this.matchedPeptides[1] && this.matchedPeptides[1].pos.length > 1); - } - - isDecoy() { - if (this.is_decoy) { - return this.is_decoy; - } else { - //its from csv not database, for simplicity lets just look at first crosslink //todo - look at again - return this.crosslinks[0].isDecoyLink(); - } - } - -} - -/***/ }), - -/***/ "./CLMS-model/src/spectrum-match/xi2-spectrum-match.js": -/*!*************************************************************!*\ - !*** ./CLMS-model/src/spectrum-match/xi2-spectrum-match.js ***! - \*************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ Xi2SpectrumMatch: () => (/* binding */ Xi2SpectrumMatch) -/* harmony export */ }); -/* harmony import */ var _crosslink__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../crosslink */ "./CLMS-model/src/crosslink.js"); -/* harmony import */ var _spectrum_match__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./spectrum-match */ "./CLMS-model/src/spectrum-match/spectrum-match.js"); - - - -class Xi2SpectrumMatch extends _spectrum_match__WEBPACK_IMPORTED_MODULE_1__.SpectrumMatch { - constructor(containingModel, participants, crosslinks, peptides, identification) { - super(); - this.containingModel = containingModel; //containing BB model - this.identification = identification; - this.primaryDataSetId = identification.rs_id; - this.spectrumId = identification.sp; - this.searchId = identification.si.toString(); - this.id = identification.id; - this.precursorMZ = +identification.pc_mz; - this.calc_mass = +identification.cm; - this._score = +identification.sc; - - - this.resultSetId = identification.rs_id.toString(); - this.crosslinker_id = identification.cl; - - // this.scanNumber = null;//+identificationes[0].sn; - this.scanIndex = null;//+identificationes[0].sc_i; - this.precursor_intensity = +identification.pc_i; - this.elution_time_start = +identification.rt; - this.elution_time_end = null;//+identificationes[0].e_e; - - this.src = null;//+identificationes[0].src; //for looking up run name - this.plf = null;//+identificationes[0].plf; //for looking up peak list file name - //run name may have come from csv file - - this.precursorCharge = +identification.pc_c; - if (this.precursorCharge === -1) { - this.precursorCharge = undefined; - } - - this.matchedPeptides = []; - this.matchedPeptides[0] = peptides.get(this.searchId + "_" + identification.pi1); - // following will be inadequate for trimeric and higher order cross-links - if (!this.isNotCrosslinked()) { - this.matchedPeptides[1] = peptides.get(this.searchId + "_" + identification.pi2); - } - // } else { //*here - if its from a csv file use identificationes as the matchedPep array, - // //makes it easier to construct as parsing CSV - // this.matchedPeptides = identificationes; - // } - - //if the match is ambiguous it will relate to many crosslinks - this.crosslinks = []; - this.linkPos1 = +identification.s1; - // if (identification.s2) { - this.linkPos2 = +identification.s2; - // } - - // the protein IDs and residue numers we eventually want to get:- - let p1ID, p2ID, res1, res2; - - if (this.isNotCrosslinked()) { - //its a linear - this.containingModel.set("linearsPresent", true); - for (let i = 0; i < this.matchedPeptides[0].prt.length; i++) { - p1ID = this.matchedPeptides[0].prt[i]; - this.associateWithLink(participants, crosslinks, p1ID); - } - if (this.matchedPeptides[1]) { - for (let i = 0; i < this.matchedPeptides[1].prt.length; i++) { - p1ID = this.matchedPeptides[1].prt[i]; - this.associateWithLink(participants, crosslinks, p1ID); - } - } - return; - } - - this.couldBelongToBetweenLink = false; - this.couldBelongToSelfLink = false; - - //loop to produce all alternative linkage site combinations - //(position1 count * position2 count alternative) - for (let i = 0; i < this.matchedPeptides[0].pos.length; i++) { - for (let j = 0; j < this.matchedPeptides[1].pos.length; j++) { - - if (i > 0 || j > 0) { - this.containingModel.set("ambiguousPresent", true); - } - - //some files (must be csv) are not puting in duplicate protein ids in ambig links - //in this case use last one - if (i < this.matchedPeptides[0].prt.length) { - p1ID = this.matchedPeptides[0].prt[i]; - } else { - p1ID = this.matchedPeptides[0].prt[this.matchedPeptides[0].prt.length - 1]; - } - if (j < this.matchedPeptides[1].prt.length) { - p2ID = this.matchedPeptides[1].prt[j]; - } else { - p2ID = this.matchedPeptides[1].prt[this.matchedPeptides[1].prt.length - 1]; - } - - // * residue numbering starts at 1 * - res1 = +this.matchedPeptides[0].pos[i] - 1 + this.linkPos1; - res2 = +this.matchedPeptides[1].pos[j] - 1 + this.linkPos2; - - this.associateWithLink(participants, crosslinks, p1ID, p2ID, res1, res2, this.matchedPeptides[0].pos[i] - 0, this.matchedPeptides[0].sequence.length, this.matchedPeptides[1].pos[j], this.matchedPeptides[1].sequence.length); - } - } - - //identify homodimers: if peptides overlap its a homodimer - this.confirmedHomomultimer = false; - this.overlap = []; - if (this.isAmbig() === false && p1ID === p2ID) { //todo: potential problem re ambiguous homo-multimer link (compare current behaviour to xiNET paper product type fig) - - if (this.matchedPeptides[0].sequence && this.matchedPeptides[1].sequence) { - - const pep1length = this.matchedPeptides[0].sequence.length; - const pep2length = this.matchedPeptides[1].sequence.length; - const pep1_start = +this.matchedPeptides[0].pos[0]; - const pep2_start = +this.matchedPeptides[1].pos[0]; - const pep1_end = pep1_start + (pep1length - 1); - const pep2_end = pep2_start + (pep2length - 1); - if (pep1_start >= pep2_start && pep1_start <= pep2_end) { - this.confirmedHomomultimer = true; - this.overlap[0] = pep1_start - 1; - if (pep1_end < pep2_end) { - this.overlap[1] = pep1_end; - } else { - this.overlap[1] = pep2_end; - } - } else if (pep2_start >= pep1_start && pep2_start <= pep1_end) { - this.confirmedHomomultimer = true; - this.overlap[0] = pep2_start - 1; - if (pep2_end < pep1_end) { - this.overlap[1] = pep2_end; - } else { - this.overlap[1] = pep1_end; - } - } - } else if (res1 === res2) { - this.confirmedHomomultimer = true; - this.overlap[0] = res1 - 1; - this.overlap[1] = res2; - } - } - } - - isNotCrosslinked() { - return this.linkPos1 === 0; - } - - isMonoLink() { - return false; - } - - runName() { - return this.identification.run; - } - - peakListFileName() { - return this.containingModel.get("peakListFiles").get(this.plf); - } - - group() { - return this.containingModel.get("searches").get(this.datasetId).group; - } - - expMZ() { - return this.precursorMZ; - } - - expMass() { - return this.precursorMZ * this.precursorCharge - (this.precursorCharge * Xi2SpectrumMatch.protonMass); - } - - calcMZ() { - return (this.calc_mass + (this.precursorCharge * Xi2SpectrumMatch.protonMass)) / this.precursorCharge; - } - - calcMass() { - return this.calc_mass; - } - - missingPeaks() { - const errorMZ = this.expMZ() - this.calcMZ(); - const errorM = errorMZ * this.precursorCharge; - //how many peaks assumed missing/miss-assigned - return Math.round(errorM / Xi2SpectrumMatch.C13_MASS_DIFFERENCE); - } - - massError() { - //old - //return ((this.expMass() - this.calcMass()) / this.calcMass()) * 1000000; - - // new - change needed due to some other change to do with missing peaks - // what is the error in m/z - const assumedMZ = this.expMZ() - this.missingPeaks() * Xi2SpectrumMatch.C13_MASS_DIFFERENCE / this.precursorCharge; - const errorMZ = assumedMZ - this.calcMZ(); - return errorMZ / this.calcMZ() * 1000000; - } - - ionTypes() { - const search = this.containingModel.get("searches").get(this.resultSetId); - let ionTypes = []; - ionTypes = ionTypes.concat(search.s_config.fragmentation.cterm_ions); - ionTypes = ionTypes.concat(search.s_config.fragmentation.nterm_ions); - return ionTypes; - } - - ionTypesString() { - const ions = this.ionTypes(); - let returnString = ""; - for (let i = 0; i < ions.length; i++) { - let ion = ions[i];//.type; - if (ion.indexOf("Ion") > 0) { - ion = ion.substring(0, ion.indexOf("Ion")); - } - returnString = returnString + ion.toLowerCase() + ";"; - } - return returnString; - } - - crosslinkerModMass() { - const crosslinker = this.getCrossLinker(); - if (crosslinker) { - return crosslinker.mass; - } else return 0; - } - - getCrossLinker() { - // if (this.crosslinker_id === -1) { - return null; - // } - // - // const searches = this.containingModel.get("searches"); - // const search = searches.get(this.searchId); - // const crosslinkers = search.crosslinkers; - // const clCount = crosslinkers.length; - // for (let c = 0; c < clCount; c++) { - // const crosslinker = crosslinkers[c]; - // if (crosslinker.id == this.crosslinker_id) { // yes, they're different types, don't === - // return crosslinker; - // } - // } - } - - fragmentTolerance() { - const search = this.containingModel.get("searches").get(this.resultSetId); - return { - "tolerance": search.ms2tolerance, - "unit": search.ms2toleranceunits - }; - } - - fragmentToleranceString() { - const search = this.containingModel.get("searches").get(this.resultSetId); - return search.ms2tolerance + " " + search.ms2toleranceunits; - } - - score() { - return this._score; - } - - experimentalMissedCleavageCount() { - const enzymeSpecificity = this.containingModel.get("enzymeSpecificity"); - - //yes... this should prob be done with regex - // (https://github.com/Rappsilber-Laboratory/xi3-issue-tracker/issues/401#issuecomment-495158293) - - function countMissedCleavages(peptide, linkPos) { - let count = 0; - const seqMods = peptide.seq_mods; - if (seqMods) { - const pepLen = seqMods.length; - - const indexOfLinkedAA = findIndexofNthUpperCaseLetter(seqMods, linkPos); - - for (let i = 0; i < pepLen; i++) { - for (let spec of enzymeSpecificity) { - if (seqMods[i] === spec.aa) { - if (i < pepLen) { - if (seqMods[i + 1] >= "A" && seqMods[i + 1] <= "Z") { - if (i !== indexOfLinkedAA) { - let postConstrained = false; - if (spec.postConstraint) { - for (let pc of spec.postConstraint) { - if (peptide.sequence[i + 1] === pc) { - postConstrained = true; - break; - } - } - } - if (!postConstrained) { - count++; - } - } - } - } - } - } - } - } - return count; - } - - function findIndexofNthUpperCaseLetter(str, n) { // n is 1-indexed here - let i = -1; - while (n > 0 && i < str.length) { - i++; - const c = str[i]; - if (c >= "A" && c <= "Z") n--; - } - return i === str.length ? undefined : i; - } - - const mc1 = countMissedCleavages(this.matchedPeptides[0], this.linkPos1); - if (this.matchedPeptides[1]) { - const mc2 = countMissedCleavages(this.matchedPeptides[1], this.linkPos2); - return Math.max(mc1, mc2); - } - return mc1; - } - - searchMissedCleavageCount() { - const enzymeSpecificity = this.containingModel.get("enzymeSpecificity"); - - function countSearchMissedCleavages(peptide) { - let count = 0; - const sequence = peptide.sequence; - const pepLen = sequence.length; - for (let i = 0; i < pepLen; i++) { - for (let spec of enzymeSpecificity) { - if (sequence[i] === spec.aa) { - if (i < (pepLen - 1)) { - count++; - } - } - } - } - return count; - } - - const mc1 = countSearchMissedCleavages(this.matchedPeptides[0]); - if (this.matchedPeptides[1]) { - const mc2 = countSearchMissedCleavages(this.matchedPeptides[1]); - return Math.max(mc1, mc2); - } - return mc1; - } - - modificationCount() { - function peptideModCount(peptide) { - let count = 0; - const sequence = peptide.seq_mods; - const pepLen = sequence.length; - for (let i = 0; i < pepLen - 1; i++) { - const a = sequence[i]; - const b = sequence[i + 1]; - if ((a >= "A" && a <= "Z") && (b < "A" || b > "Z")) count++; - } - return count; - } - - const modCount1 = peptideModCount(this.matchedPeptides[0]); - if (this.matchedPeptides[1]) { - const modCount2 = peptideModCount(this.matchedPeptides[1]); - if (modCount2 > modCount1) { - return modCount2; - } - } - return modCount1; - } - -// this.id = identification.id; -// this.spectrumId = identification.sp_id; -// this.searchId = identification.si.toString(); -// this.resultSetId = identification.rsi.toString(); -// this.crosslinker_id = identification.cl; -// -// // this.scanNumber = null;//+identificationes[0].sn; -// this.scanIndex = null;//+identificationes[0].sc_i; -// this.precursor_intensity = null;//+identificationes[0].pc_i; -// this.elution_time_start = null;//+identificationes[0].e_s; -// this.elution_time_end = null;//+identificationes[0].e_e; -// -// this.src = null;//+identificationes[0].src; //for looking up run name -// this.plf = null;//+identificationes[0].plf; //for looking up peak list file name -// //run name may have come from csv file -// -// this.precursorCharge = +identification.pc_c; -// if (this.precursorCharge === -1) { -// this.precursorCharge = undefined; -// } -// -// this.precursorMZ = +identification.pc_mz; -// this.calc_mass = +identification.cm; -// this._score = +identification.sc; - - get passThreshold() { - return true; - } - - get pepSeq1_mods() { - return this.matchedPeptides[0].seq_mods; - } - - get pepSeq2_mods() { - if (!this.matchedPeptides[1]) return undefined; - return this.matchedPeptides[1].seq_mods; - } - - get psmId() { - return this.identification.id; - } - - get datasetId() { - return this.resultSetId; - } - - get scanNumber() { - return this.identification.sn; - } -} - -Xi2SpectrumMatch.protonMass = 1.007276466879; -Xi2SpectrumMatch.C13_MASS_DIFFERENCE = 1.0033548; - - -/***/ }), - -/***/ "./CLMS-model/src/xi2-load-spectrum.js": -/*!*********************************************!*\ - !*** ./CLMS-model/src/xi2-load-spectrum.js ***! - \*********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ xi2LoadSpectrum: () => (/* binding */ xi2LoadSpectrum) -/* harmony export */ }); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! d3 */ "./node_modules/d3/d3.js"); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(d3__WEBPACK_IMPORTED_MODULE_0__); - - -const xi2LoadSpectrum = function (match) { - - const formatted_data = {}; - - formatted_data.sequence1 = match.matchedPeptides[0].seq_mods; - formatted_data.base_sequence1 = match.matchedPeptides[0].sequence; - formatted_data.mod_ids1 = match.matchedPeptides[0].mod_ids; - formatted_data.mod_pos1 = match.matchedPeptides[0].mod_pos; - formatted_data.linkPos1 = match.linkPos1 - 1; - if (match.matchedPeptides[1]) { - formatted_data.sequence2 = match.matchedPeptides[1].seq_mods; - formatted_data.base_sequence2 = match.matchedPeptides[1].sequence; - formatted_data.mod_ids2 = match.matchedPeptides[1].mod_ids; - formatted_data.mod_pos2 = match.matchedPeptides[1].mod_pos; - formatted_data.linkPos2 = match.linkPos2 - 1; - } - formatted_data.precursorCharge = match.precursorCharge; - formatted_data.config = window.compositeModelInst.get("clmsModel").get("searches").get(match.datasetId).s_config; - formatted_data.crosslinkerID = match.crosslinker_id; - formatted_data.precursorMZ = match.expMZ(); - formatted_data.requestID = match.id; - formatted_data.spectrum_title = "PSMID: " + match.id; - - console.log("xi2LoadSpectrum match:" + match.id); - - d3__WEBPACK_IMPORTED_MODULE_0___default().text(window.peakListUrl + "?uuid=" + match.spectrumId, function (error, text) { - if (error) { - console.log("error getting peak list", error); - } else { - if (text === "false") { - const xiVersion = window.compositeModelInst.get("clmsModel").get("searches").get(match.searchId).version; - const message = "Missing peak list for spectrum " + match.spectrumId + ". xiSearch v" + xiVersion; - alert(message); - // ToDo: clear (following doesn't work: window.compositeModelInst.get("xispec_wrapper").setData({}); - } else { - d3__WEBPACK_IMPORTED_MODULE_0___default().select("#range-error").text(""); - const rawPeaks = JSON.parse(text); - const intensity = rawPeaks[0]; - const mz = rawPeaks[1]; - const peakList = []; - const peakCount = intensity.length; - for (let i = 0; i < peakCount; i++){ - peakList.push([mz[i], intensity[i]]); - } - formatted_data.peakList = peakList; - console.log(formatted_data); - window.compositeModelInst.get("xispec_wrapper").setData(formatted_data); - } - } - }); - -}; - - -/***/ }), - -/***/ "./crosslink-viewer/js/views/xinet/crosslink-viewer-BB.js": -/*!****************************************************************!*\ - !*** ./crosslink-viewer/js/views/xinet/crosslink-viewer-BB.js ***! - \****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ CrosslinkViewer: () => (/* binding */ CrosslinkViewer) -/* harmony export */ }); -/* harmony import */ var _css_xiNET_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../../css/xiNET.css */ "./crosslink-viewer/css/xiNET.css"); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! d3 */ "./node_modules/d3/d3.js"); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(d3__WEBPACK_IMPORTED_MODULE_1__); -/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); -/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_2__); -/* harmony import */ var _vendor_cola__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../../vendor/cola */ "./crosslink-viewer/vendor/cola.js"); -/* harmony import */ var _vendor_cola__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_vendor_cola__WEBPACK_IMPORTED_MODULE_3__); -/* harmony import */ var _xiview_js_svgexp__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../../../xiview/js/svgexp */ "./xiview/js/svgexp.js"); -/* harmony import */ var _xiview_js_utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../../../xiview/js/utils */ "./xiview/js/utils.js"); -/* harmony import */ var _xiview_js_downloads__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../../../xiview/js/downloads */ "./xiview/js/downloads.js"); -/* harmony import */ var _interactor_rendered_protein__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./interactor/rendered-protein */ "./crosslink-viewer/js/views/xinet/interactor/rendered-protein.js"); -/* harmony import */ var _link_rendered_crosslink__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./link/rendered-crosslink */ "./crosslink-viewer/js/views/xinet/link/rendered-crosslink.js"); -/* harmony import */ var _interactor_group__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./interactor/group */ "./crosslink-viewer/js/views/xinet/interactor/group.js"); -/* harmony import */ var _link_p_p_link__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./link/p_p-link */ "./crosslink-viewer/js/views/xinet/link/p_p-link.js"); -/* harmony import */ var _link_g_g_link__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./link/g_g-link */ "./crosslink-viewer/js/views/xinet/link/g_g-link.js"); -/* harmony import */ var _xiview_js_model_color_protein_color_model__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ../../../../xiview/js/model/color/protein-color-model */ "./xiview/js/model/color/protein-color-model.js"); - - - -// import * as _ from "underscore"; - - - - - - - - - - - - - - -class CrosslinkViewer extends (backbone__WEBPACK_IMPORTED_MODULE_2___default().View) { - - // constructor(attributes, options) { - // super(_.extend(attributes, { - // events: { - // } - // }), options); - // } - - initialize() { - // this.debug = true; - this.fixedSize = this.model.get("xinetFixedSize"); - this.cropLabels = this.model.get("xinetCropLabels"); - const self = this; - - function newCustomContextMenuSel(outerDivClass) { - const contextMenuSel = d3__WEBPACK_IMPORTED_MODULE_1__.select(self.el) - .append("div").classed("custom-menu-margin", true) - .classed(outerDivClass, true); - const menuUL = contextMenuSel.append("div").classed("custom-menu", true) - .append("ul"); - contextMenuSel.node().onmouseover = function () { - // self.contextMenuParticipant.highlighted = true; // todo - look at - change hidden proteins in model - self.model.setHighlightedProteins(self.contextMenuParticipant.proteins); - }; - contextMenuSel.node().onmouseout = function (evt) { - let e = evt.toElement || evt.relatedTarget; - do { - if (e === this) return; - if (e) e = e.parentNode; // seems like tab changing when uniprot opens can cause e to become null - } while (e); - if (self.contextMenuParticipant){ - self.model.setHighlightedProteins([]); // todo - look at - } - self.contextMenuParticipant = null; - d3__WEBPACK_IMPORTED_MODULE_1__.select(this).style("display", "none"); - }; - return menuUL; - } - - this.contextMenuUlSel = newCustomContextMenuSel("xinet-context-menu"); - //create SVG element - this.svgElement = d3__WEBPACK_IMPORTED_MODULE_1__.select(this.el).append("div").style("height", "100%").append("svg").node(); //document.createElementNS(CrosslinkViewer.svgns, "svg"); - this.svgElement.setAttribute("width", "100%"); - this.svgElement.setAttribute("height", "100%"); - this.svgElement.setAttribute("style", "pointer-events:visible"); - //add listeners - - this.svgElement.onmousedown = function (evt) { - self.mouseDown(evt); - }; - this.svgElement.onmousemove = function (evt) { - self.mouseMove(evt); - }; - this.svgElement.onmouseup = function (evt) { - self.mouseUp(evt); - }; - - this.el.oncontextmenu = function (evt) { - if (evt.preventDefault) { // necessary for addEventListener, works with traditional - evt.preventDefault(); - } - evt.returnValue = false; // necessary for attachEvent, works with traditional - return false; // works with traditional, not with attachEvent or addEventListener - }; - - const mouseWheelEvt = (/Firefox/i.test(navigator.userAgent)) ? "DOMMouseScroll" : "mousewheel"; //FF doesn't recognize mousewheel as of FF3.x - this.svgElement.addEventListener(mouseWheelEvt, function (evt) { - self.mouseWheel(evt); - }, false); - - this.lastMouseUp = new Date().getTime(); - - // various SVG groups needed - this.wrapper = document.createElementNS(CrosslinkViewer.svgns, "g"); //in effect, a hack for fact firefox doesn't support getCTM on svgElement - const identM = this.svgElement.createSVGMatrix(); - const s = "matrix(" + identM.a + "," + identM.b + "," + identM.c + "," + identM.d + "," + identM.e + "," + identM.f + ")"; - this.wrapper.setAttribute("transform", s); - this.container = document.createElementNS(CrosslinkViewer.svgns, "g"); - this.container.setAttribute("id", "container"); - this.wrapper.appendChild(this.container); - - this.groupsSVG = document.createElementNS(CrosslinkViewer.svgns, "g"); - this.groupsSVG.setAttribute("id", "groupsSVG"); - this.container.appendChild(this.groupsSVG); - - this.p_pLinksWide = document.createElementNS(CrosslinkViewer.svgns, "g"); - this.p_pLinksWide.setAttribute("id", "p_pLinksWide"); - this.container.appendChild(this.p_pLinksWide); - - this.proteinLower = document.createElementNS(CrosslinkViewer.svgns, "g"); - this.proteinLower.setAttribute("id", "proteinLower"); - this.container.appendChild(this.proteinLower); - - this.highlights = document.createElementNS(CrosslinkViewer.svgns, "g"); - this.highlights.setAttribute("class", "highlights"); //proteins also contain highlight groups - this.container.appendChild(this.highlights); - - this.res_resLinks = document.createElementNS(CrosslinkViewer.svgns, "g"); - this.res_resLinks.setAttribute("id", "res_resLinks"); - this.container.appendChild(this.res_resLinks); - - this.p_pLinks = document.createElementNS(CrosslinkViewer.svgns, "g"); - this.p_pLinks.setAttribute("id", "p_pLinks"); - this.container.appendChild(this.p_pLinks); - - this.proteinUpper = document.createElementNS(CrosslinkViewer.svgns, "g"); - this.proteinUpper.setAttribute("id", "proteinUpper"); - this.container.appendChild(this.proteinUpper); - - this.svgElement.appendChild(this.wrapper); - - // this.debugRectSel = d3.select(this.proteinUpper).append("rect").attr("stroke", "green").attr("fill", "none").style("pointer-events", "none"); - // this.debugRectSel2 = d3.select(this.proteinUpper).append("rect").attr("stroke", "blue").attr("fill", "none").style("pointer-events", "none"); - - //is a d3 selection unlike those above - this.selectionRectSel = d3__WEBPACK_IMPORTED_MODULE_1__.select(this.svgElement).append("rect") - .attr("x", 10) - .attr("y", 10) - .attr("width", 50) - .attr("height", 100) - .attr("stroke", "red") - .attr("stroke-dasharray", "4,4") - .attr("stroke-dashoffset", "32") - .style("animation", "dash 2s linear infinite") - .attr("fill", "none") - .attr("display", "none"); - - this.d3cola = _vendor_cola__WEBPACK_IMPORTED_MODULE_3__.d3adaptor() - .groupCompactness(1e-5) - .avoidOverlaps(true); - - this.dragElement = null; - this.dragStart = null; - - this.renderedProteins = new Map(); - this.renderedCrosslinks = new Map(); - this.renderedP_PLinks = new Map(); - // all xiNET.Groups in play - this.groupMap = new Map(); - this.g_gLinks = new Map(); - this.toSelect = []; // used by right click drag - this.z = 1; - this.container.setAttribute("transform", "scale(1)"); - this.state = CrosslinkViewer.STATES.MOUSE_UP; - - this.firstRender = true; - - // calculate default bar scale - let maxSeqLength = 0; - for (let participant of this.model.get("clmsModel").get("participants").values()) { - if (participant.is_decoy === false && this.renderedProteins.has(participant.id) === false) { - const newProtien = new _interactor_rendered_protein__WEBPACK_IMPORTED_MODULE_7__.RenderedProtein(participant, this); - this.renderedProteins.set(participant.id, newProtien); - - const protSize = participant.size; - if (protSize > maxSeqLength) { - maxSeqLength = protSize; - } - } - } - const width = this.svgElement.parentNode.clientWidth; - const defaultPixPerRes = ((width * 0.8) - _interactor_rendered_protein__WEBPACK_IMPORTED_MODULE_7__.RenderedProtein.LABELMAXLENGTH) / maxSeqLength; - - // https://stackoverflow.com/questions/12141150/from-list-of-integers-get-number-closest-to-a-given-value/12141511#12141511 - function takeClosest(myList, myNumber) { - const bisect = d3__WEBPACK_IMPORTED_MODULE_1__.bisector(function (d) { - return d; - }).left; - const pos = bisect(myList, myNumber); - if (pos === 0 || pos === 1) { - return myList[1]; // don't return smallest scale as default - } - if (pos === myList.length) { - return myList[myList.length - 1]; - } - return myList[pos - 1]; - } - - this.defaultBarScale = takeClosest(CrosslinkViewer.barScales, defaultPixPerRes); - - const expand = this.renderedProteins.size < 4; - for (let rp of this.renderedProteins.values()) { - //to do - should this really be here - this.proteinLower.appendChild(rp.lowerGroup); - this.proteinUpper.appendChild(rp.upperGroup); - if (!rp.stickZoom) { - rp.stickZoom = this.defaultBarScale; - } - rp.scale(); - // rp.width;// cause it to store a constant value for unexpanded width? - if (expand) { - rp.toStickNoTransition(); - } - } - - for (let crosslink of this.model.get("clmsModel").get("crosslinks").values()) { - if (!crosslink.isDecoyLink() && !crosslink.isLinearLink()) { - if (!this.renderedCrosslinks.has(crosslink.id)) { - const renderedCrossLink = new _link_rendered_crosslink__WEBPACK_IMPORTED_MODULE_8__.RenderedCrosslink(crosslink, this); - this.renderedCrosslinks.set(crosslink.id, renderedCrossLink); - const toId = crosslink.toProtein ? crosslink.toProtein.id : "null"; - const p_pId = crosslink.fromProtein.id + "-" + toId; - let p_pLink = this.renderedP_PLinks.get(p_pId); - if (typeof p_pLink == "undefined") { - p_pLink = new _link_p_p_link__WEBPACK_IMPORTED_MODULE_10__.P_PLink(p_pId, crosslink, this); - this.renderedP_PLinks.set(p_pId, p_pLink); - } - p_pLink.crosslinks.push(crosslink); - - crosslink.p_pLink = p_pLink; - } - } - } - - this.listenTo(this.model, "filteringDone", this.render); - this.listenTo(this.model, "hiddenChanged", this.hiddenProteinsChanged); - this.listenTo(this.model, "change:groups", this.groupsChanged); - this.listenTo(this.model, "change:highlights", this.highlightedLinksChanged); - this.listenTo(this.model, "change:selection", this.selectedLinksChanged); - - this.listenTo(this.model, "change:linkColourAssignment currentColourModelChanged", this.render); - this.listenTo(this.model, "change:proteinColourAssignment currentProteinColourModelChanged", this.proteinColoursUpdated); - - this.listenTo(this.model.get("annotationTypes"), "change:shown", this.setAnnotations); - this.listenTo(this.model.get("alignColl"), "bulkAlignChange", this.setAnnotations); - this.listenTo(this.model, "change:selectedProteins", this.selectedProteinsChanged); - this.listenTo(this.model, "change:highlightedProteins", this.highlightedProteinsChanged); - - this.listenTo(window.vent, "proteinMetadataUpdated", this.proteinMetadataUpdated); - - this.listenTo(window.vent, "xinetSvgDownload", this.downloadSVG); - this.listenTo(window.vent, "xinetAutoLayout", this.autoLayout); - this.listenTo(window.vent, "xinetLoadLayout", this.loadLayout); - this.listenTo(window.vent, "xinetSaveLayout", this.saveLayout); - - this.listenTo(window.vent, "collapseGroups", this.collapseGroups); - this.listenTo(window.vent, "expandGroups", this.expandGroups); - - this.listenTo(this.model, "change:xinetShowLabels", this.showLabels); - this.listenTo(this.model, "change:xinetFixedSize", this.setFixedSize); - this.listenTo(this.model, "change:xinetCropLabels", this.setCropLabels); - this.listenTo(this.model, "change:xinetThickLinks", this.render); - this.listenTo(this.model, "change:xinetPpiSteps", this.render); - - return this; - } - - expandProtein() { - d3__WEBPACK_IMPORTED_MODULE_1__.select(".xinet-context-menu").style("display", "none"); - this.contextMenuParticipant.setExpanded(true); - this.render(); - this.contextMenuParticipant = null; - } - - collapseInteractor() { - d3__WEBPACK_IMPORTED_MODULE_1__.select(".xinet-context-menu").style("display", "none"); - this.model.setHighlightedProteins([]); - this.contextMenuParticipant.setExpanded(false, this.contextMenuPoint); - // if (this.contextMenuParticipant.type === "group") { - // this.render(); - // } - //this.hiddenProteinsChanged(); //REINSTATE? - //this.render(); - this.contextMenuParticipant = null; - } - - cantCollapseGroup() { - // d3.select(".custom-menu-margin").style("display", "none"); - // d3.select(".group-custom-menu-margin").style("display", "none"); - } - - ungroup() { - d3__WEBPACK_IMPORTED_MODULE_1__.select(".xinet-context-menu").style("display", "none"); - this.model.setHighlightedProteins([]); - this.model.get("groups").delete(this.contextMenuParticipant.id); - this.model.trigger("change:groups"); - this.contextMenuParticipant = null; - } - - collapseGroups() { - for (let group of this.groupMap.values()) { - if (group.expanded === true && !group.isOverlappingGroup()) { - // group.setExpanded(false); - group.collapse(null, false); - } - } - this.hiddenProteinsChanged(); - this.render(); - } - - expandGroups() { - for (let group of this.groupMap.values()) { - if (group.expanded === false) { - // group.setExpanded(true); - group.expand(false);// todo: reanme this to expandNoTransition - } - } - this.hiddenProteinsChanged(); - this.render(); - } - - groupsChanged() { - console.log("xiNET GROUPS CHANGED"); - this.d3cola.stop(); - - // a Map with group id as key and Set of protein ids to group as value - const modelGroups = this.model.get("groups"); - - //clear out old groups -- https://stackoverflow.com/questions/9882284/looping-through-array-and-removing-items-without-breaking-for-loop - const groupIdsToRemove = []; - for (let group of this.groupMap.values()) { - if (!modelGroups.has(group.id)) { - groupIdsToRemove.push(group.id); - - group.parentGroups = new Set();//[]; //don't think necessary but just in case - group.subroups = []; - for (let rp of group.renderedParticipants) { - rp.parentGroups.delete(group); - } - - if (group.expanded) { - this.groupsSVG.removeChild(group.upperGroup); - } else { - this.proteinUpper.removeChild(group.upperGroup); - } - } - } - for (let rgId of groupIdsToRemove) { - this.groupMap.delete(rgId); - } - - for (let g of modelGroups.entries()) { - if (!this.groupMap.has(g[0])) { //if group doesn't exist - const group = new _interactor_group__WEBPACK_IMPORTED_MODULE_9__.Group(g[0], g[1], this); - group.init(); - this.groupMap.set(group.id, group); - } else { // group already exists but the proteins in it may have changed - const group = this.groupMap.get(g[0]); - group.renderedParticipants = []; - for (let pId of g[1]) { - const p = this.renderedProteins.get(pId); - if (p) { // no decoys in this.renderedProteins - group.renderedParticipants.push(this.renderedProteins.get(pId)); - } - } - } - } - this.scale();//just to update groups selection highlights - this.hiddenProteinsChanged(); - this.render(); - } - - // handle changes to manually hidden proteins, - // but also deal with stuff to do with groups / group hierarchy - // specifically subgroups could change as result of things being hidden so this is here - // (i.e. overlapping group becomes subgroup) - hiddenProteinsChanged() { - console.log("xiNET HIDDEN PROTEINS CHANGED"); - this.d3cola.stop(); - - //clear parent groups of all proteins - for (let rp of this.renderedProteins.values()) { - rp.parentGroups = new Set();//[]; - } - - // parent groups may change, so clear groups - for (let g of this.groupMap.values()) { - g.subgroups = []; // subgroups as xiNET.Groups - g.parentGroups = new Set(); - g.leaves = []; // different from g.renderedParticipants coz only contains ungrouped RenderedProteins, used by cola.js - g.groups = []; // indexes of subgroups in resulting groupArr, used by cola.js // needed? prob not coz groups already referred to by index - - for (let rp of g.renderedParticipants) { - rp.parentGroups.delete(g); // sometimes it won't have contained g as parentGroup - } - } - - //sort it by count not hidden (not manually hidden and not filtered) - const sortedGroupMap = new Map([...this.groupMap.entries()].sort((a, b) => a[1].unhiddenParticipantCount - b[1].unhiddenParticipantCount)); - - // get maximal set of possible subgroups - const groups = Array.from(sortedGroupMap.values()); - const gCount = groups.length; // contains xiNET.Groups - for (let gi = 0; gi < gCount - 1; gi++) { - const group1 = groups[gi]; - if (group1.unhiddenParticipantCount > 0) { - for (let gj = gi + 1; gj < gCount; gj++) { - const group2 = groups[gj]; - if (group1.isSubsetOf(group2)) { - group2.subgroups.push(group1); - console.log(group1.name, "is SUBSET of", group2.name); - } - } - } - } - - for (let g of groups) { - for (let rp of g.renderedParticipants) { - rp.parentGroups.add(g); - } - } - - //sort out parentGroups - for (let group1 of groups.reverse()) { - if (group1.upperGroup.parentNode) { - // z-ordering (?) - const pn = group1.upperGroup.parentNode; - pn.removeChild(group1.upperGroup); - pn.appendChild(group1.upperGroup); - } - for (let group2 of group1.subgroups) { - group2.parentGroups.add(group1); - } - } - - let manuallyHidden = 0; - for (let renderedParticipant of this.renderedProteins.values()) { - if (renderedParticipant.participant.manuallyHidden === true) { - manuallyHidden++; - } - if (renderedParticipant.inCollapsedGroup() === false) { - renderedParticipant.setHidden(renderedParticipant.participant.hidden); - } else { - renderedParticipant.setHidden(true); - } - } - - if (manuallyHidden === 0) { - d3__WEBPACK_IMPORTED_MODULE_1__.select("#hiddenProteinsMessage").style("display", "none"); - } else { - const pSel = d3__WEBPACK_IMPORTED_MODULE_1__.select("#hiddenProteinsText"); - pSel.text((manuallyHidden > 1) ? (manuallyHidden + " Hidden Proteins") : (manuallyHidden + " Hidden Protein")); - const messageSel = d3__WEBPACK_IMPORTED_MODULE_1__.select("#hiddenProteinsMessage"); - messageSel.style("display", "block"); - } - - - for (let group of groups) { - if (!group.expanded && group.isOverlappingGroup()) { - group.setExpanded(true); - } - } - for (let group of groups) { - let hasVisible = false; - for (let p of group.renderedParticipants) { - if (p.participant.hidden === false) { - hasVisible = true; - } - } - if (!hasVisible || group.inCollapsedGroup()) { - group.setHidden(true); - } else { - group.setHidden(false); - group.updateCountLabel(); - if (group.expanded) { - group.updateExpandedGroup(); - } else { - group.setPosition(group.ix, group.iy); - } - } - } - - /* - this.subgraphs = []; - - for (let interactor of this.renderedProteins.values()) { - interactor.subgraph = null; - } - for (let interactor of this.groupMap.values()) { - interactor.subgraph = null; - } - - for (let interactor of this.renderedProteins.values()) { - if (!interactor.hidden) { - interactor.getSubgraph();//adds new subgraphs to this.subgraphs - } - } - for (let interactor of this.groupMap.values()) { - if (!interactor.hidden) { - interactor.getSubgraph();//adds new subgraphs to this.subgraphs - } - } - - this.subgraphs.sort(function (a, b) { - return b.nodes.size - a.nodes.size; - }); - - - //Sort subgraphs into linear and non-linear sets - this.linearGraphs = []; - this.nonLinearGraphs = []; - for (let graph of this.subgraphs) { - // const nodes = graph.nodes.values(); - const nodeCount = graph.nodes.size; - let isLinear = true; - if (nodeCount === 1) { - isLinear = true; - } else { - var endFound = false; - for (let node of graph.nodes.values()) { - const externalLinkCount = node.countExternalLinks(); - // console.log("ELC*: " + externalLinkCount); - if (node.expanded === true) { - isLinear = false; - break; - } - if (externalLinkCount > 2) { - isLinear = false; - break; - } else if (externalLinkCount < 2) { - endFound = true; - } - } - //check not circular - if (!endFound) { - isLinear = false; - } - } - if (isLinear === true) { - this.linearGraphs.push(graph); - } else { - this.nonLinearGraphs.push(graph); - } - }*/ - - return this; - } - - render() { - console.log("xiNET RENDER"); - this.d3cola.stop(); - if (this.firstRender) { // first render - this.firstRender = false; - if (this.model.get("clmsModel").get("xiNETLayout")) { - this.loadLayout(this.model.get("clmsModel").get("xiNETLayout").layout); - } else { - this.autoLayout([]); //layout all - } - } - - for (let ppLink of this.renderedP_PLinks.values()) { - - - ppLink.hd = false; - const filteredCrossLinks = new Set(); - const filteredMatches = new Set(); - const altP_PLinks = new Set(); - for (let crosslink of ppLink.crosslinks) { - if (crosslink.filteredMatches_pp.length > 0) { - filteredCrossLinks.add(crosslink.id); - for (let m of crosslink.filteredMatches_pp) { - const match = m.match; // oh dear, this... - filteredMatches.add(match.id); - if (match.hd === true) { - ppLink.hd = true; - } - if (match.crosslinks.length > 1) { - for (let matchCrossLink of match.crosslinks) { - if (!matchCrossLink.isDecoyLink()) { - altP_PLinks.add(matchCrossLink.p_pLink.id); - } - } - } - } - } - } - ppLink.filteredMatchCount = filteredMatches.size; - ppLink.filteredCrossLinkCount = filteredCrossLinks.size; - ppLink.ambiguous = altP_PLinks.size > 1; - - if (!ppLink.renderedToProtein || // not linear - //or either end hidden - ppLink.renderedFromProtein.participant.hidden || - ppLink.renderedToProtein.participant.hidden) { - ppLink.hide(); - } else { - const fromProtInCollapsedGroup = ppLink.renderedFromProtein.inCollapsedGroup(); - const toProtInCollapsedGroup = ppLink.renderedToProtein.inCollapsedGroup(); - - // if (// or is self link in collapsed group - // (ppLink.crosslinks[0].isSelfLink() && fromProtInCollapsedGroup) || - // // or either end is expanded to bar and not in collapsed group - // (ppLink.renderedFromProtein.expanded && !fromProtInCollapsedGroup) || - // (ppLink.renderedToProtein.expanded && !toProtInCollapsedGroup) || - // (fromProtInCollapsedGroup && toProtInCollapsedGroup) - // ) { - // ppLink.hide(); - // } - // else { - if (ppLink.filteredCrossLinkCount === 0) { - ppLink.hide(); - } else { - ppLink.ambiguous = altP_PLinks.size > 1; - if (fromProtInCollapsedGroup && toProtInCollapsedGroup) { - const source = ppLink.renderedFromProtein.getRenderedInteractor(); - const target = ppLink.renderedToProtein.getRenderedInteractor(); - let ggId; - if (source.id < target.id) { - ggId = source.id + "_" + target.id; - } else { - ggId = target.id + "_" + source.id; - } - let ggLink = ppLink.controller.g_gLinks.get(ggId); - if (!ggLink) { - if (source.id < target.id) { - ggLink = new _link_g_g_link__WEBPACK_IMPORTED_MODULE_11__.G_GLink(ggId, source, target, this); - } else { - ggLink = new _link_g_g_link__WEBPACK_IMPORTED_MODULE_11__.G_GLink(ggId, target, source, this); - } - this.g_gLinks.set(ggId, ggLink); - } - ggLink.p_pLinks.set(ppLink.id, ppLink); - ppLink.hide(); - } else { - // ppLink.show(); - if (// or is self link in collapsed group - (ppLink.crosslinks[0].isSelfLink() && fromProtInCollapsedGroup) || - // or either end is expanded to bar and not in collapsed group - (ppLink.renderedFromProtein.expanded && !fromProtInCollapsedGroup) || - (ppLink.renderedToProtein.expanded && !toProtInCollapsedGroup) || - (fromProtInCollapsedGroup && toProtInCollapsedGroup) - ) { - ppLink.hide(); - } else { - ppLink.show(); - } - } - } - // } - } - } - for (let cLink of this.renderedCrosslinks.values()) { - cLink.check(); - } - const ggLinkIdsToRemove = []; - for (let ggLink of this.g_gLinks.values()) { - if ( //true - ggLink.group1.expanded === false && ggLink.group2.expanded === false - && ggLink.check() - && this.groupMap.has(ggLink.group1.id) && this.groupMap.has(ggLink.group2.id) - && !(ggLink.group1.inCollapsedGroup() || ggLink.group2.inCollapsedGroup()) - ) { - ggLink.show(); - //set line coord? - } else { - ggLinkIdsToRemove.push(ggLink.id); - ggLink.hide(); - } - } - for (let id of ggLinkIdsToRemove) { - this.g_gLinks.delete(id); - } - } - - autoLayoutGroup(group, fixedParticipants) { - console.log("xiNET AUTO LAYOUT SINGLE GROUP"); - this.d3cola.stop(); - - const linkLength = (this.renderedProteins.size < 20) ? 40 : 20; - const width = this.svgElement.parentNode.clientWidth; - const height = this.svgElement.parentNode.clientHeight; - - for (let renderedProtein of this.renderedProteins.values()) { - if (fixedParticipants.length === 0) { - delete renderedProtein.x; - delete renderedProtein.y; - delete renderedProtein.px; - delete renderedProtein.py; - } - renderedProtein.fixed = fixedParticipants.indexOf(renderedProtein.participant) !== -1; - delete renderedProtein.index; - } - for (let g of this.groupMap.values()) { - if (fixedParticipants.length === 0) { // todo - some issues here (select a collapsed group and select fixed selected) - delete g.x; - delete g.y; - delete g.px; - delete g.py; - } - delete g.index; - delete g.parent; - g.leaves = []; // clear this, it's used by cola, gets filled by auto - } - - this.d3cola.size([height - /*layoutXOffset -*/ 40, width - 40]).symmetricDiffLinkLengths(linkLength); - - const self = this; - - const links = new Map(); - const nodeSet = new Set(); - for (let crosslink of self.model.getFilteredCrossLinks()) { - // for (let graph of this.nonLinearGraphs) { - // for (let link of graph.links.values()) { - if (crosslink.toProtein) { // not linears - // if (link.crosslinks[0].isSelfLink() === false) { - const source = self.renderedProteins.get(crosslink.fromProtein.id).getRenderedInteractor(); - const target = self.renderedProteins.get(crosslink.toProtein.id).getRenderedInteractor(); - if (group.renderedParticipants.indexOf(source) !== -1 || group.renderedParticipants.indexOf(target) !== -1) { - nodeSet.add(source); - const fromId = crosslink.fromProtein.id; - const toId = crosslink.toProtein.id; - const linkId = fromId + "-" + toId; - if (!links.has(linkId)) { - const linkObj = {}; - // todo - maybe do use indexes, might avoid probs in cola - linkObj.source = source; - linkObj.target = target; - nodeSet.add(target); // bit weird doing ths here - linkObj.id = linkId; - links.set(linkId, linkObj); - } - } - } - } - - const nodeArr = Array.from(nodeSet); - const linkArr = Array.from(links.values()); - doLayout(nodeArr, linkArr); - - function doLayout(nodes, links) { - //don't know how necessary these deletions are - delete self.d3cola._lastStress; - delete self.d3cola._alpha; - delete self.d3cola._descent; - delete self.d3cola._rootGroup; - - const groups = []; - if (self.groupMap) { - for (let g of self.groupMap.values()) { - delete g.index; - if (!g.hidden && g.expanded) { - g.groups = []; - // put any rp not contained in a subgroup in group1.leaves - for (let rp of g.renderedParticipants) { - if (!rp.hidden) { - let inSubGroup = false; - for (let subgroup of g.subgroups) { - if (subgroup.contains(rp)) { - inSubGroup = true; - break; - } - } - if (!inSubGroup) { - g.leaves.push(nodes.indexOf(rp)); - } - } - } - groups.push(g); - } - } - //need to use indexes of groups - for (let g of groups) { - console.log("GROUP ", g.unhiddenParticipantCount, g.id); - for (let i = 0; i < g.subgroups.length; i++) { - console.log("\tSUBGROUP ", g.subgroups[i].unhiddenParticipantCount, g.subgroups[i].id); - if (!g.subgroups[i].hidden) { - // todo - this is where you need to sort out issue of nested subgroups... - // the problem is when the same subgroup gets added to multiple parent groups - // the following seems to be working but not convinced it's totally reliable (depends on order groups end up in?) - let isSubset = false; - for (let j = i + 1; j < g.subgroups.length; j++) { - if (g.subgroups[i].isSubsetOf(g.subgroups[j])) { - isSubset = true; - break; - } - } - if (!isSubset) { - if (g.subgroups[i].expanded) { - g.groups.push(groups.indexOf(g.subgroups[i])); - - } else { - g.leaves.push(g.subgroups[i]); - } - } - } - } - } - } - - const cmp = self.contextMenuPoint; - - self.d3cola.nodes(nodes).groups(groups).links(links).start(23, 10, 1, 0, true).on("tick", function () { //.start(23, 10, 1, 0, true) - for (let node of self.d3cola.nodes()) { - node.setPositionFromXinet((node.x * self.z) - ((width/2 * self.z)) + cmp.x, - (node.y * self.z) - ((height/2 * self.z)) + cmp.y); - // node.setPositionFromXinet((node.x * self.z) - ((cmp.x - (width/2)) * self.z), - // (node.y * self.z) - ((cmp.y - (width/2)) * self.z) + 30); - // // node.setPositionFromCola(); - node.setAllLinkCoordinates(); - } - for (let g of self.d3cola.groups()) { // todo - seems a bit of a weird way to have done this? - if (g.expanded) { - g.updateExpandedGroup(); - } - } - }); - } - } - - autoLayout(fixedParticipants) { - console.log("xiNET AUTO LAYOUT"); - this.d3cola.stop(); - if (fixedParticipants.length === 0) { - this.container.setAttribute("transform", "scale(" + 1 + ")");// translate(" + ((width / scaleFactor) - bbox.width - bbox.x) + " " + -bbox.y + ")"); - this.scale(); - } - - const linkLength = (this.renderedProteins.size < 20) ? 40 : 20; - const width = this.svgElement.parentNode.clientWidth; - const height = this.svgElement.parentNode.clientHeight; - - /* const tempGroupMap = new Map (this.groupMap); - - //Grid layout linear graphs - var column = 0, row = 0; - if (this.linearGraphs.length > 0) { - column++; - for (let graph of this.linearGraphs) { - // todo - this is a right mess, fixing can wait til i'm back from holiday - var nodes = Array.from(graph.nodes.keys()); // - var nodeCount = nodes.length; - if (nodeCount > 2) { - nodes = this.reorderedNodes(graph); - } - nodeCount = nodes.length; - for (var n = 0; n < nodeCount; n++) { - var p = this.renderedProteins.get(nodes[n]); - if (!p) { - p = this.groupMap.get(nodes[n]); - tempGroupMap.delete(nodes[n]); - } - for (let pg of p.parentGroups.values()) { - tempGroupMap.delete(pg.id); - } - var x, y; - row++; - x = this.xForColumn(column); - y = this.yForRow(row); - var lastNodeY = this.yForRow(row + ((nodeCount - 1 - n) * 2)); - let lowerBound = height; - if (column < 4) { - lowerBound = lowerBound - 100; - } - if ((lastNodeY + 20) > lowerBound) { - column++; - row = 1; - x = this.xForColumn(column); - y = this.yForRow(row); - } - // console.log("??", p.id, column, row); - p.setPosition(x, y); - p.setAllLinkCoordinates(); - } - } - } - //remember edge of gridded proteins - const layoutXOffset = this.xForColumn(column + 1);*/ - - for (let renderedProtein of this.renderedProteins.values()) { - if (fixedParticipants.length === 0) { - delete renderedProtein.x; - delete renderedProtein.y; - delete renderedProtein.px; - delete renderedProtein.py; - } - renderedProtein.fixed = fixedParticipants.indexOf(renderedProtein.participant) !== -1; - delete renderedProtein.index; - } - for (let g of this.groupMap.values()) { - if (fixedParticipants.length === 0) { // todo - some issues here (select a collapsed group and select fixed selected) - delete g.x; - delete g.y; - delete g.px; - delete g.py; - } - delete g.index; - delete g.parent; - g.leaves = []; // clear this, it's used by cola, gets filled by auto - } - - this.d3cola.size([height - /*layoutXOffset -*/ 40, width - 40]).symmetricDiffLinkLengths(linkLength); - - const self = this; - - const links = new Map(); - const nodeSet = new Set(); - for (let crosslink of self.model.getFilteredCrossLinks()) { - // for (let graph of this.nonLinearGraphs) { - // for (let link of graph.links.values()) { - if (crosslink.toProtein) { // not linears - // if (link.crosslinks[0].isSelfLink() === false) { - const source = self.renderedProteins.get(crosslink.fromProtein.id).getRenderedInteractor(); - const target = self.renderedProteins.get(crosslink.toProtein.id).getRenderedInteractor(); - nodeSet.add(source); - const fromId = crosslink.fromProtein.id; - const toId = crosslink.toProtein.id; - const linkId = fromId + "-" + toId; - if (!links.has(linkId)) { - const linkObj = {}; - // todo - maybe do use indexes, might avoid probs in cola - linkObj.source = source; - linkObj.target = target; - nodeSet.add(target); // bit weird doing ths here - linkObj.id = linkId; - links.set(linkId, linkObj); - } - } - } - // } - const nodeArr = Array.from(nodeSet); - const linkArr = Array.from(links.values()); - doLayout(nodeArr, linkArr); - - function doLayout(nodes, links) { - //don't know how necessary these deletions are - delete self.d3cola._lastStress; - delete self.d3cola._alpha; - delete self.d3cola._descent; - delete self.d3cola._rootGroup; - - const groups = []; - if (self.groupMap) { - for (let g of self.groupMap.values()) { - delete g.index; - if (!g.hidden && g.expanded) { - g.groups = []; - // put any rp not contained in a subgroup in group1.leaves - for (let rp of g.renderedParticipants) { - if (!rp.hidden) { - let inSubGroup = false; - for (let subgroup of g.subgroups) { - if (subgroup.contains(rp)) { - inSubGroup = true; - break; - } - } - if (!inSubGroup) { - g.leaves.push(nodes.indexOf(rp)); - } - } - } - groups.push(g); - } - } - //need to use indexes of groups - for (let g of groups) { - console.log("GROUP ", g.unhiddenParticipantCount, g.id); - for (let i = 0; i < g.subgroups.length; i++) { - console.log("\tSUBGROUP ", g.subgroups[i].unhiddenParticipantCount, g.subgroups[i].id); - if (!g.subgroups[i].hidden) { - // todo - this is where you need to sort out issue of nested subgroups... - // the problem is when the same subgroup gets added to multiple parent groups - // the following seems to be working but not convinced it's totally reliable (depends on order groups end up in?) - let isSubset = false; - for (let j = i + 1; j < g.subgroups.length; j++) { - if (g.subgroups[i].isSubsetOf(g.subgroups[j])) { - isSubset = true; - break; - } - } - if (!isSubset) { - if (g.subgroups[i].expanded) { - g.groups.push(groups.indexOf(g.subgroups[i])); - - } else { - g.leaves.push(g.subgroups[i]); - } - } - } - } - } - } - let participantDebugSel, groupDebugSel; - if (self.debug) { - participantDebugSel = d3__WEBPACK_IMPORTED_MODULE_1__.select(self.groupsSVG).selectAll(".node") - .data(nodes); - participantDebugSel.enter().append("rect") - .classed("node", true) - .attr({ - rx: 5, - ry: 5 - }) - .style("stroke", "red") - .style("fill", "none") - .style("pointer-events", "none"); - groupDebugSel = d3__WEBPACK_IMPORTED_MODULE_1__.select(self.groupsSVG).selectAll(".group") - .data(groups); - groupDebugSel.enter().append("rect") - .classed("group", true) - .attr({ - rx: 5, - ry: 5 - }) - .style("stroke", "blue") - .style("fill", "none") - .style("pointer-events", "none"); - groupDebugSel.exit().remove(); - participantDebugSel.exit().remove(); - } - self.d3cola.nodes(nodes).groups(groups).links(links).start(23, 10, 1, 0, true).on("tick", function () { //.start(23, 10, 1, 0, true) - // let x1 = null, y1 = null, x2 = null, y2 = null; - // for (let node of self.d3cola.nodes()) { - // if (!x1 || node.x < x1) { - // x1 = node.x; - // } - // if (!y1 || node.y < y1) { - // y1 = node.y; - // } - // if (!x2 || node.x > x2) { - // x2 = node.x; - // } - // if (!y2 || node.y > y2) { - // y2 = node.y; - // } - // } - // - // let c = 0; - // let xr = (width - /*layoutXOffset -*/ 120) / (x2 - x1); - // let yr = ((height - 60) / (y2 - y1)); - - for (let node of self.d3cola.nodes()) { - // node.setPositionFromCola((node.x * xr) - (x1 * xr) /*+ layoutXOffset*/, - // (node.y * yr) - (y1 * yr) + 30); - node.setPositionFromCola(); - node.setAllLinkCoordinates(); - } - for (let g of self.d3cola.groups()) { // todo - seems a bit of a weird way to have done this? - if (g.expanded) { - g.updateExpandedGroup(); - } - } - if (fixedParticipants.length === 0) { - self.zoomToFullExtent(); - } - - if (self.debug) { - groupDebugSel.attr({ - x: function (d) { - return d.bounds.x; - }, - y: function (d) { - return d.bounds.y; - }, - width: function (d) { - return d.bounds.width(); - }, - height: function (d) { - return d.bounds.height(); - } - }); - participantDebugSel.attr({ - x: function (d) { - return d.bounds.x; - }, - y: function (d) { - return d.bounds.y; - }, - width: function (d) { - return d.bounds.width(); - }, - height: function (d) { - return d.bounds.height(); - } - }); - } - }); - //} - } - } - - // //functions used... - // xForColumn(c) { - // const maxBlobRadius = 40; - // // var LABELMAXLENGTH = 0; - // // return (c * ((2 * maxBlobRadius) + LABELMAXLENGTH)) - maxBlobRadius; - // return c * maxBlobRadius - (maxBlobRadius / 2); - // } - // - // yForRow(r) { - // const maxBlobRadius = 50; - // return (r * maxBlobRadius) - 10; - // } - // - // reorderedNodes(linearGraph) { - // const reorderedNodes = []; - // appendNode(getStartNode(), new Set ()); - // return reorderedNodes; - // - // function getStartNode() { - // // var ns = Array.from(linearGraph.nodes.values()); - // // var count = ns.length; - // // // alert (nodeCount); - // // for (var n = 0; n < count; n++) { - // // if (ns[n].countExternalLinks() < 2) { - // // // alert("got start"); - // // return ns[n]; - // // } - // // } - // for (let node of linearGraph.nodes.values()) { - // if (node.countExternalLinks() < 2) { - // console.log("StartNode", node.id); - // return node; - // } - // } - // console.error("missed linear subgraph start"); - // return null; - // } - // - // function appendNode(currentNode, checkedNodes) { - // checkedNodes.add(currentNode.id); // yeah, wierdness, this all needs tidied up - // if (!currentNode.hidden) { - // reorderedNodes.push(currentNode.participant.id); - // } - // - // // var proteinLinksArr = Array.from(currentNode.renderedP_PLinks.values()); - // // for (var l = 0; l < proteinLinksArr.length; l++) { - // // var link = proteinLinksArr[l]; - // // if (link.isPassingFilter()) { - // // var nextNode = link.getOtherEnd(currentNode); - // // if (reorderedNodes.indexOf(nextNode.participant.id) === -1) { - // // // alert("here"); - // // appendNode(nextNode); - // // break; - // // } - // // } - // // } - // - // for (let link of currentNode.renderedP_PLinks.values()) { - // if (link.isPassingFilter()) { - // const nextNode = link.getOtherEnd(currentNode); - // if (!checkedNodes.has(nextNode.id)) { - // console.log("nextNode", nextNode.id); - // appendNode(nextNode, checkedNodes); - // break; - // } - // } - // } - // } - // } - - saveLayout(callback) { - const layout = {}; - const proteinColourModel = this.model.get("proteinColourAssignment"); - if (proteinColourModel instanceof _xiview_js_model_color_protein_color_model__WEBPACK_IMPORTED_MODULE_12__.ManualColourModel) { - layout.manualColourAssignment = JSON.stringify(Object.fromEntries(proteinColourModel.colourAssignment)); - } - layout.groups = Array.from(this.groupMap.values()); - layout.proteins = Array.from(this.renderedProteins.values()); - const myJSONText = JSON.stringify(layout, null); - console.log("SAVING", layout); - callback(myJSONText.replace(/\\u0000/gi, "")); - } - - //todo - this is becoming about config of all xiVIEw not just config of xiNET, should be moved - loadLayout(layout) { - console.log("xiNET LOAD LAYOUT", layout); - let proteinPositions, groups; - // for backwards compatibility (after groups added to layout) - if (layout.proteins) { - proteinPositions = layout.proteins; - groups = layout.groups; - } else { - proteinPositions = layout; - } - let namesChanged = false; - for (let protLayout of proteinPositions) { - const protein = this.renderedProteins.get(protLayout.id); - if (protein !== undefined) { - protein.setPositionFromXinet(protLayout["x"], protLayout["y"]); - if (typeof protLayout["rot"] !== "undefined") { - // noinspection PointlessArithmeticExpressionJS - protein.rotation = protLayout["rot"] - 0; - } - protein.ix = protLayout["x"]; - protein.iy = protLayout["y"]; - protein.newForm = protLayout["expanded"]; - if (CrosslinkViewer.barScales.indexOf(+protLayout["stickZoom"]) > -1) { - protein.stickZoom = protLayout["stickZoom"]; - } - // noinspection PointlessArithmeticExpressionJS - protein.rotation = protLayout["rot"] - 0; - protein.flipped = protLayout["flipped"]; - protein.participant.manuallyHidden = protLayout["manuallyHidden"]; - - if (protLayout["name"]) { - protein.participant.name = protLayout["name"]; - namesChanged = true; - } - - } - } - - for (let rp of this.renderedProteins.values()) { - rp.setEverything(); - } - - if (groups && typeof groups[Symbol.iterator] === "function") { - const modelGroupMap = new Map(); - for (const savedGroup of groups) { - //gonna need to check for proteins now missing from results - const presentProteins = new Set(); - - for (let pId of savedGroup.participantIds) { - if (this.renderedProteins.get(pId)) { - presentProteins.add(pId); - } - } - if (presentProteins.size === 0) { - // layoutIsDodgy = true; - // this prob happens as a result of revalidating data in lab version - console.log("! group in layout but no proteins in search:" + savedGroup.id + "; " + savedGroup.participantIds); - } else { - modelGroupMap.set(savedGroup.id, presentProteins); - } - } - this.model.set("groups", modelGroupMap); - this.model.trigger("change:groups"); - - for (const savedGroup of groups) { - const xiNetGroup = this.groupMap.get(savedGroup.id); - if (xiNetGroup && savedGroup.expanded === false) { - xiNetGroup.collapse(null, false); - xiNetGroup.setPositionFromXinet(savedGroup.x, savedGroup.y); - } - } - } - - this.model.get("filterModel").trigger("change", this.model.get("filterModel")); - - this.zoomToFullExtent(); - - if (layout.manualColourAssignment) { - window.linkColor.manualProteinColoursBB.setMap(JSON.parse(layout.manualColourAssignment)); - this.model.set("proteinColourAssignment", window.linkColor.manualProteinColoursBB); - } - - // if (layoutIsDodgy) { - // alert("Looks like something went wrong with the saved layout, if you can't see your proteins click Auto layout"); - // } - - if (namesChanged) { - // vent.trigger("proteinMetadataUpdated", {}); //ain't gonna work - for (let renderedParticipant of this.renderedProteins.values()) { - renderedParticipant.updateName(); - } - } - } - - downloadSVG() { - const svgArr = [this.svgElement]; - const svgStrings = (0,_xiview_js_svgexp__WEBPACK_IMPORTED_MODULE_4__.capture)(svgArr); - let svgXML = (0,_xiview_js_svgexp__WEBPACK_IMPORTED_MODULE_4__.makeXMLStr)(new XMLSerializer(), svgStrings[0]); - //bit of a hack - const bBox = this.svgElement.getBoundingClientRect(); - const width = Math.round(bBox.width); - const height = Math.round(bBox.height); - svgXML = svgXML.replace("width=\"100%\"", "width=\"" + width + "px\""); - svgXML = svgXML.replace("height=\"100%\"", "height=\"" + height + "px\""); - const fileName = (0,_xiview_js_utils__WEBPACK_IMPORTED_MODULE_5__.makeLegalFileName)((0,_xiview_js_utils__WEBPACK_IMPORTED_MODULE_5__.searchesToString)() + "--xiNET--" + (0,_xiview_js_utils__WEBPACK_IMPORTED_MODULE_5__.filterStateToString)()); - (0,_xiview_js_downloads__WEBPACK_IMPORTED_MODULE_6__.download)(svgXML, "application/svg", fileName + ".svg"); - } - - highlightedLinksChanged() { - for (let p_pLink of this.renderedP_PLinks.values()) { - p_pLink.showHighlight(false); - } - const highlightedCrossLinks = this.model.getMarkedCrossLinks("highlights"); - for (let renderedCrossLink of this.renderedCrosslinks.values()) { - if (highlightedCrossLinks.indexOf(renderedCrossLink.crosslink) !== -1) { - if (renderedCrossLink.renderedFromProtein.expanded || - !renderedCrossLink.renderedToProtein || renderedCrossLink.renderedToProtein.expanded) { - renderedCrossLink.showHighlight(true); - } else if (renderedCrossLink.renderedToProtein) { - const p_pLink = this.renderedP_PLinks.get( - renderedCrossLink.renderedFromProtein.participant.id + "-" + renderedCrossLink.renderedToProtein.participant.id); - p_pLink.showHighlight(true); - } - } else { - renderedCrossLink.showHighlight(false); - } - } - for (let gg of this.g_gLinks.values()) { - gg.checkHighlight(); - } - return this; - } - - selectedLinksChanged() { - for (let p_pLink of this.renderedP_PLinks.values()) { - p_pLink.setSelected(false); - } - const selectedCrossLinks = this.model.getMarkedCrossLinks("selection"); - for (let renderedCrossLink of this.renderedCrosslinks.values()) { - if (selectedCrossLinks.indexOf(renderedCrossLink.crosslink) !== -1) { - renderedCrossLink.setSelected(true); - if (renderedCrossLink.renderedToProtein) { - const p_pLink = this.renderedP_PLinks.get( - renderedCrossLink.renderedFromProtein.participant.id + "-" + renderedCrossLink.renderedToProtein.participant.id); - p_pLink.setSelected(true); - } - } else { - renderedCrossLink.setSelected(false); - } - } - for (let gg of this.g_gLinks.values()) { - gg.checkSelected(); - } - return this; - } - - selectedProteinsChanged() { - const selectedProteins = this.model.get("selectedProteins"); - for (let renderedProtein of this.renderedProteins.values()) { - if (selectedProteins.indexOf(renderedProtein.participant) === -1 ){//&& renderedProtein.isSelected === true) { - renderedProtein.selected = false; - } - } - for (let selectedProtein of selectedProteins) { - if (selectedProtein.is_decoy !== true) { - this.renderedProteins.get(selectedProtein.id).selected = true; - } - } - if (this.groupMap) { - for (let g of this.groupMap.values()) { - g.updateSelected(); - } - } - return this; - } - - highlightedProteinsChanged() { - const highlightedProteins = this.model.get("highlightedProteins"); - - for (let renderedProtein of this.renderedProteins.values()) { - if (highlightedProteins.indexOf(renderedProtein.participant) === -1){//} && renderedProtein.highlight === true) { - renderedProtein.highlighted = false; - } - } - for (let highlightedProtein of highlightedProteins) { - if (highlightedProtein.is_decoy !== true) { - const renderedProtein = this.renderedProteins.get(highlightedProtein.id); - renderedProtein.highlighted = true; - } - - } - - if (this.groupMap) { - for (let g of this.groupMap.values()) { - let someHighlighted = false, allHighlighted = true; - for (let rp of g.renderedParticipants) { - if (rp.highlighted) { - someHighlighted = true; - } else { - allHighlighted = false; - } - } - if (someHighlighted) { - g.dashed = !allHighlighted; - g.highlighted = true; - } else { - g.highlighted = false; - g.updateSelected(); - } - } - } - - return this; - } - - // updates protein names and colours - proteinMetadataUpdated() { - for (let renderedParticipant of this.renderedProteins.values()) { - renderedParticipant.updateName(); - } - this.proteinColoursUpdated(); - return this; - } - - proteinColoursUpdated() { - const proteinColourModel = window.compositeModelInst.get("proteinColourAssignment"); - for (let renderedParticipant of this.renderedProteins.values()) { - if (proteinColourModel) { - const c = proteinColourModel.getColour(renderedParticipant.participant); - d3__WEBPACK_IMPORTED_MODULE_1__.select(renderedParticipant.outline) - .attr("fill", c); - d3__WEBPACK_IMPORTED_MODULE_1__.select(renderedParticipant.background) - .attr("fill", c); - } - } - //groups also - for (let g of this.groupMap.values()) { - if (proteinColourModel && proteinColourModel instanceof _xiview_js_model_color_protein_color_model__WEBPACK_IMPORTED_MODULE_12__.ManualColourModel) { - const c = proteinColourModel.getColour(g); - g.setColour(c); - } else { - g.setColour("#CCCCCC"); - } - } - return this; - } - - showLabels() { - const show = this.model.get("xinetShowLabels"); - for (let renderedParticipant of this.renderedProteins.values()) { - renderedParticipant.showLabel(show); - } - return this; - } - - setFixedSize() { - this.fixedSize = this.model.get("xinetFixedSize"); - for (let renderedParticipant of this.renderedProteins.values()) { - renderedParticipant.resize(); - } - return this; - } - - setCropLabels() { - this.cropLabels = this.model.get("xinetCropLabels"); - for (let renderedParticipant of this.renderedProteins.values()) { - renderedParticipant.updateName(); - } - return this; - } - - zoomToFullExtent() { - const margin = 50; - const width = this.svgElement.parentNode.clientWidth - (2 * margin); - const height = this.svgElement.parentNode.clientHeight - (2 * margin); - const bbox = this.container.getBBox(); - let xr = (width / bbox.width); - let yr = (height / bbox.height); - let scaleFactor; - if (xr > yr) { - scaleFactor = yr; - } else { - scaleFactor = xr; - } - this.container.setAttribute("transform", "scale(" + scaleFactor - + ") translate(" + ((width / scaleFactor) - bbox.width - bbox.x + (margin / scaleFactor)) + " " + (-bbox.y + (margin / scaleFactor)) + ")"); - this.scale(); - } - - scale() { - this.z = this.container.getCTM().inverse().a; - if (this.z < 0) { - console.error("weird negative value for this.z"); - this.z = 1; - } - for (let prot of this.renderedProteins.values()) { - prot.setPositionFromXinet(prot.ix, prot.iy); // this rescales the protein - if (prot.expanded) - prot.setAllLinkCoordinates(); - } - for (let renderedCrossLink of this.renderedCrosslinks.values()) { - if (renderedCrossLink.shown && renderedCrossLink.crosslink.isSelfLink() === false && renderedCrossLink.crosslink.toProtein) { - renderedCrossLink.line.setAttribute("stroke-width", this.z * CrosslinkViewer.linkWidth); - renderedCrossLink.highlightLine.setAttribute("stroke-width", this.z * 10); - if (renderedCrossLink.crosslink.ambiguous === true) { - renderedCrossLink.dashedLine(true); //rescale spacing of dashes - } - } - } - for (let p_pLink of this.renderedP_PLinks.values()) { - if (p_pLink.renderedToProtein && p_pLink.renderedFromProtein !== p_pLink.renderedToProtein && - !p_pLink.renderedFromProtein.expanded && !p_pLink.renderedToProtein.expanded) { - if (p_pLink.line) { - p_pLink.line.setAttribute("stroke-width", this.z * CrosslinkViewer.linkWidth); - p_pLink.highlightLine.setAttribute("stroke-width", this.z * 10); - p_pLink.updateThickLineWidth(); - if (p_pLink.ambiguous) { - p_pLink.dashedLine(true); //rescale spacing of dashes // performance issue? - } - } - } - } - for (let gg of this.g_gLinks.values()) { - if (gg.group1 !== gg.group2) { - // if (p_pLink.line) { - gg.line.setAttribute("stroke-width", this.z * CrosslinkViewer.linkWidth); - gg.highlightLine.setAttribute("stroke-width", this.z * 10); - gg.updateThickLineWidth(); - // if (p_pLink.ambiguous) { - // p_pLink.dashedLine(true); //rescale spacing of dashes - // } - // } - } - } - for (let g of this.groupMap.values()) { - if (!g.hidden) { - g.outline.setAttribute("stroke-width", this.z * 5); - g.highlight.setAttribute("stroke-width", this.z * 5); - if (g.expanded) { - g.updateExpandedGroup(); - } else { - g.setPositionFromXinet(g.ix, g.iy); - } - g.dashed = g._dashed; // rescale dashes - } - } - } - - setAnnotations() { - for (let renderedProtein of this.renderedProteins.values()) { - renderedProtein.setPositionalFeatures(); - } - } - - setCTM(element, matrix) { - const s = "matrix(" + matrix.a + "," + matrix.b + "," + matrix.c + "," + matrix.d + "," + matrix.e + "," + matrix.f + ")"; - element.setAttribute("transform", s); - } - - mouseDown(evt) { - evt.preventDefault(); - this.d3cola.stop(); - this.dragStart = evt; - this.state = CrosslinkViewer.STATES.SELECT_PAN; - this.mouseMoved = false; - this.toSelect = []; - d3__WEBPACK_IMPORTED_MODULE_1__.select(".xinet-context-menu").style("display", "none"); - } - - // dragging/rotating/panning/selecting - mouseMove(evt) { - if (this.dragStart) { - const p = this.getEventPoint(evt); // seems to be correct, see below - const c = p.matrixTransform(this.container.getCTM().inverse()); - const ds = this.getEventPoint(this.dragStart).matrixTransform(this.container.getCTM().inverse()); - const dx = ds.x - c.x; - const dy = ds.y - c.y; - if (Math.sqrt(dx * dx + dy * dy) > (5 * this.z)) { - this.mouseMoved = true; - } - if (this.dragElement != null && evt.which !== 3) { //dragging or rotating / not right-click mouse down - //remove tooltip - this.model.get("tooltipModel").set("contents", null); - if (this.state === CrosslinkViewer.STATES.DRAGGING) { - // we are currently dragging things around - if (this.dragElement.type === "group" && this.dragElement.expanded) { - if (!this.dragElement.selected) { - const toDrag = this.dragElement.renderedParticipants; - for (let d = 0; d < toDrag.length; d++) { - const renderedProtein = toDrag[d]; - renderedProtein.setPositionFromXinet(renderedProtein.ix - dx, renderedProtein.iy - dy); - renderedProtein.setAllLinkCoordinates(); - } - for (let g of this.dragElement.subgroups) { - if (!g.expanded) { - g.setPositionFromXinet(g.ix - dx, g.iy - dy); - g.setAllLinkCoordinates(); - } - } - }else { - this.moveSelected(dx, dy); - } - this.dragElement.updateExpandedGroup(); - } else if (this.dragElement.participant || this.dragElement.type === "group"){ //collapsed group or protein - if (!this.dragElement.selected) { - this.dragElement.setPositionFromXinet(this.dragElement.ix - dx, this.dragElement.iy - dy); - this.dragElement.setAllLinkCoordinates(); - } else { - this.moveSelected(dx, dy); - } - } - this.dragStart = evt; - } else if (this.state === CrosslinkViewer.STATES.ROTATING) { - // Distance from mouse x and center of stick. - const _dx = c.x - this.dragElement.ix; - // Distance from mouse y and center of stick. - const _dy = c.y - this.dragElement.iy; - //see http://en.wikipedia.org/wiki/Atan2#Motivation - let centreToMouseAngleRads = Math.atan2(_dy, _dx); - if (this.whichRotator === 0) { - centreToMouseAngleRads = centreToMouseAngleRads + Math.PI; - } - const centreToMouseAngleDegrees = centreToMouseAngleRads * (360 / (2 * Math.PI)); - this.dragElement.setRotation(centreToMouseAngleDegrees); - this.dragElement.setAllLinkCoordinates(); - } else { //not dragging or rotating yet, maybe we should start - // don't start dragging just on a click - we need to move the mouse a bit first - if (Math.sqrt(dx * dx + dy * dy) > (5 * this.z)) { //this.mouseMoved? - this.state = CrosslinkViewer.STATES.DRAGGING; - } - } - } else if (this.state === CrosslinkViewer.STATES.SELECT_PAN) { - if (evt.which === 3) { - //SELECT - const ds = this.getEventPoint(this.dragStart).matrixTransform(this.wrapper.getCTM().inverse()); - // var dx = c.x - ds.x; - // var dy = c.y - ds.y; - - const sx = p.x - ds.x; - const sy = p.y - ds.y; - - let rectX = ds.x; - if (sx < 0) { - rectX += sx; - } - let rectY = ds.y; - if (sy < 0) { - rectY += sy; - } - - this.selectionRectSel.attr("display", "inline") - .attr("x", rectX) - .attr("y", rectY) - .attr("width", Math.abs(sx)) - .attr("height", Math.abs(sy)); - - this.toSelect = []; - - const svgRect = this.svgElement.createSVGRect(); - svgRect.x = rectX; - svgRect.y = rectY; - svgRect.width = Math.abs(sx); - svgRect.height = Math.abs(sy); - - for (let renderedParticipant of this.renderedProteins.values()) { - if (renderedParticipant.hidden !== true) { - const intersects = this.svgElement.getIntersectionList(svgRect, renderedParticipant.upperGroup); - if (intersects.length > 0) { - renderedParticipant.highlighted = true; // todo - use model - this.toSelect.push(renderedParticipant.participant); - } else { - renderedParticipant.highlighted = false; // todo - use model - } - } - - } - for (let renderedGroup of this.groupMap.values()) { - if (renderedGroup.hidden !== true && renderedGroup.expanded === false) { - const intersects = this.svgElement.getIntersectionList(svgRect, renderedGroup.upperGroup); - if (intersects.length > 0) { - renderedGroup.highlighted = true; // todo - use model? - for (let renderedParticipant of renderedGroup.renderedParticipants) { - this.toSelect.push(renderedParticipant.participant); - } - } else { - renderedGroup.highlighted = false; // todo - use model? - } - } - } - } else { - //PAN - const ds = this.getEventPoint(this.dragStart).matrixTransform(this.container.getCTM().inverse()); - const dx = c.x - ds.x; - const dy = c.y - ds.y; - this.setCTM(this.container, - this.container.getCTM() - .translate(dx, dy) - ); - this.dragStart = evt; - } - } - } - } - - moveSelected(dx, dy) { - const toDrag = this.model.get("selectedProteins"); - for (let d = 0; d < toDrag.length; d++) { - const renderedProtein = this.renderedProteins.get(toDrag[d].id); - renderedProtein.setPositionFromXinet(renderedProtein.ix - dx, renderedProtein.iy - dy); - renderedProtein.setAllLinkCoordinates(); - } - for (let g of this.groupMap.values()) { - if (!g.expanded && g.selected) { - g.setPositionFromXinet(g.ix - dx, g.iy - dy); - g.setAllLinkCoordinates(); - } - } - } - - // this ends all dragging and rotating - mouseUp(evt) { - this.preventDefaultsAndStopPropagation(evt); - //remove selection rect, may not be shown but just do this now - this.selectionRectSel.attr("display", "none"); - //eliminate some spurious mouse up events - a simple version of debouncing, but it seems to work better than for e.g. _.debounce - const time = new Date().getTime(); - if ((time - this.lastMouseUp) > 150) { - const rightClick = (evt.button === 2); - const add = evt.ctrlKey || evt.shiftKey; - const p = this.getEventPoint(evt); - const c = p.matrixTransform(this.container.getCTM().inverse()); - if (this.state === CrosslinkViewer.STATES.ROTATING) { - //round protein rotation to nearest 5 degrees (looks neater) - this.dragElement.setRotation(Math.round(this.dragElement.rotation / 5) * 5); - this.dragElement.setAllLinkCoordinates(); - } else { - if (this.dragElement) { - if (rightClick) { - if (this.mouseMoved) { // move and right click - // ADD TO SELECT POST RIGHT CLICK DRAG -- RIGHT CLICK, HAS MOVED, NO DRAG ELEMENT - this.model.setSelectedProteins(this.toSelect, add); - } - // EXPANDING / COLLAPSING -- RIGHT CLICK, NO MOVE, IS A DRAG ELEMENT - this.contextMenuParticipant = this.dragElement; - if (this.dragElement.ix || this.dragElement.type === "group") { - this.model.get("tooltipModel").set("contents", null); - this.contextMenuPoint = c; - this.showContextMenu(evt); - } - } else if (this.dragElement.participant && !this.mouseMoved) { // it's a protein - // ADD SINGLE PROTEIN TO SELECTION - LEFT CLICK, NO MOVE, IS A DRAG ELEMENT - this.model.setSelectedProteins([this.dragElement.participant], add); - } else if (this.dragElement.participant && add && this.mouseMoved) { - // alert ("add protein to group, not implemented yet"); - // get list of groups intersecting point where protein was 'dropped' - const groupsAtPoint = []; - for (let renderedGroup of this.groupMap.values()) { - if (renderedGroup.hidden !== true){ // && renderedGroup.expanded === false) { - const bbox = renderedGroup.upperGroup.getBBox(); - if (c.x > bbox.x && c.x < bbox.x + bbox.width && c.y > bbox.y && c.y < bbox.y + bbox.height) { - console.log("just dropped in" + renderedGroup.id); //to see-ee what condition my condition was in - groupsAtPoint.push(renderedGroup); - } - } - } - // if only one group, add protein to that group - if (groupsAtPoint.length === 1) { - const group = groupsAtPoint[0]; - this.model.addProteinToGroup(group.id, this.dragElement.participant.id); - } else if (groupsAtPoint.length > 1) { - // if more than one group, show a menu of groups to add to - alert("more than one group at that point, this not implemented yet. You need a menu to confirm which group(s) to add to"); - } - } else if (this.dragElement.type === "group" && !this.mouseMoved) { // was left-click on a group, no move mouse - //add all group's proteins to selection - this.model.setSelectedProteins(this.dragElement.proteins, add); - } - } else { //no drag element - if (rightClick) { - if (this.mouseMoved) { // move and right click - // ADD TO SELECT POST RIGHT CLICK DRAG -- RIGHT CLICK, HAS MOVED, NO DRAG ELEMENT - this.model.setSelectedProteins(this.toSelect, add); - } - } else if (!this.mouseMoved) { - //UNSELECT - EITHER MOUSE BUTTON, NO MOVE, NO DRAG ELEMENT - this.model.setMarkedCrossLinks("selection", [], false, add); - this.model.setSelectedProteins([]); - - } - } - } - this.dragElement = null; - this.whichRotator = -1; - this.state = CrosslinkViewer.STATES.MOUSE_UP; - this.mouseMoved = false; - } - this.lastMouseUp = time; - return false; - } - - showContextMenu(evt) { - const self = this; - const menuListSel = this.contextMenuUlSel; - menuListSel.selectAll("li").remove(); - - const renderedInteractor = this.contextMenuParticipant; - const proteinColourModel = this.model.get("proteinColourAssignment"); - - if (renderedInteractor.participant) { //protein - if (renderedInteractor.expanded) { - menuListSel.append("li").text("Collapse Protein").on("click", () => { - this.collapseInteractor(renderedInteractor); - }); - //scale buttons - const scaleButtonsListItemSel = menuListSel.append("li").text("Scale: "); - const scaleButtons = scaleButtonsListItemSel.selectAll("ul.custom-menu") - .data(CrosslinkViewer.barScales) - .enter() - .append("div") - .attr("class", "barScale") - .append("label"); - scaleButtons.append("span") - .text(function (d) { - if (d === 8) return "AA"; - else return d; - }); - scaleButtons.append("input") - // .attr ("id", function(d) { return d*100; }) - .attr("class", function (d) { - return "scaleButton scaleButton_" + (d * 100); - }) - .attr("name", "scaleButtons") - .attr("type", "radio") - .on("change", function (d) { - self.contextMenuParticipant.setStickScale(d, self.contextMenuPoint); - }); - d3__WEBPACK_IMPORTED_MODULE_1__.select(".scaleButton_" + (renderedInteractor.stickZoom * 100)).property("checked", true); - - } else { - menuListSel.append("li").text("Expand Protein").on("click", () => { - this.expandProtein(renderedInteractor); - }); - } - - menuListSel.append("li").text("Open in UniProt").on("click", () => { - window.open("https://www.uniprot.org/uniprotkb?query=" + renderedInteractor.participant.accession); - }); - - menuListSel.append("li").text("Set Protein Colour").on("click", () => { - //todo: set protein colour for all selected proteins? - this.model.chooseInteractorColor(renderedInteractor.participant.id); - d3__WEBPACK_IMPORTED_MODULE_1__.select(".xinet-context-menu").style("display", "none"); - }); - - if (proteinColourModel instanceof _xiview_js_model_color_protein_color_model__WEBPACK_IMPORTED_MODULE_12__.ManualColourModel) { - if (proteinColourModel.hasManualAssignment(renderedInteractor.participant.id)) { - menuListSel.append("li").text("Remove Protein Colour").on("click", () => { - proteinColourModel.removeManualAssignment(renderedInteractor.participant.id); - this.model.trigger("currentProteinColourModelChanged", proteinColourModel); - d3__WEBPACK_IMPORTED_MODULE_1__.select(".xinet-context-menu").style("display", "none"); - }); - } - } - - for (let pg of renderedInteractor.parentGroups) { - menuListSel.append("li").text("Remove from group " + pg.name) - .attr("data-group", pg.name).attr("data-protein", renderedInteractor.participant.id) - .node().onclick = function (evt) { //on("click", function (evt) { - const protien = evt.target.getAttribute("data-protein"); - const group = evt.target.getAttribute("data-group"); - console.log("remove protein " + protien + " from group " + group); - d3__WEBPACK_IMPORTED_MODULE_1__.select(".xinet-context-menu").style("display", "none"); - self.contextMenuParticipant.highlighted = false; - self.model.removeProteinFromGroup(group, protien); - }; - } - - } else { // group - if (renderedInteractor.expanded) { - if (renderedInteractor.isOverlappingGroup()) { - menuListSel.append("li").text("Can't collapse overlapping groups").on("click", () => { - this.cantCollapseGroup(); //does nothing - d3__WEBPACK_IMPORTED_MODULE_1__.select(".xinet-context-menu").style("display", "none"); - }); - // menuListSel.append("li").text("Enclose Overlapping Groups").on("click", () => { - // alert("enclose overlapping groups not implemented yet"); - // }); - } else { - menuListSel.append("li").text("Collapse Group").on("click", () => { - this.collapseInteractor(renderedInteractor); - }); - } - // menuListSel.append("li").text("Autolayout Group").on("click", () => { - // this.autoLayoutGroup(renderedInteractor, []); - // d3.select(".xinet-context-menu").style("display", "none"); - // }); - } else { - menuListSel.append("li").text("Expand Group").on("click", () => { - renderedInteractor.setExpanded(true, this.getEventPoint(evt)); - d3__WEBPACK_IMPORTED_MODULE_1__.select(".xinet-context-menu").style("display", "none"); - }); - } - - menuListSel.append("li").text("Ungroup").on("click", () => { - this.ungroup(renderedInteractor); - d3__WEBPACK_IMPORTED_MODULE_1__.select(".xinet-context-menu").style("display", "none"); - }); - - menuListSel.append("li").text("Set Group Colour").on("click", () => { - this.model.chooseInteractorColor(renderedInteractor.id); - d3__WEBPACK_IMPORTED_MODULE_1__.select(".xinet-context-menu").style("display", "none"); - }); - - if (proteinColourModel instanceof _xiview_js_model_color_protein_color_model__WEBPACK_IMPORTED_MODULE_12__.ManualColourModel) { - if (proteinColourModel.hasManualAssignment(renderedInteractor.id)) { - menuListSel.append("li").text("Remove Group Colour").on("click", () => { - proteinColourModel.removeManualAssignment(renderedInteractor.id); - this.model.trigger("currentProteinColourModelChanged", proteinColourModel); - d3__WEBPACK_IMPORTED_MODULE_1__.select(".xinet-context-menu").style("display", "none"); - }); - } - } - } - - //keep menu on screen - const width = this.svgElement.parentNode.clientWidth; - const height = this.svgElement.parentNode.clientHeight; - const pageX = evt.pageX; - const pageY = evt.pageY - 37; //todo: hacky, 37 is height of top bar - const menu = d3__WEBPACK_IMPORTED_MODULE_1__.select(".xinet-context-menu"); - menu.style("display", "block"); - const menuWidth = menu.node().getBoundingClientRect().width; - const menuHeight = menu.node().getBoundingClientRect().height; - console.log("menuWidth: " + menuWidth, "menuHeight: " + menuHeight); - const mouseOffset = 20; - const x = pageX + mouseOffset + menuWidth > width ? pageX - mouseOffset - menuWidth : pageX + mouseOffset; - const y = pageY + mouseOffset + menuHeight > height ? pageY - mouseOffset - menuHeight : pageY + mouseOffset; - menu.style("top", y + "px").style("left", x + "px"); - } - - mouseWheel(evt) { - this.preventDefaultsAndStopPropagation(evt); - this.d3cola.stop(); - let delta; - //see http://stackoverflow.com/questions/5527601/normalizing-mousewheel-speed-across-browsers - // noinspection JSUnresolvedVariable - if (evt.wheelDelta) { - delta = evt.wheelDelta / 3600; // Chrome/Safari - } else { - delta = evt.detail / -90; // Mozilla - } - const z = 1 + delta; - const g = this.container; - const p = this.getEventPoint(evt); - const c = p.matrixTransform(g.getCTM().inverse()); - const k = this.svgElement.createSVGMatrix().translate(c.x, c.y).scale(z).translate(-c.x, -c.y); - this.setCTM(g, g.getCTM().multiply(k)); - this.scale(); - return false; - } - - mouseOut() { //todo - // don't, causes problem's - RenderedInteractor mouseOut getting propagated? - // d3.select(".custom-menu-margin").style("display", "none"); - // d3.select(".group-custom-menu-margin").style("display", "none"); - } - - getEventPoint(evt) { - const p = this.svgElement.createSVGPoint(); - let element = this.svgElement.parentNode; - let top = 0, - left = 0; - do { - top += element.offsetTop || 0; - left += element.offsetLeft || 0; - element = element.offsetParent; - } while (element); - p.x = evt.clientX - left; //crossBrowserElementX(evt);//, this.svgElement); - p.y = evt.clientY - top; //crossBrowserElementY(evt);//, this.svgElement); - return p; - } - - //stop event propagation and defaults; only do what we ask - preventDefaultsAndStopPropagation(evt) { - if (evt.stopPropagation) - evt.stopPropagation(); - if (evt.cancelBubble != null) - evt.cancelBubble = true; - if (evt.preventDefault) - evt.preventDefault(); - } - -} - -CrosslinkViewer.removeDomElement = function (child) { - if (child && child.parentNode) { - child.parentNode.removeChild(child); - } -}; - -CrosslinkViewer.svgns = "http://www.w3.org/2000/svg"; // namespace for svg elements -CrosslinkViewer.linkWidth = 1.7; // default line width -//static values signifying Controller's status -CrosslinkViewer.STATES = { - MOUSE_UP: 0, - SELECT_PAN: 1, - DRAGGING: 2, - ROTATING: 3 -}; - -CrosslinkViewer.barScales = [0.01, 0.2, 0.5, 0.8, 1, 2, 4, 8]; - - -/***/ }), - -/***/ "./crosslink-viewer/js/views/xinet/interactor/group.js": -/*!*************************************************************!*\ - !*** ./crosslink-viewer/js/views/xinet/interactor/group.js ***! - \*************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ Group: () => (/* binding */ Group) -/* harmony export */ }); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! d3 */ "./node_modules/d3/d3.js"); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(d3__WEBPACK_IMPORTED_MODULE_0__); -/* harmony import */ var _interactor__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./interactor */ "./crosslink-viewer/js/views/xinet/interactor/interactor.js"); -/* harmony import */ var _crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../crosslink-viewer-BB */ "./crosslink-viewer/js/views/xinet/crosslink-viewer-BB.js"); -/* harmony import */ var _xiview_js_make_tooltip__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../../../../xiview/js/make-tooltip */ "./xiview/js/make-tooltip.js"); -/* harmony import */ var _rendered_protein__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./rendered-protein */ "./crosslink-viewer/js/views/xinet/interactor/rendered-protein.js"); - - - - - - -class Group extends _interactor__WEBPACK_IMPORTED_MODULE_1__.Interactor { - constructor(id, participantIds, controller) { - super(controller); - - this._id = id; - this.name = id; - - this.renderedParticipants = []; - for (let pId of participantIds) { - const p = this.controller.renderedProteins.get(pId); - if (p) { // no decoys in this.controller.renderedProteins - this.renderedParticipants.push(p); - } - } - this.parentGroups = new Set(); - this.subgroups = []; - - this.expanded = true; - this.hidden = false; - this.type = "group"; - - this.padding = 45; // used by cola.js - - this.upperGroup = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.svgns, "g"); - this.upperGroup.setAttribute("class", "protein upperGroup"); - - //make highlight - this.highlight = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.svgns, "rect"); - this.highlight.setAttribute("class", "highlightedProtein"); - this.highlight.setAttribute("stroke-width", "3"); - this.highlight.setAttribute("fill", "none"); - this.highlight.setAttribute("stroke-opacity", "0"); - - //create label - we will move this svg element around when expand / collapse - this.labelSVG = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.svgns, "text"); - this.labelSVG.setAttribute("fill", "black"); - this.labelSVG.setAttribute("x", "0"); - this.labelSVG.setAttribute("y", "0"); - this.labelSVG.setAttribute("class", "xlv_text proteinLabel"); - this.labelSVG.setAttribute("text-decoration", "underline"); - this.labelText = this.name; - this.labelTextNode = document.createTextNode(this.labelText); - this.labelSVG.appendChild(this.labelTextNode); - - //make blob - this.outline = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.svgns, "rect"); - this.outline.setAttribute("stroke", "white"); - this.outline.setAttribute("stroke-width", "3"); - this.outline.setAttribute("stroke-opacity", "1"); - this.outline.setAttribute("fill-opacity", "0.5"); - this.outline.setAttribute("fill", "#cccccc"); - - this.upperGroup.appendChild(this.outline); - this.upperGroup.appendChild(this.highlight); - this.upperGroup.appendChild(this.labelSVG); - - //need to change this if default is unexpanded - this.controller.groupsSVG.appendChild(this.upperGroup); - - const self = this; - // this.upperGroup.setAttribute('pointer-events','all'); - this.upperGroup.onmousedown = function (evt) { - self.mouseDown(evt); - }; - this.upperGroup.onmouseover = function (evt) { - self.mouseOver(evt); - }; - this.upperGroup.onmouseout = function (evt) { - self.mouseOut(evt); - }; - } - - get id () { - return this._id; - } - - set id (id){ - this._id = id; - } - - get proteins () { - const proteins = []; - for (let renderedParticipant of this.renderedParticipants) { - proteins.push(renderedParticipant.participant); - } - return proteins; - } - - get width() { - // return 60; - const approxLabelWidth = 10 * (this.labelText.length + 2); - return (approxLabelWidth > this.symbolRadius) ? approxLabelWidth : this.symbolRadius + 20; - } - - get height () { - return 60; - } - - get bBox () { - return this.upperGroup.getBBox(); - // let x1 = 0, y1 = 0, x2 = 0, y2 = 0; - // const z = this.controller.z;//, pad = 5 * z; - // - // for (let rp of this.renderedParticipants) { - // if (!rp.hidden && !this.containsInSubgroup(rp)) { - // const rpBbox = rp.bBox; - // if (!x1 || (rpBbox.x * z) + rp.ix < x1) { - // x1 = (rpBbox.x * z) + rp.ix; - // } - // if (!y1 || (rpBbox.y * z) + rp.iy < y1) { - // y1 = (rpBbox.y * z) + rp.iy; - // } - // if (!x2 || ((rpBbox.x + rpBbox.width) * z) + rp.ix > x2) { - // x2 = ((rpBbox.x + rpBbox.width) * z) + rp.ix; - // } - // if (!y2 || ((rpBbox.y + rpBbox.height) * z) + rp.iy > y2) { - // y2 = ((rpBbox.y + rpBbox.height) * z) + rp.iy; - // } - // } - // } - // - // const w = x2 - x1, h = y2 -y1; - // - // return { - // x: x1, - // y: y1, - // width: w, - // height: h - // }; - } - - //only output the info needed to reproduce the layout, used by save layout function - toJSON() { - const participantIds = []; - for (let rp of this.renderedParticipants) { - participantIds.push(rp.participant.id); - } - return { - id: this.id, - x: this.ix, - y: this.iy, - expanded: this.expanded, - participantIds: participantIds - }; - } - - get unhiddenParticipantCount () { - let count = 0; - for (let renderedParticipant of this.renderedParticipants) { - if (!renderedParticipant.participant.hidden) { - count++; - } - } - return count; - } - - get selected () { - const selectedProteins = this.controller.model.get("selectedProteins"); - for (let rp of this.renderedParticipants) { - if (selectedProteins.indexOf(rp.participant) === -1) { - return false; - } - } - return true; - } - - set selected (selected) { - super.selected = selected; - if (selected) { - this.outline.setAttribute("stroke", "none"); - } else { - this.outline.setAttribute("stroke", "white"); - } - } - - set highlighted (highlight) { - super.highlighted = highlight; - if (highlight) { - this.outline.setAttribute("stroke", "none"); - } else { - this.outline.setAttribute("stroke", "white"); - } - } - - // result depends on whats hidden - isSubsetOf(anotherGroup) { - for (let renderedParticipant of this.renderedParticipants) { - if (!renderedParticipant.participant.hidden && anotherGroup.renderedParticipants.indexOf(renderedParticipant) === -1) { - return false; - } - } - return true; - } - - contains(renderedProtein) { - for (let rp of this.renderedParticipants) { - if (rp === renderedProtein) { - return true; - } - } - return false; - } - - containsInSubgroup(renderedProtein) { - for (let subgroup of this.subgroups) { - if (subgroup.contains(renderedProtein)) { - return true; - } - } - return false; - } - - isOverlappingGroup() { - for (let renderedParticipant of this.renderedParticipants) { - if (!renderedParticipant.participant.hidden && renderedParticipant.parentGroups.size > 1) { - for (let parentGroup of renderedParticipant.parentGroups) { - if (!parentGroup.isSubsetOf(this) && !this.isSubsetOf(parentGroup)) { - return true; - } - } - } - } - for (let subgroup of this.subgroups) { - if (!subgroup.hidden && subgroup.parentGroups.size > 1) { - for (let subgroupParentGroup of subgroup.parentGroups) { - if (!subgroupParentGroup.isSubsetOf(this) && !this.isSubsetOf(subgroupParentGroup)) { - return true; - } - } - } - } - return false; - } - - init() { - this.controller.groupsSVG.appendChild(this.upperGroup); - this.setExpanded(this.expanded); - } - - mouseDown(evt) { - this.controller.d3cola.stop(); - this.controller.dragElement = this; - this.controller.dragStart = evt; - this.controller.mouseMoved = false; - return false; - } - - mouseOver(evt) { - // this.showHighlight(true); - const toHighlight = []; - for (let rp of this.renderedParticipants) { - toHighlight.push(rp.participant); - } - this.controller.model.setHighlightedProteins(toHighlight); - //call in super? - const p = this.controller.getEventPoint(evt); - this.controller.model.get("tooltipModel") - .set("header", _xiview_js_make_tooltip__WEBPACK_IMPORTED_MODULE_3__.makeTooltipTitle.complex(this)) - .set("contents", _xiview_js_make_tooltip__WEBPACK_IMPORTED_MODULE_3__.makeTooltipContents.complex(this)) - .set("location", { - pageX: p.x, - pageY: p.y - }); - } - - // mouseOut(evt) { - // this.highlighted = false; - // Interactor.prototype.mouseOut.call(this, evt); - // } - - getAverageParticipantPosition() { - let xSum = 0, - ySum = 0; - const rpCount = this.renderedParticipants.length; - for (let rp of this.renderedParticipants) { - xSum += rp.ix; - ySum += rp.iy; - } - return [xSum / rpCount, ySum / rpCount]; - } - - /* leave this.x and this.y as they were set by cola, - calculate centre of interactor's glyph, - call setPosition with those - */ - setPositionFromCola() { - this.px = this.x; - this.py = this.y; - // let xOffset = 0; - // if (!this.hidden) { // todo - hacky - // xOffset = (this.width / 20); // - (this.getBlobRadius()) + 5) - // // if (this.expanded) { - // // xOffset = xOffset + (this.participant.size / 2 * this.stickZoom ); - // // } - // } - this.setPosition(this.x /*- xOffset*/, this.y); - } - - /* calculate top left of interactor's glyph, - set this.x and this.y as cola would have them, - call setPosition with same params this received - */ - setPositionFromXinet(ix, iy) { - this.px = this.x; - this.py = this.y; - let xOffset = 0; - if (!this.hidden) { // todo - hacky - xOffset = (this.width / 2); // - (this.getBlobRadius()) + 5) - // if (this.expanded) { - // xOffset = xOffset + (this.participant.size / 2 * this.stickZoom ); - // } - } - this.x = ix - xOffset; - this.y = iy; - this.setPosition(ix, iy); - } - - //also setting size of collapsed group symbol; scaling line widths, corner radii - setPosition(ix, iy) { //todo - array for coordinate param? - if (!this.expanded) { - this.ix = ix; - this.iy = iy; - const symbolWidth = 20; - const x = this.ix - (symbolWidth * this.controller.z); - const y = this.iy - (symbolWidth * this.controller.z); - const scaledWidth = 2 * (symbolWidth * this.controller.z); - const cornerRadii = 5 * this.controller.z; - - const updateOutline = function (svgElement) { - if (!x){ - console.log("!x"); - } - - svgElement.setAttribute("x", x); - svgElement.setAttribute("y", y); - svgElement.setAttribute("width", scaledWidth); - svgElement.setAttribute("height", scaledWidth); - svgElement.setAttribute("rx", cornerRadii); - svgElement.setAttribute("ry", cornerRadii); - }; - - updateOutline(this.outline); - // noinspection JSCheckFunctionSignatures - this.outline.setAttribute("stroke-width", 3 * this.controller.z); - - updateOutline(this.highlight); - this.highlight.setAttribute("stroke-width", 9 * this.controller.z); - - this.labelSVG.setAttribute("transform", "translate(" + this.ix + " " + this.iy + ")" + - " scale(" + (this.controller.z) + ")"); - - for (let group of this.parentGroups) { - if (group.expanded && !this.hidden) { - group.updateExpandedGroup(); - } - } - for (let ggLink of this.controller.g_gLinks.values()) { - ggLink.setLineCoordinates(); - } - if (this.selfLink != null) { - if (typeof this.selfLink.thickLine !== "undefined") { - this.selfLink.thickLine.setAttribute("transform", "translate(" + this.ix + - " " + this.iy + ")" + " scale(" + (this.controller.z) + ")"); - } - this.selfLink.line.setAttribute("transform", "translate(" + this.ix + - " " + this.iy + ")" + " scale(" + (this.controller.z) + ")"); - this.selfLink.highlightLine.setAttribute("transform", "translate(" + this.ix + - " " + this.iy + ")" + " scale(" + (this.controller.z) + ")"); - } - - } else { - console.log("error - calling setPosition on unexpanded Group"); - } - } - - updateExpandedGroup() { - let x1 = 0, y1 = 0, x2 = 0, y2 = 0; - const z = this.controller.z, pad = 5 * z; - - for (let rp of this.renderedParticipants) { - if (!rp.hidden && !this.containsInSubgroup(rp)) { - const rpBbox = rp.bBox; - if (!x1 || (rpBbox.x * z) + rp.ix < x1) { - x1 = (rpBbox.x * z) + rp.ix; - } - if (!y1 || (rpBbox.y * z) + rp.iy < y1) { - y1 = (rpBbox.y * z) + rp.iy; - } - if (!x2 || ((rpBbox.x + rpBbox.width) * z) + rp.ix > x2) { - x2 = ((rpBbox.x + rpBbox.width) * z) + rp.ix; - } - if (!y2 || ((rpBbox.y + rpBbox.height) * z) + rp.iy > y2) { - y2 = ((rpBbox.y + rpBbox.height) * z) + rp.iy; - } - } - } - - for (let sg of this.subgroups) { - if (!sg.hidden) { - const sgBbox = sg.bBox; - if (!x1 || (sgBbox.x) < x1) { - x1 = (sgBbox.x); - } - if (!y1 || (sgBbox.y) < y1) { - y1 = (sgBbox.y); - } - if (!x2 || ((sgBbox.x + sgBbox.width)) > x2) { - x2 = ((sgBbox.x + sgBbox.width)); - } - if (!y2 || ((sgBbox.y + sgBbox.height)) > y2) { - y2 = ((sgBbox.y + sgBbox.height)); - } - } - } - - const updateOutline = function (svgElement) { - svgElement.setAttribute("x", x1 - pad); - svgElement.setAttribute("y", y1 - pad); - svgElement.setAttribute("width", x2 - x1 + (2 * pad)); - svgElement.setAttribute("height", y2 - y1 + (2 * pad)); - svgElement.setAttribute("rx", pad); - svgElement.setAttribute("ry", pad); - }; - - updateOutline(this.outline); - // noinspection JSCheckFunctionSignatures - this.outline.setAttribute("stroke-width", 3 * this.controller.z); - - updateOutline(this.highlight); - this.highlight.setAttribute("stroke-width", 9 * this.controller.z); - - //move label - this.labelSVG.setAttribute("transform", "translate(" + (x1 - pad) + " " + (y1 - pad) + ")" + - " scale(" + (this.controller.z) + ")"); - - for (let group of this.parentGroups) { - if (group.expanded && !this.hidden) { - group.updateExpandedGroup(); - } - } - } - - setColour(colour) { - if (colour === "#FFFFFF") colour = "#CCCCCC"; - this.outline.setAttribute("fill", colour); - } - - setHidden(bool) { // todo: make this a property? - d3__WEBPACK_IMPORTED_MODULE_0___default().select(this.upperGroup).style("display", bool ? "none" : null); - d3__WEBPACK_IMPORTED_MODULE_0___default().select(this.labelSVG).style("display", bool ? "none" : null); - this.hidden = !!bool; - } - - // updateHighlight() { - // if (this.expanded) { - // let someHighlighted = false, allHighlighted = true; - // for (let rp of this.renderedParticipants) { - // if (!rp.hidden) { - // if (rp.isHighlighted) { - // someHighlighted = true; - // } else { - // allHighlighted = false; - // } - // } - // } - // if (someHighlighted) { - // if (!allHighlighted) { - // this.dashedOutline(true); - // } else { - // this.dashedOutline(false); - // } - // this.showHighlight(true); - // } else { - // this.dashedOutline(false); - // this.showHighlight(false); - // this.updateSelected(); - // } - // } - // } - - updateSelected() { - let someSelected = false, allSelected = true; - for (let rp of this.renderedParticipants) { - if (rp.selected) { - someSelected = true; - } else { - allSelected = false; - } - } - if (someSelected) { - this.dashed = !allSelected; - this.selected = true; - } else { - this.selected = false; - } - } - - set dashed(dash) { - if (dash){// && !this._dashed) { - this.highlight.setAttribute("stroke-dasharray", (8 * this.controller.z) + ", " + (8 * this.controller.z)); - } else if (!dash){//} && this._dashed) { - this.highlight.removeAttribute("stroke-dasharray"); - } - this._dashed = !!dash; - } - - updateCountLabel() { - this.labelSVG.innerHTML = this.labelText + " ("+ this.unhiddenParticipantCount + ")"; - } - - setExpanded(expanded, svgP) { - this.controller.model.get("tooltipModel").set("contents", null); - if (this.busy !== true) { - if (this.isOverlappingGroup()) { - console.error("overlapping group", this.id); - expanded = true; - } - if (expanded) { - if (this.expanded !== expanded) { - this.expand(); - } - } else { - if (this.expanded !== expanded) { - this.collapse(svgP); - } - } - } - } - - collapse(svgP, transition = true) { - // transition = false; - if (this.isOverlappingGroup()) { - console.error("overlapping group", this.id); - this.expand(false); - return; - } - let newX, newY; - if (svgP) { - newX = svgP.x; - newY = svgP.y; - } else { - const avPos = this.getAverageParticipantPosition(); - newX = avPos[0]; - newY = avPos[1]; - } - - const originalProteinPositions = []; // will reset positions after transition - const originalCollapsedSubgroupPositions = []; // will reset positions after transition - const proteinXPositionInterpolations = []; - const proteinYPositionInterpolations = []; - const collapsedSubgroupXPositionInterpolations = []; - const collapsedSubgroupYPositionInterpolations = []; - const cubicInOut = d3__WEBPACK_IMPORTED_MODULE_0___default().ease("cubic-in-out"); - this.busy = true; - const self = this; - - if (transition) { - for (let rp of this.renderedParticipants) { - originalProteinPositions.push([rp.ix, rp.iy]); - proteinXPositionInterpolations.push(d3__WEBPACK_IMPORTED_MODULE_0___default().interpolate(rp.ix, newX)); - proteinYPositionInterpolations.push(d3__WEBPACK_IMPORTED_MODULE_0___default().interpolate(rp.iy, newY)); - } - - for (let sg of this.subgroups) { - // if (!sg.expanded) { - originalCollapsedSubgroupPositions.push([sg.ix, sg.iy]); - collapsedSubgroupXPositionInterpolations.push(d3__WEBPACK_IMPORTED_MODULE_0___default().interpolate(sg.ix, newX)); - collapsedSubgroupYPositionInterpolations.push(d3__WEBPACK_IMPORTED_MODULE_0___default().interpolate(sg.iy, newY)); - // } - } - - d3__WEBPACK_IMPORTED_MODULE_0___default().timer(function (elapsed) { - return updateCollapsing(elapsed / (_rendered_protein__WEBPACK_IMPORTED_MODULE_4__.RenderedProtein.transitionTime * 2)); - }); - - } else { - updateCollapsing(1); - } - - function updateCollapsing(interp) { - if (interp === 1) { // finished - tidy up - self.expanded = false; - self.setPositionFromXinet(newX, newY); - - for (let i = 0; i < self.renderedParticipants.length; i++) { - const rp = self.renderedParticipants[i]; - rp.setHidden(true); - if (transition){ - rp.setPositionFromXinet(originalProteinPositions[i][0], originalProteinPositions[i][1]); - } - // rp.setAllLinkCoordinates(); - } - - for (let i = 0; i < self.subgroups.length; i++) { - const sg = self.subgroups[i]; - // if (!sg.expanded) { - if (transition){ - sg.setPositionFromXinet(originalCollapsedSubgroupPositions[i][0], originalCollapsedSubgroupPositions[i][1]); - } - // } - } - self.labelSVG.setAttribute("dominant-baseline", "central"); - self.labelSVG.setAttribute("text-anchor", "middle"); - self.hideSubgroups(); - self.controller.proteinUpper.appendChild(self.upperGroup); - self.outline.setAttribute("fill-opacity", "1"); - if (transition) { - self.controller.hiddenProteinsChanged(); - self.controller.render(); - } - self.busy = false; - return true; - } else if (interp > 1 || isNaN(interp)) { - return updateCollapsing(1); - } else { - for (let i = 0; i < self.renderedParticipants.length; i++) { - const rp = self.renderedParticipants[i]; - const x = proteinXPositionInterpolations[i](cubicInOut(interp)); - const y = proteinYPositionInterpolations[i](cubicInOut(interp)); - rp.setPositionFromXinet(x, y); - rp.setAllLinkCoordinates(); - } - - for (let i = 0; i < self.subgroups.length; i++) { - const sg = self.subgroups[i]; - if (!sg.expanded) { - const x = collapsedSubgroupXPositionInterpolations[i](cubicInOut(interp)); - const y = collapsedSubgroupYPositionInterpolations[i](cubicInOut(interp)); - sg.setPositionFromXinet(x, y); - } - } - self.updateExpandedGroup(); - return false; - } - } - } - - expand(transition = true) { - // transition = false; - this.busy = true; - const self = this; - - this.expanded = true; - // if (transition) { // yucky, transition is being used to indicate whether this is one interactor collapsing or from 'Collapse All' - // this.controller.render(); - // } - - const proteinXPositionInterpolations = []; - const proteinYPositionInterpolations = []; - const collapsedSubgroupXPositionInterpolations = []; - const collapsedSubgroupYPositionInterpolations = []; - - const cubicInOut = d3__WEBPACK_IMPORTED_MODULE_0___default().ease("cubic-out"); - - // this.labelSVG.setAttribute("dominant-baseline", null); - // this.labelSVG.setAttribute("text-anchor", null); - // this.showSubgroups(); - // this.controller.groupsSVG.appendChild(this.upperGroup); - // this.outline.setAttribute("fill-opacity", "0.5"); - // - // for (let rp of this.renderedParticipants) { - // rp.setHidden(rp.participant.hidden || rp.inCollapsedGroup()); - // } - - const tl = this.controller.svgElement.createSVGPoint(); - tl.x = 0; - tl.y =0; - const br = this.controller.svgElement.createSVGPoint(); - const width = this.controller.svgElement.parentNode.clientWidth; - const height = this.controller.svgElement.parentNode.clientHeight; - br.x = width; - br.y = height; - const topLeft = tl.matrixTransform(this.controller.container.getCTM().inverse()); - const bottomRight = br.matrixTransform(this.controller.container.getCTM().inverse()); - - //bbox of the expanded group (before moving it on screen if necessary) - let bboxTL = this.controller.svgElement.createSVGPoint(); - let bboxBR = this.controller.svgElement.createSVGPoint(); - - // decide on new positions for proteins and collapsed subgroups - if (transition) { // only if transition (not if no position, i.e. from saved layout) - let ix = this.ix, iy = this.iy; - if (!ix) { // todo? um, check why this can be undefined (is it when loading from saved layout) - const pPos = this.getAverageParticipantPosition(); - ix = pPos[0]; - iy = pPos[1]; - } - - this.controller.hiddenProteinsChanged(); //needed for isOnScreen() to work - - let allOnScreen = true; - for (let rp of this.renderedParticipants) { - if (!isOnScreen(rp)) { - allOnScreen = false; - // can't break here because we need to get the bbox of the expanded group - } - } - - for (let sg of this.subgroups) { - if (!sg.expanded) { - if (!isOnScreen(sg)) { - allOnScreen = false; - // can't break here because we need to get the bbox of the expanded group - } - } - } - - if (allOnScreen) { - for (let rp of this.renderedParticipants) { - proteinXPositionInterpolations.push(d3__WEBPACK_IMPORTED_MODULE_0___default().interpolate(ix, rp.ix)); - proteinYPositionInterpolations.push(d3__WEBPACK_IMPORTED_MODULE_0___default().interpolate(iy, rp.iy)); - } - for (let sg of this.subgroups) { - // if (!sg.expanded) { - collapsedSubgroupXPositionInterpolations.push(d3__WEBPACK_IMPORTED_MODULE_0___default().interpolate(ix, sg.ix)); - collapsedSubgroupYPositionInterpolations.push(d3__WEBPACK_IMPORTED_MODULE_0___default().interpolate(iy, sg.iy)); - // } - } - } else { - // alert("not all on screen"); - console.log("not all on screen", bboxTL, bboxBR); - - - //scale? - const bboxWidth = (bboxBR.x - bboxTL.x); - const bboxHeight = bboxBR.y - bboxTL.y; - const preferredWidth = (width / 2) * this.controller.z; - const preferredHeight = (height / 2) * this.controller.z; - let xScale, yScale, scale = 1; - if (bboxWidth > (width * this.controller.z) || bboxHeight > (height * this.controller.z)) { - if (bboxWidth > preferredWidth) { - xScale = preferredWidth / bboxWidth; - } - if (bboxHeight > preferredHeight) { - yScale = preferredHeight / bboxHeight; - } - scale = Math.min(xScale, yScale); - console.log("SCALE!!", scale); - //bbox is that of the expanded group - - const bboxMidPoint = {};//= this.controller.svgElement.createSVGPoint(); - - bboxMidPoint.x = (bboxTL.x + bboxBR.x) / 2; - bboxMidPoint.y = (bboxTL.y + bboxBR.y) / 2; - - const xTrans = ix - bboxMidPoint.x; - const yTrans = iy - bboxMidPoint.y; - - for (let rp of this.renderedParticipants) { - const dx = rp.ix + xTrans - bboxMidPoint.x; - const dy = rp.iy + yTrans - bboxMidPoint.y; - // const dx = rp.ix + (ix - bboxMidPoint.x) - bboxMidPoint.x; - // = rp.ix + ix - 2 * bboxMidPoint.x; - proteinXPositionInterpolations.push(d3__WEBPACK_IMPORTED_MODULE_0___default().interpolate(ix, ix + (dx * scale))); - proteinYPositionInterpolations.push(d3__WEBPACK_IMPORTED_MODULE_0___default().interpolate(iy, iy + (dy * scale))); - } - for (let sg of this.subgroups) { - // if (!sg.expanded) { - const dx = sg.ix + xTrans - bboxMidPoint.x; - const dy = sg.iy + yTrans - bboxMidPoint.y; - - collapsedSubgroupXPositionInterpolations.push(d3__WEBPACK_IMPORTED_MODULE_0___default().interpolate(ix, ix + (dx * scale))); - collapsedSubgroupYPositionInterpolations.push(d3__WEBPACK_IMPORTED_MODULE_0___default().interpolate(iy, iy + (dy * scale))); - // } - } - } else { - //bbox is that of the expanded group - - const bboxMidPoint = {};//= this.controller.svgElement.createSVGPoint(); - - bboxMidPoint.x = (bboxTL.x + bboxBR.x) / 2; - bboxMidPoint.y = (bboxTL.y + bboxBR.y) / 2; - - const xTrans = ix - bboxMidPoint.x; - const yTrans = iy - bboxMidPoint.y; - - for (let rp of this.renderedParticipants) { - proteinXPositionInterpolations.push(d3__WEBPACK_IMPORTED_MODULE_0___default().interpolate(ix, rp.ix + xTrans)); - proteinYPositionInterpolations.push(d3__WEBPACK_IMPORTED_MODULE_0___default().interpolate(iy, rp.iy + yTrans)); - } - for (let sg of this.subgroups) { - // if (!sg.expanded) { - collapsedSubgroupXPositionInterpolations.push(d3__WEBPACK_IMPORTED_MODULE_0___default().interpolate(ix, sg.ix + xTrans)); - collapsedSubgroupYPositionInterpolations.push(d3__WEBPACK_IMPORTED_MODULE_0___default().interpolate(iy, sg.iy + yTrans)); - // } - } - } - } - - //move all prots / subgroups to - for (let rp of this.renderedParticipants) { - if (!rp.hidden){ - rp.setPositionFromXinet(ix, iy); - } - } - for (let sg of this.subgroups) { - if (!sg.hidden) { - sg.setPositionFromXinet(ix, iy); - } - } - - // this.expanded = true; - this.labelSVG.setAttribute("dominant-baseline", null); - this.labelSVG.setAttribute("text-anchor", null); - - this.showSubgroups(); - - this.controller.groupsSVG.appendChild(this.upperGroup); - this.outline.setAttribute("fill-opacity", "0.5"); - - for (let rp of this.renderedParticipants) { - rp.setHidden(rp.participant.hidden || rp.inCollapsedGroup()); - } - - if (transition) { // yucky, transition is being used to indicate whether this is one interactor collapsing or from 'Collapse All' - this.controller.render(); - } - - d3__WEBPACK_IMPORTED_MODULE_0___default().timer(function (elapsed) { - return updateExpanding(elapsed / (_rendered_protein__WEBPACK_IMPORTED_MODULE_4__.RenderedProtein.transitionTime * 2)); - }); - } else { - updateExpanding(1); - } - - function isOnScreen(interactor){ - if (!interactor.hidden) { - // console.log("TESTING", interactor); - if (!bboxTL.x || interactor.ix < bboxTL.x) { - bboxTL.x = interactor.ix; - // console.log("SETTING BBOX TL X", bboxTL.x); - } - if (!bboxTL.y || interactor.iy < bboxTL.y) { - bboxTL.y = interactor.iy; - // console.log("SETTING BBOX TL Y", bboxTL.y); - } - if (!bboxBR.x || interactor.ix > bboxBR.x) { - bboxBR.x = interactor.ix; - // console.log("SETTING BBOX BR X", bboxBR.x); - } - if (!bboxBR.y || interactor.iy > bboxBR.y) { - bboxBR.y = interactor.iy; - // console.log("SETTING BBOX BR Y", bboxBR.y); - } - } - return interactor.ix > topLeft.x && interactor.ix < bottomRight.x && interactor.iy > topLeft.y && interactor.iy < bottomRight.y; - } - - function updateExpanding(interp) { - if (interp === 1) { // finished - tidy up - self.updateExpandedGroup(); - if (transition) { // yucky, transition is being used to indicate whether this is one interactor collapsing or from 'Collapse All' - self.controller.hiddenProteinsChanged(); - self.controller.render(); - } - self.busy = false; - return true; - } else if (interp > 1 || isNaN(interp)) { - return updateExpanding(1); - } else { - for (let i = 0; i < self.renderedParticipants.length; i++) { - const rp = self.renderedParticipants[i]; - const x = proteinXPositionInterpolations[i](cubicInOut(interp)); - const y = proteinYPositionInterpolations[i](cubicInOut(interp)); - rp.setPosition(x, y); - rp.setAllLinkCoordinates(); - } - - for (let i = 0; i < self.subgroups.length; i++) { - const sg = self.subgroups[i]; - if (!sg.expanded) { - const x = collapsedSubgroupXPositionInterpolations[i](cubicInOut(interp)); - const y = collapsedSubgroupYPositionInterpolations[i](cubicInOut(interp)); - sg.setPosition(x, y); - } else { - sg.updateExpandedGroup(); - } - } - - self.updateExpandedGroup(); - return false; - } - } - } - - hideSubgroups() { - for (let subgroup of this.subgroups) { - subgroup.setHidden(true); - } - } - - showSubgroups() { - for (let subgroup of this.subgroups) { - if (!subgroup.inCollapsedGroup()) { - subgroup.setHidden(false); - } - } - } - - // update all lines (e.g after a move) - setAllLinkCoordinates() { - for (let rp of this.renderedParticipants) { - rp.setAllLinkCoordinates(); - } - } - - // addConnectedNodes (subgraph) { - // for (let p of this.renderedParticipants) { - // for (let link of p.renderedP_PLinks.values()) { - // //visible, non-self links only - // if (link.renderedFromProtein !== link.renderedToProtein && link.isPassingFilter()) { - // if (!subgraph.links.has(link.id)) { - // subgraph.links.set(link.id, link); - // let otherEnd; - // if (link.renderedFromProtein === this) { - // otherEnd = link.renderedToProtein; - // } else { - // otherEnd = link.renderedFromProtein; - // } - // // if (otherEnd !== null) { - // const renderedOtherEnd = otherEnd.getRenderedInteractor(); - // renderedOtherEnd.subgraph = subgraph; - // //if (!subgraph.nodes.has(renderedOtherEnd.id)) { - // subgraph.nodes.set(renderedOtherEnd.id, renderedOtherEnd); - // otherEnd.subgraph = subgraph; - // otherEnd.addConnectedNodes(subgraph); - // //} - // // } - // } - // } - // } - // } - // return subgraph; - // } - - // countExternalLinks () { - // // return this.renderedP_PLinks.length; - // const renderedParticipantsLinkedTo = new Set(); - // - // for (let link of this.subgraph.links.values()) { - // const rp = link.getOtherEnd(this); - // renderedParticipantsLinkedTo.add(rp); - // } - // - // - // - // // //let countExternal = 0; - // // for (let link of this.renderedP_PLinks) { - // // if (link.crosslinks[0].isSelfLink() === false) - // // { - // // if (link.isPassingFilter()) { - // // //countExternal++; - // // renderedParticipantsLinkedTo.add(link.getOtherEnd(this).getRenderedInteractor()); - // // } - // // } - // // } - // return renderedParticipantsLinkedTo.size; - // - // } -} - - -/***/ }), - -/***/ "./crosslink-viewer/js/views/xinet/interactor/interactor.js": -/*!******************************************************************!*\ - !*** ./crosslink-viewer/js/views/xinet/interactor/interactor.js ***! - \******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ Interactor: () => (/* binding */ Interactor) -/* harmony export */ }); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! d3 */ "./node_modules/d3/d3.js"); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(d3__WEBPACK_IMPORTED_MODULE_0__); -/* harmony import */ var _trig__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../trig */ "./crosslink-viewer/js/views/xinet/trig.js"); - - - -class Interactor { - - constructor(controller) { - this.controller = controller; - this.selfLink = null; - this.parentGroups = new Set(); - - this._selected = false; - this._highlight = false; - } - - get symbolRadius() { - return 25; - } - - mouseDown(evt) { - this.controller.preventDefaultsAndStopPropagation(evt); - this.controller.d3cola.stop(); - this.controller.dragElement = this; - this.controller.dragStart = evt; - this.controller.mouseMoved = false; - return false; - } - - mouseOut() { - //this.controller.preventDefaultsAndStopPropagation(evt); // isn't stopping mouseOut in controller getting called - this.controller.model.setHighlightedProteins([]); - this.controller.model.get("tooltipModel").set("contents", null); - } - - set highlighted(show) { - if (show === true && !this._highlight) { - const d3HighSel = d3__WEBPACK_IMPORTED_MODULE_0___default().select(this.highlight); - d3HighSel - .classed("selectedProtein", false) - .classed("highlightedProtein", true) - .attr("stroke-opacity", "1"); - } else if (show === false && this._highlight) { - const d3HighSel = d3__WEBPACK_IMPORTED_MODULE_0___default().select(this.highlight); - if (!this._selected) { - d3HighSel.attr("stroke-opacity", "0"); - } - d3HighSel - .classed("selectedProtein", true) - .classed("highlightedProtein", false); - } - this._highlight = !!show; - } - - get highlighted() { - return this._highlight; - } - - set selected(select) { - const d3HighSel = d3__WEBPACK_IMPORTED_MODULE_0___default().select(this.highlight); - if (select === true && !this._selected) { - d3HighSel - .classed("selectedProtein", true) - .classed("highlightedProtein", false) - .attr("stroke-opacity", "1"); - } else if (select === false && this._selected) { - d3HighSel - .attr("stroke-opacity", "0") - .classed("selectedProtein", false) - .classed("highlightedProtein", true); - } - this._selected = !!select; - } - - get selected() { - return this._selected; - } - - getAggregateSelfLinkPath() { - const intraR = this.symbolRadius + 7; - const sectorSize = 45; - const arcStart = (0,_trig__WEBPACK_IMPORTED_MODULE_1__.trig)(intraR, 25 + sectorSize); - const arcEnd = (0,_trig__WEBPACK_IMPORTED_MODULE_1__.trig)(intraR, -25 + sectorSize); - const cp1 = (0,_trig__WEBPACK_IMPORTED_MODULE_1__.trig)(intraR, 40 + sectorSize); - const cp2 = (0,_trig__WEBPACK_IMPORTED_MODULE_1__.trig)(intraR, -40 + sectorSize); - return "M 0,0 " + - "Q " + cp1.x + "," + -cp1.y + " " + arcStart.x + "," + -arcStart.y + - " A " + intraR + " " + intraR + " 0 0 1 " + arcEnd.x + "," + -arcEnd.y + - " Q " + cp2.x + "," + -cp2.y + " 0,0"; - } - - // update all lines (e.g after a move) - setAllLinkCoordinates() { - for (let pl of this.renderedP_PLinks) { - pl.setLineCoordinates(this); - } - for (let rcl of this.renderedCrosslinks) { - rcl.setLineCoordinates(this); - } - // yes... the group-to-group links are updated separately - } - - showLabel(show) { - d3__WEBPACK_IMPORTED_MODULE_0___default().select(this.labelSVG).attr("display", show ? null : "none"); - } - - getRenderedInteractor() { - // get highest collapsed group - for (let pg of this.parentGroups.values()) { - if (!pg.expanded) { - return pg.getRenderedInteractor(); - } - } - return this; - } - - inCollapsedGroup() { - // noinspection LoopStatementThatDoesntLoopJS - for (let pg of this.parentGroups.values()) { - if (!pg.expanded) { - return true; - } - } - return false; - } - - // getSubgraph () { - // if (this.subgraph == null) { - // const subgraph = { - // nodes: new Map(), - // links: new Map() - // }; - // const thisNode = this.getRenderedInteractor(); - // subgraph.nodes.set(thisNode.id, thisNode); - // this.subgraph = this.addConnectedNodes(subgraph); - // thisNode.subgraph = subgraph; - // this.controller.subgraphs.push(subgraph); - // } - // return this.subgraph; - // } -} - - -/***/ }), - -/***/ "./crosslink-viewer/js/views/xinet/interactor/rendered-protein.js": -/*!************************************************************************!*\ - !*** ./crosslink-viewer/js/views/xinet/interactor/rendered-protein.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ RenderedProtein: () => (/* binding */ RenderedProtein) -/* harmony export */ }); -/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/modules/index-all.js"); -/* harmony import */ var _interactor__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./interactor */ "./crosslink-viewer/js/views/xinet/interactor/interactor.js"); -/* harmony import */ var _rotator__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./rotator */ "./crosslink-viewer/js/views/xinet/interactor/rotator.js"); -/* harmony import */ var _crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../crosslink-viewer-BB */ "./crosslink-viewer/js/views/xinet/crosslink-viewer-BB.js"); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! d3 */ "./node_modules/d3/d3.js"); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(d3__WEBPACK_IMPORTED_MODULE_4__); -/* harmony import */ var _xiview_js_make_tooltip__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../../../../xiview/js/make-tooltip */ "./xiview/js/make-tooltip.js"); -/* harmony import */ var _trig__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../trig */ "./crosslink-viewer/js/views/xinet/trig.js"); - - - - - - - - - -class RenderedProtein extends _interactor__WEBPACK_IMPORTED_MODULE_1__.Interactor { - - constructor(participant, controller) { - super(controller); - this.participant = participant; - this.busy = false; - this.renderedP_PLinks = []; - this.renderedCrosslinks = []; - this.parentGroups = new Set(); - // layout info - this.ix = 300; - this.iy = 40; - this.rotation = 0; - this.expanded = false; - this.hidden = false; - this.isFlipped = false; - // this.isSelected = false; - // this.isHighlighted = false; - this.createElements(); - } - - createElements() { - //'rotators' - this.lowerRotator = new _rotator__WEBPACK_IMPORTED_MODULE_2__.Rotator(this, 0, this.controller); - this.upperRotator = new _rotator__WEBPACK_IMPORTED_MODULE_2__.Rotator(this, 1, this.controller); - - /* - * Lower group - * svg group for elements that appear underneath links - */ - this.lowerGroup = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "g"); - this.lowerGroup.setAttribute("class", "protein lowerGroup"); - //make highlight - this.highlight = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "rect"); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.highlight).attr("fill-opacity", "0").attr("stroke-width", "5"); - this.lowerGroup.appendChild(this.highlight); - //make background - this.background = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "rect"); - this.lowerGroup.appendChild(this.background); - //domains in rectangle form (shown underneath links) - this.rectDomains = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "g"); - this.rectDomains.setAttribute("opacity", "0"); - this.lowerGroup.appendChild(this.rectDomains); - this.peptides = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "g"); - this.lowerGroup.appendChild(this.peptides); - - /* - * Upper group - * svg group for elements that appear above links - */ - this.upperGroup = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "g"); - this.upperGroup.setAttribute("class", "protein upperGroup"); - //svg groups for self links - this.selfLinksHighlights = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "g"); - this.selfLinks = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "g"); - this.upperGroup.appendChild(this.selfLinksHighlights); - this.upperGroup.appendChild(this.selfLinks); - - //create label - we will move this svg element around when protein form changes - this.labelSVG = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "text"); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.labelSVG).attr("text-anchor", "middle") - .attr("dominant-baseline", "middle") - .attr("fill", this.participant.is_decoy ? "#FB8072" : "black") - .attr("x", 0) - .attr("y", 0) - .classed("protein xlv_text proteinLabel", true); - this.labelTextNode = document.createTextNode(this.participant.name); - this.updateName(); - this.labelSVG.appendChild(this.labelTextNode); - - //ticks (and animo acid letters) - this.ticks = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "g"); - - //make outline - //http://stackoverflow.com/questions/17437408/how-do-i-change-a-circle-to-a-square-using-d3 - this.outline = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "rect"); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.outline).attr("stroke", "black") - .attr("stroke-width", "1") - .attr("fill", "#EEEEEE"); - this.upperGroup.appendChild(this.outline); - this.upperGroup.appendChild(this.ticks); - //domains as pie slices - shown on top of everything - this.circDomains = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "g"); - this.circDomains.setAttribute("opacity", "1"); - this.upperGroup.appendChild(this.circDomains); - this.upperGroup.appendChild(this.labelSVG); - - this.scaleLabels = []; - - this.toCircle(null, false); - - // events - const self = this; - this.upperGroup.onmousedown = function (evt) { - self.mouseDown(evt); - }; - this.upperGroup.onmouseover = function (evt) { - self.mouseOver(evt); - }; - this.upperGroup.onmouseout = function (evt) { - self.mouseOut(evt); - }; - - //going to use right click ourselves - this.upperGroup.oncontextmenu = function (evt) { - // if (evt.preventDefault) { - evt.preventDefault(); - // } - return false; - }; - } - - get proteins () { - return [this.participant]; - } - - get bBox () { - return this.upperGroup.getBBox(); - // return { - // x:this.ix - 30, - // y: this.iy - 30, - // width: this.width, - // height: this.height - // }; - } - - get width(){ - const approxLabelWidth = 10 * (this.labelText.length + 2); - if (!this.expanded) { - return (approxLabelWidth > this.symbolRadius)? approxLabelWidth : this.symbolRadius + 20;//this.upperGroup.getBBox().width + 10; - } else { - return (this.participant.size * this.stickZoom) + approxLabelWidth; - } - } - - get height () { - return 60; - } - - get symbolRadius() { - if (this.controller.fixedSize) { - return 12; - } else { - return Math.sqrt(this.participant.size / Math.PI) * 0.6; - } - } - - //when we get here all prot's have been created and defaultBarScale will have value - //this is called by loadLayout function - setEverything() { - this.busy = false; - if (!this.stickZoom) { - this.stickZoom = this.controller.defaultBarScale; - } - // this.showHighlight(this.isHighlighted); - // this.setSelected(this.isSelected); - this.setPositionFromXinet(this.ix, this.iy); - this.scale(); - this.setAllLinkCoordinates(); - if (this.newForm === true) { //hacky? - this.toStickNoTransition(); - } - } - - updateName() { - //choose label text - if (!this.controller.cropLabels) { - this.labelText = this.participant.name; - } else { - this.labelText = this.participant.name.split("_")[0]; - } - if (this.labelText.length > 25) { - this.labelText = this.labelText.substr(0, 16) + "..."; - } - this.labelTextNode.textContent = this.labelText; - } - - mouseOver(evt) { - this.controller.model.setHighlightedProteins([this.participant]); - if (!this.controller.dragElement) { - const p = this.controller.getEventPoint(evt); - this.controller.model.get("tooltipModel") - .set("header", _xiview_js_make_tooltip__WEBPACK_IMPORTED_MODULE_5__.makeTooltipTitle.interactor(this.participant)) - .set("contents", _xiview_js_make_tooltip__WEBPACK_IMPORTED_MODULE_5__.makeTooltipContents.interactor(this.participant)) - .set("location", { - pageX: p.x, - pageY: p.y - }); - } - } - - resize() { - if (!this.expanded) { - const r = this.symbolRadius; - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.outline) - .attr("x", -r).attr("y", -r) - .attr("width", r * 2).attr("height", r * 2) - .attr("rx", r).attr("ry", r); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.background) - .attr("x", -r).attr("y", -r) - .attr("width", r * 2).attr("height", r * 2) - .attr("rx", r).attr("ry", r); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.highlight) - .attr("width", (r * 2) + 5).attr("height", (r * 2) + 5) - .attr("x", -r - 2.5).attr("y", -r - 2.5) - .attr("rx", r + 2.5).attr("ry", r + 2.5); - this.labelSVG.setAttribute("transform", "translate(" + (-(r + 5)) + "," + "-5)"); - for (let ppLink of this.renderedP_PLinks) { - if (ppLink.crosslinks[0].isSelfLink() && ppLink.shown) { - ppLink.initSelfLinkSVG(); - } - } - } - } - - //only output the info needed to reproduce the layout, used by save layout function - toJSON() { - return { - id: this.participant.id, - x: this.ix, - y: this.iy, - rot: this.rotation, - expanded: this.expanded, - stickZoom: this.stickZoom, - flipped: this.isFlipped, - manuallyHidden: this.participant.manuallyHidden, - name: this.participant.name // having this here is bit of hack - }; - } - - setRotation(angle) { - this.rotation = angle % 360; - if (this.rotation < 0) { - this.rotation += 360; - } - this.upperGroup.setAttribute("transform", "translate(" + this.ix + " " + this.iy + ")" + - " scale(" + (this.controller.z) + ") " + "rotate(" + this.rotation + ")"); - this.lowerGroup.setAttribute("transform", "translate(" + this.ix + " " + this.iy + ")" + - " scale(" + (this.controller.z) + ") " + "rotate(" + this.rotation + ")"); - - const svg = this.controller.svgElement; - const transformToContainingGroup = this.labelSVG.getAttribute("transform"); - const labelTransform = d3__WEBPACK_IMPORTED_MODULE_4___default().transform(transformToContainingGroup); - const sll = this.scaleLabels.length; - if (this.rotation >= 90 && this.rotation < 270) { - const k = svg.createSVGMatrix() - .translate(Math.abs(labelTransform.translate[0]), 0) - .rotate(180, 0, 0); - this.labelSVG.transform.baseVal.initialize(svg.createSVGTransformFromMatrix(k)); - if (this.expanded) { - for (let i = 0; i < sll; i++) { - this.scaleLabels[i].setAttribute("transform", "scale(-1,1)"); - } - this.ticks.setAttribute("transform", "scale(1,-1)"); - } - } else { - const k = svg.createSVGMatrix() - .translate(-(Math.abs(labelTransform.translate[0])), 0); - this.labelSVG.transform.baseVal.initialize(svg.createSVGTransformFromMatrix(k)); - if (this.expanded) { - for (let j = 0; j < sll; j++) { - this.scaleLabels[j].setAttribute("transform", "scale(1,1)"); - } - this.ticks.setAttribute("transform", "scale(1,1)"); - } - } - } - - /* leave this.x and this.y as they were set by cola, - calculate centre of interactor's glyph, - call setPosition with those - */ - setPositionFromCola() { - this.px = this.x; - this.py = this.y; - // let xOffset = 0; - // if (!this.hidden) { // todo - hacky - // xOffset = (this.width / 2 - (this.getBlobRadius()) + 5) - // if (this.expanded) { - // xOffset = xOffset + (this.participant.size / 2 * this.stickZoom ); - // } - // } - this.setPosition(this.x /*- xOffset*/, this.y); - this.updateExpandedGroup(); - } - - /* calculate top left of interactor's glyph, - set this.x and this.y as cola would have them, - call setPosition with same params this received - */ - setPositionFromXinet(ix, iy) { - this.px = this.x; - this.py = this.y; - let xOffset = 0; - if (!this.hidden) { // todo - hacky - xOffset = (this.width / 2 - (this.symbolRadius) + 5); - // // if (this.expanded) { - // // xOffset = xOffset + (this.participant.size / 2 * this.stickZoom ); - // // } - } - this.x = ix - xOffset; - this.y = iy; - this.setPosition(ix, iy); - this.updateExpandedGroup(); - } - - // more accurately described as setting transform for top svg elements (sets scale also) - setPosition(ix, iy) { - this.ix = ix; - this.iy = iy; - if (this.expanded) { - this.upperGroup.setAttribute("transform", "translate(" + this.ix + " " + this.iy + ")" + - " scale(" + (this.controller.z) + ") " + "rotate(" + this.rotation + ")"); - this.lowerGroup.setAttribute("transform", "translate(" + this.ix + " " + this.iy + ")" + - " scale(" + (this.controller.z) + ") " + "rotate(" + this.rotation + ")"); - } else { - this.upperGroup.setAttribute("transform", "translate(" + this.ix + " " + this.iy + ")" + - " scale(" + (this.controller.z) + ") "); - this.lowerGroup.setAttribute("transform", "translate(" + this.ix + " " + this.iy + ")" + - " scale(" + (this.controller.z) + ") "); - if (this.selfLink != null) { - if (typeof this.selfLink.thickLine !== "undefined") { - this.selfLink.thickLine.setAttribute("transform", "translate(" + this.ix + - " " + this.iy + ")" + " scale(" + (this.controller.z) + ")"); - } - this.selfLink.line.setAttribute("transform", "translate(" + this.ix + - " " + this.iy + ")" + " scale(" + (this.controller.z) + ")"); - this.selfLink.highlightLine.setAttribute("transform", "translate(" + this.ix + - " " + this.iy + ")" + " scale(" + (this.controller.z) + ")"); - } - } - } - - updateExpandedGroup() { - for (let group of this.parentGroups) { - if (group.expanded && !this.hidden) { - group.updateExpandedGroup(); - } - } - } - - setStickScale(scale, svgP) { - const oldScale = this.stickZoom; - - //dist from centre - const dx = (this.ix - svgP.x); - const dy = (this.iy - svgP.y); - - // new dist from centre - const nx = dx * scale / oldScale; - const ny = dy * scale / oldScale; - - //required change - const rx = nx - dx; - let ry = ny - dy; - - if (this.rotation === 0 || this.rotation === 180) { - ry = 0; - } - - //new pos - const x = this.ix + rx; - const y = this.iy + ry; - - this.stickZoom = scale; - this.scale(); - this.setPositionFromXinet(x, y); - this.setAllLinkCoordinates(); - } - - scale() { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.peptides).attr("transform", "scale(" + (this.stickZoom) + ", 1)"); - const protLength = (this.participant.size) * this.stickZoom; - if (this.expanded) { - const labelWidth = this.labelSVG.getBBox().width; - const labelTransform = d3__WEBPACK_IMPORTED_MODULE_4___default().transform(this.labelSVG.getAttribute("transform")); - const k = this.controller.svgElement.createSVGMatrix().rotate(labelTransform.rotate) - .translate((-(((this.participant.size / 2) * this.stickZoom) + +(labelWidth / 2) + 10)), 0); - this.labelSVG.transform.baseVal.initialize(this.controller.svgElement.createSVGTransformFromMatrix(k)); - if (this.annotations) { - for (let anno of this.annotations.values()) { - const feature = anno.feature; - anno.pieSlice.setAttribute("d", this.getAnnotationRectPath(feature)); - anno.colouredRect.setAttribute("d", this.getAnnotationRectPath(feature)); - } - } - - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.outline) - .attr("width", protLength) - .attr("x", this.getResXwithStickZoom(0.5)); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.background) - .attr("width", protLength) - .attr("x", this.getResXwithStickZoom(0.5)); - - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.highlight) - .attr("width", protLength + 5) - .attr("x", this.getResXwithStickZoom(0.5) - 2.5); - - this.placeRotators(); - - for (let residueLink of this.renderedCrosslinks) { - if (residueLink.crosslink.isSelfLink() || residueLink.crosslink.isMonoLink()) { - const path = this.getCrossLinkPath(residueLink); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(residueLink.line).attr("d", path); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(residueLink.highlightLine).attr("d", path); - } - } - - this.setScaleGroup(); - this.setRotation(this.rotation); // places ticks and rotators - } - } - - placeRotators() { - //place rotators - this.lowerRotator.svg.setAttribute("transform", - "translate(" + (this.getResXwithStickZoom(0.5) - RenderedProtein.rotOffset) + " 0)"); - this.upperRotator.svg.setAttribute("transform", - "translate(" + (this.getResXwithStickZoom(this.participant.size - 0 + 0.5) + RenderedProtein.rotOffset) + " 0)"); - } - - setScaleGroup() { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.ticks).selectAll("*").remove(); - - this.scaleLabels = []; - // const ScaleMajTick = 100; - const ScaleTicksPerLabel = 2; // varies with scale? - let tick = -1; - const lastTickX = this.getResXwithStickZoom(this.participant.size); - - for (let res = 1; res <= this.participant.size; res++) { - if (res === 1 || - ((res % 100 === 0) && (200 * this.stickZoom > RenderedProtein.minXDist)) || - ((res % 10 === 0) && (20 * this.stickZoom > RenderedProtein.minXDist)) - ) { - const tx = this.getResXwithStickZoom(res); - if (this.stickZoom >= 8 || res !== 1) { - tickAt(this, tx); - } - tick = (tick + 1) % ScaleTicksPerLabel; - // does this one get a label? - if (tick === 0) { // && tx > 20) { - if ((tx + RenderedProtein.minXDist) < lastTickX) { - scaleLabelAt(this, res, tx); - } - } - } - if (this.stickZoom >= 8 && this.participant.sequence) { - const seqLabelGroup = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "g"); - seqLabelGroup.setAttribute("transform", "translate(" + this.getResXwithStickZoom(res) + " " + 0 + ")"); - const seqLabel = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "text"); - seqLabel.setAttribute("font-family", "monospace"); - seqLabel.setAttribute("font-size", "10px"); - seqLabel.setAttribute("text-anchor", "middle"); - seqLabel.setAttribute("x", "0"); - seqLabel.setAttribute("y", "3"); - seqLabel.appendChild(document.createTextNode(this.participant.sequence[res - 1])); - seqLabelGroup.appendChild(seqLabel); - this.scaleLabels.push(seqLabel); - this.ticks.appendChild(seqLabelGroup); - } - } - scaleLabelAt(this, this.participant.size, lastTickX); - if (this.stickZoom >= 8) { - tickAt(this, lastTickX); - } - - function scaleLabelAt(self, text, tickX) { - const scaleLabelGroup = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "g"); - scaleLabelGroup.setAttribute("transform", "translate(" + tickX + " " + 0 + ")"); - const scaleLabel = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "text"); - scaleLabel.setAttribute("class", "xinetAxisLabel"); - scaleLabel.setAttribute("font-family", "monospace"); - scaleLabel.setAttribute("font-size", "14"); - scaleLabel.setAttribute("text-anchor", "middle"); - scaleLabel.setAttribute("x", "0"); - scaleLabel.setAttribute("y", (RenderedProtein.STICKHEIGHT + 4).toString()); - scaleLabel.appendChild(document.createTextNode(text)); - scaleLabelGroup.appendChild(scaleLabel); - self.scaleLabels.push(scaleLabel); - self.ticks.appendChild(scaleLabelGroup); - } - - function tickAt(self, tickX) { - const tick = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "line"); - tick.setAttribute("x1", tickX); - tick.setAttribute("y1", "5"); - tick.setAttribute("x2", tickX); - tick.setAttribute("y2", "10"); - tick.setAttribute("stroke", "black"); - self.ticks.appendChild(tick); - } - } - - toggleFlipped() { - this.isFlipped = !this.isFlipped; - if (this.isFlipped) { - this.selfLinks.setAttribute("transform", "scale (1 -1)"); - this.selfLinksHighlights.setAttribute("transform", "scale (1 -1)"); - } else { - this.selfLinks.setAttribute("transform", "scale (1 1)"); - this.selfLinksHighlights.setAttribute("transform", "scale (1 1)"); - } - } - - setHidden(bool) { - // MJG - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.upperGroup).style("display", bool ? "none" : null); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.lowerGroup).style("display", bool ? "none" : null); - this.hidden = !!bool; - } - - setExpanded(expanded, svgP) { - this.controller.model.get("tooltipModel").set("contents", null); - if (this.busy !== true) { - if (expanded) { - if (this.expanded !== expanded) { - this.toStick(); - } - } else { - if (this.expanded !== expanded) { - this.toCircle(svgP); - } - } - } - } - - toCircle(svgP, transition = true) { - const transitionTime = transition ? RenderedProtein.transitionTime : 0; //this maybe isn't so good - - this.busy = true; - _crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.removeDomElement(this.lowerRotator.svg); - _crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.removeDomElement(this.upperRotator.svg); - - // const protLength = this.participant.size * this.stickZoom; - const r = this.symbolRadius; - const protColourModel = window.compositeModelInst.get("proteinColourAssignment"); - - if (transition) { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.outline).transition() - .attr("fill-opacity", 1) - .attr("fill", protColourModel.getColour(this.participant)) - .attr("x", -r).attr("y", -r) - .attr("width", r * 2).attr("height", r * 2) - .attr("rx", r).attr("ry", r) - .duration(transitionTime); - - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.background).transition() - .attr("fill-opacity", 1) - .attr("fill", protColourModel.getColour(this.participant)) - .attr("x", -r).attr("y", -r) - .attr("width", r * 2).attr("height", r * 2) - .attr("rx", r).attr("ry", r) - .duration(transitionTime); - - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.rectDomains).transition().attr("opacity", 0) - .attr("transform", "scale(1, 1)") - .duration(transitionTime); - - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.circDomains).transition().attr("opacity", 1) - .attr("transform", "scale(1, 1)") - .duration(transitionTime); - } else { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.outline) - .attr("fill-opacity", 1) - .attr("fill", protColourModel.getColour(this.participant)) - .attr("x", -r).attr("y", -r) - .attr("width", r * 2).attr("height", r * 2) - .attr("rx", r).attr("ry", r); - - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.background) - .attr("fill-opacity", 1) - .attr("fill", protColourModel.getColour(this.participant)) - .attr("x", -r).attr("y", -r) - .attr("width", r * 2).attr("height", r * 2) - .attr("rx", r).attr("ry", r); - - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.rectDomains).attr("opacity", 0) - .attr("transform", "scale(1, 1)"); - - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.circDomains).attr("opacity", 1) - .attr("transform", "scale(1, 1)"); - } - - - const stickZoomInterpol = d3__WEBPACK_IMPORTED_MODULE_4___default().interpolate(this.stickZoom, 0); - const rotationInterpol = d3__WEBPACK_IMPORTED_MODULE_4___default().interpolate((this.rotation > 180) ? this.rotation - 360 : this.rotation, 0); - //todo: should take current transform of label as start - const labelTransform = d3__WEBPACK_IMPORTED_MODULE_4___default().transform(this.labelSVG.getAttribute("transform")); - const labelStartPoint = labelTransform.translate[0]; //-(((this.participant.size / 2) * this.stickZoom) + 10); - const labelTranslateInterpol = d3__WEBPACK_IMPORTED_MODULE_4___default().interpolate(labelStartPoint, 0); //-(r + 5)); - - let xInterpol = null, - yInterpol = null; - if (typeof svgP !== "undefined" && svgP !== null) { - xInterpol = d3__WEBPACK_IMPORTED_MODULE_4___default().interpolate(this.ix, svgP.x); - yInterpol = d3__WEBPACK_IMPORTED_MODULE_4___default().interpolate(this.iy, svgP.y); - } - - const self = this; - if (transition) { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.ticks).transition().attr("opacity", 0).duration(transitionTime / 4) - .each("end", - function () { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this).selectAll("*").remove(); - } - ); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.highlight).transition() - .attr("width", (r * 2) + 5).attr("height", (r * 2) + 5) - .attr("x", -r - 2.5).attr("y", -r - 2.5) - .attr("rx", r + 2.5).attr("ry", r + 2.5) - .duration(transitionTime); - const aggSelfLinkPath = this.getAggregateSelfLinkPath(); - for (let residueLink of this.renderedCrosslinks) { - const crosslinkPath = this.getCrossLinkPath(residueLink); - const lineSel = d3__WEBPACK_IMPORTED_MODULE_4___default().select(residueLink.line); - if (residueLink.crosslink.isSelfLink()) { - lineSel.attr("d", crosslinkPath); - lineSel.transition().attr("d", aggSelfLinkPath) - .duration(transitionTime); - const highlightLineSel = d3__WEBPACK_IMPORTED_MODULE_4___default().select(residueLink.highlightLine); - highlightLineSel.attr("d", crosslinkPath); - highlightLineSel.transition().attr("d", aggSelfLinkPath) - .duration(transitionTime); - } else if (residueLink.crosslink.isMonoLink()) { - lineSel.attr("d", crosslinkPath); - lineSel.transition().attr("d", "M 0,0 L 0,0 L 0,0 L 0,0") - .duration(transitionTime); - const highlightLineSel = d3__WEBPACK_IMPORTED_MODULE_4___default().select(residueLink.highlightLine); - highlightLineSel.attr("d", crosslinkPath); - highlightLineSel.transition().attr("d", "M 0,0 L 0,0 L 0,0 L 0,0") - .duration(transitionTime); - } - } - - if (this.annotations) { - const annotArr = Array.from(this.annotations.values()); - const annotationCount = annotArr.length; - for (let a = 0; a < annotationCount; a++) { - const anno = annotArr[a], - feature = anno.feature, - pieSlice = anno.pieSlice, - rectDomain = anno.colouredRect; - if (feature.type !== RenderedProtein.disulfide) { - if (transition) { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(pieSlice).transition().attr("d", this.getAnnotationPieSliceApproximatePath(feature)) - .duration(transitionTime).each("end", - function () { - for (let b = 0; b < annotationCount; b++) { - const annoB = annotArr[b]; - if (this === annoB.pieSlice) { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this).attr("d", self.getAnnotationPieSliceArcPath(annoB.feature)); - } - } - } - ); - - d3__WEBPACK_IMPORTED_MODULE_4___default().select(rectDomain).transition().attr("d", self.getAnnotationPieSliceApproximatePath(feature)) - .duration(transitionTime); - } else { - for (let b = 0; b < annotationCount; b++) { - const annoB = annotArr[b]; - if (this === annoB.pieSlice) { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this).attr("d", self.getAnnotationPieSliceArcPath(annoB.feature)); - } - } - } - } else { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(pieSlice).transition().attr("d", this.getDisulfidAnnotationCircPath(feature)) - .duration(transitionTime); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(rectDomain).transition().attr("d", self.getDisulfidAnnotationRectPath(feature)) - .duration(transitionTime); - } - } - } - } else { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.ticks).selectAll("*").remove(); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.highlight) - .attr("width", (r * 2) + 5).attr("height", (r * 2) + 5) - .attr("x", -r - 2.5).attr("y", -r - 2.5) - .attr("rx", r + 2.5).attr("ry", r + 2.5); - } - - const originalStickZoom = this.stickZoom; - const originalRotation = this.rotation; - const cubicInOut = d3__WEBPACK_IMPORTED_MODULE_4___default().ease("cubic-in-out"); - if (transition) { - d3__WEBPACK_IMPORTED_MODULE_4___default().timer(function (elapsed) { - return update(elapsed / transitionTime); - }); - } else { - update(1); - } - - function update(interp) { - const labelTransform = d3__WEBPACK_IMPORTED_MODULE_4___default().transform(self.labelSVG.getAttribute("transform")); - const k = self.controller.svgElement.createSVGMatrix().rotate(labelTransform.rotate).translate(labelTranslateInterpol(cubicInOut(interp)), 0); - if (self.labelSVG.transform) self.labelSVG.transform.baseVal.initialize(self.controller.svgElement.createSVGTransformFromMatrix(k)); - if (xInterpol !== null) { - // noinspection JSValidateTypes - self.setPositionFromXinet(xInterpol(cubicInOut(interp)), yInterpol(cubicInOut(interp))); - } - const rot = rotationInterpol(cubicInOut(interp)); - self.stickZoom = stickZoomInterpol(cubicInOut(interp)); - self.setRotation(rot); - - self.setAllLinkCoordinates(); - - if (interp === 1) { // finished - tidy up - //bring in new - self.expanded = false; - for (let rcl of self.renderedCrosslinks) { - rcl.check(); - } - for (let pl of self.renderedP_PLinks) { - pl.update(); - } - self.stickZoom = originalStickZoom; - self.rotation = originalRotation; - self.busy = false; - - // not needed coz setPosition gets called above - // if (this.complex) { - // this.complex.updateExpandedGroup(); - // } - - return true; - } else if (interp > 1 || isNaN(interp)) { - return update(1); - } else { - return false; - } - } - } - - toStick(transition = true) { - const transitionTime = transition ? RenderedProtein.transitionTime : 0; - - this.busy = true; - this.expanded = true; - - //place rotators - this.upperGroup.appendChild(this.lowerRotator.svg); - this.upperGroup.appendChild(this.upperRotator.svg); - this.placeRotators(); - - const protLength = this.participant.size * this.stickZoom; - const r = this.symbolRadius; - - const lengthInterpol = d3__WEBPACK_IMPORTED_MODULE_4___default().interpolate((2 * r), protLength); - const stickZoomInterpol = d3__WEBPACK_IMPORTED_MODULE_4___default().interpolate(0, this.stickZoom); - const rotationInterpol = d3__WEBPACK_IMPORTED_MODULE_4___default().interpolate(0, (this.rotation > 180) ? this.rotation - 360 : this.rotation); - const labelWidth = this.labelSVG.getBBox().width; - const labelTranslateInterpol = d3__WEBPACK_IMPORTED_MODULE_4___default().interpolate(0 /*-(r + 5)*/, -(((this.participant.size / 2) * this.stickZoom) + (labelWidth / 2) + 10)); - - const origStickZoom = this.stickZoom; - this.stickZoom = 0; - this.checkLinks(); - this.stickZoom = origStickZoom; - - const protColourModel = window.compositeModelInst.get("proteinColourAssignment"); - - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.circDomains).transition().attr("opacity", 0).duration(transitionTime); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.rectDomains).transition().attr("opacity", 1).duration(transitionTime); - - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.outline).transition().attr("stroke-opacity", 1) - .attr("fill-opacity", 0) - .attr("fill", protColourModel.getColour(this.participant)) - .attr("height", RenderedProtein.STICKHEIGHT) - .attr("y", -RenderedProtein.STICKHEIGHT / 2) - .attr("rx", 0).attr("ry", 0) - .duration(transitionTime); - - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.background).transition().attr("stroke-opacity", 1) - .attr("fill", protColourModel.getColour(this.participant)) - .attr("height", RenderedProtein.STICKHEIGHT) - .attr("y", -RenderedProtein.STICKHEIGHT / 2) - .attr("rx", 0).attr("ry", 0) - .duration(transitionTime); - - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.highlight).transition() - .attr("width", protLength + 5).attr("height", RenderedProtein.STICKHEIGHT + 5) - .attr("x", this.getResXwithStickZoom(0.5) - 2.5).attr("y", (-RenderedProtein.STICKHEIGHT / 2) - 2.5) - .attr("rx", 0).attr("ry", 0) - .duration(transitionTime); - - const aggSelfLinkPath = this.getAggregateSelfLinkPath(); - for (let residueLink of this.renderedCrosslinks) { - const crosslinkPath = this.getCrossLinkPath(residueLink); - const lineSel = d3__WEBPACK_IMPORTED_MODULE_4___default().select(residueLink.line); - const highlightLineSel = d3__WEBPACK_IMPORTED_MODULE_4___default().select(residueLink.highlightLine); - if (residueLink.crosslink.isSelfLink()) { - lineSel.attr("d", aggSelfLinkPath); - lineSel.transition().attr("d", crosslinkPath) - .duration(transitionTime); - highlightLineSel.attr("d", aggSelfLinkPath); - highlightLineSel.transition().attr("d", crosslinkPath) - .duration(transitionTime); - } else if (residueLink.crosslink.isMonoLink()) { - lineSel.attr("d", "M 0,0 L 0,0 L 0,0 L 0,0"); - lineSel.transition().attr("d", crosslinkPath) - .duration(RenderedProtein.transitionTime); - highlightLineSel.attr("d", "M 0,0 L 0,0 L 0,0 L 0,0"); - highlightLineSel.transition().attr("d", crosslinkPath) - .duration(transitionTime); - } - } - - if (this.annotations) { - for (let anno of this.annotations.values()) { - const feature = anno.feature, - pieSlice = anno.pieSlice, - rectDomain = anno.colouredRect; - - if (feature.type !== RenderedProtein.disulfide) { - pieSlice.setAttribute("d", this.getAnnotationPieSliceApproximatePath(feature)); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(pieSlice).transition().attr("d", this.getAnnotationRectPath(feature)) - .duration(transitionTime); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(rectDomain).transition().attr("d", this.getAnnotationRectPath(feature)) - .duration(RenderedProtein.transitionTime); - } else { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(pieSlice).transition().attr("d", this.getDisulfidAnnotationRectPath(feature)) - .duration(transitionTime); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(rectDomain).transition().attr("d", this.getDisulfidAnnotationRectPath(feature)) - .duration(transitionTime); - - } - } - } - - const self = this; - const cubicInOut = d3__WEBPACK_IMPORTED_MODULE_4___default().ease("cubic-in-out"); - if (transition) { - d3__WEBPACK_IMPORTED_MODULE_4___default().timer(function (elapsed) { - return update(elapsed / transitionTime); - }); - } else { - update(1); - } - - //~ update(1); - - function update(interp) { - const labelTransform = d3__WEBPACK_IMPORTED_MODULE_4___default().transform(self.labelSVG.getAttribute("transform")); - const k = self.controller.svgElement.createSVGMatrix().rotate(labelTransform.rotate).translate(labelTranslateInterpol(cubicInOut(interp)), 0); - self.labelSVG.transform.baseVal.initialize(self.controller.svgElement.createSVGTransformFromMatrix(k)); - - const rot = rotationInterpol(cubicInOut(interp)); - self.setRotation(rot); - - const currentLength = lengthInterpol(cubicInOut(interp)); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(self.outline).attr("width", currentLength).attr("x", -(currentLength / 2) + (0.5 * self.stickZoom)); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(self.background).attr("width", currentLength).attr("x", -(currentLength / 2) + (0.5 * self.stickZoom)); - self.stickZoom = stickZoomInterpol(cubicInOut(interp)); - self.setAllLinkCoordinates(); - - for (let group of self.parentGroups) { - group.updateExpandedGroup(); - } - - if (interp === 1) { // finished - tidy up - self.busy = false; - return true; - } else if (interp > 1 || isNaN(interp)) { - return update(1); - } else { - return false; - } - } - - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.ticks).attr("opacity", 0); - this.setScaleGroup(); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.ticks).transition().attr("opacity", 1) - .delay(transitionTime * 0.8).duration(transitionTime / 2); - } - - toStickNoTransition() { - this.toStick(false); - } - - getCrossLinkPath(renderedCrossLink) { - const x1 = this.getResXwithStickZoom(renderedCrossLink.crosslink.fromResidue); - let baseLine = 0; - if (this.stickZoom >= 8) { - baseLine = -5; - } - - // following draws little flags - if (renderedCrossLink.crosslink.isMonoLink()) { //linker modified peptide - // if (renderedCrossLink.ambig === false) { - // renderedCrossLink.line.setAttribute("fill", "red"); //xiNET.defaultSelfLinkColour.toRGB()); - // } - const p1 = [x1, 26]; - const p3 = [x1, 18]; - const p2 = (0,_trig__WEBPACK_IMPORTED_MODULE_6__.rotatePointAboutPoint)(p1, p3, 60); - baseLine = baseLine * -1; - return "M " + x1 + "," + baseLine + - " L " + p1[0] + "," + p1[1] + - " L " + p2[0] + "," + p2[1] + - " L " + p3[0] + "," + p3[1]; - } else { - - const x2 = this.getResXwithStickZoom(renderedCrossLink.crosslink.toResidue); - let height, cp1, cp2, arcStart, arcEnd, arcRadius; - arcRadius = (Math.abs(x2 - x1)) / 2; - height = -((RenderedProtein.STICKHEIGHT / 2) + 3); - if (arcRadius < 15) { - height = -28 + arcRadius; - } - - const start = [x1, baseLine]; - const end = [x2, baseLine]; - - //~ // draws a a little triangle for *truly* intraMolecular - e.g. internally linked peptides - //~ // not in use - //~ if (renderedCrossLink.intraMolecular === true){ - //~ var curveMidX = x1 + ((x2 - x1) / 2); - //~ arcStart = [ curveMidX, height - arcRadius]; - //~ arcEnd = [ curveMidX, height - arcRadius]; - //~ cp1 = [ curveMidX, height - arcRadius]; - //~ cp2 = [ curveMidX, height - arcRadius]; - - //~ } - //~ else - if (renderedCrossLink.crosslink.confirmedHomomultimer) { - const curveMidX = x1 + ((x2 - x1) / 2); - arcStart = [curveMidX, height - arcRadius]; - arcEnd = [curveMidX, height - arcRadius]; - cp1 = (0,_trig__WEBPACK_IMPORTED_MODULE_6__.rotatePointAboutPoint)([x1, height - arcRadius], start, -20); - cp2 = (0,_trig__WEBPACK_IMPORTED_MODULE_6__.rotatePointAboutPoint)([x2, height - arcRadius], end, 20); - - //flip - start[1] = start[1] * -1; - cp1[1] = cp1[1] * -1; - arcStart[1] = arcStart[1] * -1; - arcEnd[1] = arcEnd[1] * -1; - cp2[1] = cp2[1] * -1; - end[1] = end[1] * -1; - - } else { - cp1 = [x1, height]; - cp2 = [x2, baseLine]; - arcStart = [x1, height]; - arcEnd = [x2, height]; - } - - return " M " + start[0] + "," + start[1] + - " Q " + cp1[0] + "," + cp1[1] + " " + arcStart[0] + "," + arcStart[1] + - " A " + arcRadius + "," + arcRadius + " 0 0 1 " + arcEnd[0] + "," + arcEnd[1] + - " Q " + cp2[0] + "," + cp2[1] + " " + end[0] + "," + end[1]; - - } - } - - getResXwithStickZoom(r) { - return (r - (this.participant.size / 2)) * this.stickZoom; - } - - checkLinks() { - for (let p_pLink of this.renderedP_PLinks) { - //p_pLink.check(); - p_pLink.update(); - } - for (let renderedCrosslink of this.renderedCrosslinks) { - renderedCrosslink.check(); - } - } - - clearPositionalFeatures() { - this.annotations = new Map(); - if (this.circDomains) d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.circDomains).selectAll("*").remove(); - if (this.rectDomains) d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.rectDomains).selectAll("*").remove(); - } - - setPositionalFeatures() { - this.clearPositionalFeatures(); - const annotationTypes = this.controller.model.get("annotationTypes"); - //create new annotations - - // does all of the commented out above, and picks up user-defined annotations - let featuresShown = this.controller.model.getFilteredFeatures(this.participant); - const split = underscore__WEBPACK_IMPORTED_MODULE_0__.partition(featuresShown, function (f) { - return f.type === RenderedProtein.disulfide; - }); - const disulfidBonds = split[0]; - featuresShown = split[1]; - - if (featuresShown || disulfidBonds) { - //draw longest regions first - featuresShown.sort(function (a, b) { - return (b.end - b.begin) - (a.end - a.begin); - }); - - //~ disulfidBonds.sort(function(a, b) { - //~ return b.begin - a.begin; - //~ }); - - featuresShown = featuresShown.concat(disulfidBonds); - - const fsLen = featuresShown.length; - for (let f = 0; f < fsLen; f++) { - - const anno = featuresShown[f]; - - let convStart = anno.begin; - let convEnd = anno.end; - const alignModel = this.controller.model.get("alignColl").get(this.participant.id); - let withinAlignedRange = true; - - // mjg next 5 lines - const annotationTypeModel = annotationTypes.get(annotationTypes.modelId(anno)); - const annotationTypeModelAlignmentID = annotationTypeModel ? annotationTypeModel.get("typeAlignmentID") : undefined; - const alignmentID = anno.alignmentID || annotationTypeModelAlignmentID; // individual feature alignment ids trump feature type alignment ids (needed for multiple pdb chain alignments) - // it will be undefined for annotations/annotaion types aligned to search sequence so skips the next bit - - if ( //anno.category != "AA" // this handles not aligning certain features, todo; check for tidier way - alignmentID && alignModel) { - //var alignmentID = anno.alignmentID || "Canonical"; - const conv = alignModel.rangeToSearch(alignmentID, anno.begin, anno.end); - if (conv) { - convStart = conv[0]; - convEnd = conv[1]; - } else { - withinAlignedRange = false; // when conv returns null - } - } - //TODO: tooltip requring these to be written into feature object, seems wrong? - anno.fstart = +convStart; // + to convert to number - anno.fend = +convEnd; - - const fid = anno.category + "-" + anno.type + "-" + anno.alignmentID + "[" + convStart + " - " + convEnd + "]"; - - if (withinAlignedRange) { - const pieSlice = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "path"); - const colouredRect = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_3__.CrosslinkViewer.svgns, "path"); - if (anno.type !== RenderedProtein.disulfide) { - //if (anno.type != "disulfide bond") { - if (!this.expanded) { - pieSlice.setAttribute("d", this.getAnnotationPieSliceArcPath(anno)); - colouredRect.setAttribute("d", this.getAnnotationPieSliceApproximatePath(anno)); - } else { - pieSlice.setAttribute("d", this.getAnnotationRectPath(anno)); - colouredRect.setAttribute("d", this.getAnnotationRectPath(anno)); - } - pieSlice.setAttribute("stroke-width", "1"); - pieSlice.setAttribute("fill-opacity", "0.5"); - colouredRect.setAttribute("stroke-width", "1"); - colouredRect.setAttribute("fill-opacity", "0.5"); - - const c = annotationTypes.getColour(anno.category, anno.type); // domainColours(anno.category, anno.type); - pieSlice.setAttribute("fill", c); - pieSlice.setAttribute("stroke", c); - colouredRect.setAttribute("fill", c); - colouredRect.setAttribute("stroke", c); - } else { - - if (!this.expanded) { - pieSlice.setAttribute("d", this.getDisulfidAnnotationCircPath(anno)); - colouredRect.setAttribute("d", this.getDisulfidAnnotationCircPath(anno)); - } else { - pieSlice.setAttribute("d", this.getDisulfidAnnotationRectPath(anno, f)); - colouredRect.setAttribute("d", this.getDisulfidAnnotationRectPath(anno, f)); - } - pieSlice.setAttribute("stroke-width", "1"); - colouredRect.setAttribute("stroke-width", "1"); - - const c = annotationTypes.getColour(anno.category, anno.type); // domainColours(anno.category, anno.type); - pieSlice.setAttribute("fill", "none"); - pieSlice.setAttribute("stroke", c); - colouredRect.setAttribute("fill", "none"); - colouredRect.setAttribute("stroke", c); - } - - pieSlice.setAttribute("data-feature", fid); - - const self = this; - - //only needs tooltip on pie slice, its always on top even if transparent - pieSlice.onmouseover = function (evt) { - self.controller.preventDefaultsAndStopPropagation(evt); - const feature = self.annotations.get(evt.target.getAttribute("data-feature")).feature; - self.controller.model.get("tooltipModel") - //.set("header", d.id.replace("_", " ")) - .set("header", _xiview_js_make_tooltip__WEBPACK_IMPORTED_MODULE_5__.makeTooltipTitle.feature()) - .set("contents", - _xiview_js_make_tooltip__WEBPACK_IMPORTED_MODULE_5__.makeTooltipContents.feature(feature) - ) - .set("location", { - pageX: evt.pageX, - pageY: evt.pageY - }); - }; - - this.annotations.set(fid, { - feature: anno, - pieSlice: pieSlice, - colouredRect: colouredRect - }); - this.circDomains.appendChild(pieSlice); - this.rectDomains.appendChild(colouredRect); - } - } - } - } - - getAnnotationPieSliceArcPath(annotation) { - let startAngle = ((annotation.fstart - 1) / this.participant.size) * 360; - let endAngle = (annotation.fend / this.participant.size) * 360; - //just in case - if (startAngle > endAngle) { - const temp = startAngle; - startAngle = endAngle; - endAngle = temp; - } - let largeArcFlag = 0, - sweepFlag = 1; - if ((endAngle - startAngle) > 180) { //|| (endAngle - startAngle) == 0) { - largeArcFlag = 1; - } - //hacky - //actually its not clear there is better solution - - // https://stackoverflow.com/questions/5737975/circle-drawing-with-svgs-arc-path - if (annotation.fstart === 1 && annotation.fend === this.participant.size) { - startAngle = 0.1; - endAngle = 359.9; - sweepFlag = 1; - } - - const radius = this.symbolRadius - 2; - const arcStart = (0,_trig__WEBPACK_IMPORTED_MODULE_6__.trig)(radius, startAngle - 90); - const arcEnd = (0,_trig__WEBPACK_IMPORTED_MODULE_6__.trig)(radius, endAngle - 90); - return "M0,0 L" + arcStart.x + "," + arcStart.y + " A" + radius + "," + - radius + " 0 " + largeArcFlag + " " + sweepFlag + " " + arcEnd.x + "," + arcEnd.y + " Z"; - } - - getAnnotationPieSliceApproximatePath(annotation) { - //approximate pie slice - const startAngle = ((annotation.fstart - 1) / this.participant.size) * 360; - const endAngle = ((annotation.fend) / this.participant.size) * 360; - const pieRadius = this.symbolRadius - 2; - let approximatePiePath = "M 0,0"; - const stepsInArc = 5; - for (let sia = 0; sia <= RenderedProtein.stepsInArc; sia++) { - const angle = startAngle + ((endAngle - startAngle) * (sia / stepsInArc)); - const siaCoord = (0,_trig__WEBPACK_IMPORTED_MODULE_6__.trig)(pieRadius, angle - 90); - approximatePiePath += " L " + siaCoord.x + "," + siaCoord.y; - } - approximatePiePath += " L " + 0 + "," + 0; - approximatePiePath += " Z"; - return approximatePiePath; - } - - getAnnotationRectPath(annotation) { - //domain as rectangular path - const bottom = RenderedProtein.STICKHEIGHT / 2, - top = -RenderedProtein.STICKHEIGHT / 2; - const annotX = this.getResXwithStickZoom(annotation.fstart - 0.5); - const annotSize = (1 + (annotation.fend - annotation.fstart)); - const annotLength = annotSize * this.stickZoom; - let rectPath = "M " + annotX + "," + bottom; - for (let sia = 0; sia <= RenderedProtein.stepsInArc; sia++) { - const step = annotX + (annotLength * (sia / RenderedProtein.stepsInArc)); - rectPath += " L " + step + "," + top; - } - rectPath += " L " + (annotX + annotLength) + "," + bottom + - " Z"; - return rectPath; - } - - getDisulfidAnnotationRectPath(annotation/*, index*/) { - let bottom = RenderedProtein.STICKHEIGHT / 2, - top = 1.5 * bottom; - bottom = bottom - 5; - - const annotX = this.getResXwithStickZoom(annotation.fstart - 0.5); - const annotSize = (1 + (annotation.fend - annotation.fstart)); - - // const level = annotSize / 20; - top += annotSize * bottom / 30; - - - const annotLength = annotSize * this.stickZoom; - let rectPath = "M " + annotX + "," + bottom; - rectPath += " L " + annotX + "," + top; - rectPath += " L " + (annotX + annotLength) + "," + top; - rectPath += " L " + (annotX + annotLength) + "," + bottom; - return rectPath; - } - - getDisulfidAnnotationCircPath(/*annotation*/) { - return "M 0,0 L 0,0 L 0,0 L 0,0 "; - } - - get id () { - return this.participant.id; - } - - // addConnectedNodes (subgraph) { - // for (let link of this.renderedP_PLinks.values()) { - // //visible, non-self links only - // if (link.renderedFromProtein !== link.renderedToProtein && link.isPassingFilter()) { - // if (!subgraph.links.has(link.id)) { - // subgraph.links.set(link.id, link); - // let otherEnd; - // if (link.renderedFromProtein === this) { - // otherEnd = link.renderedToProtein; - // } else { - // otherEnd = link.renderedFromProtein; - // } - // // if (otherEnd !== null) { - // const renderedOtherEnd = otherEnd.getRenderedInteractor(); - // renderedOtherEnd.subgraph = subgraph; - // //if (!subgraph.nodes.has(renderedOtherEnd.id)) { - // subgraph.nodes.set(renderedOtherEnd.id, renderedOtherEnd); - // otherEnd.subgraph = subgraph; - // otherEnd.addConnectedNodes(subgraph); - // //} - // // } - // } - // } - // } - // return subgraph; - // } - // - // - // countExternalLinks () { - // // return this.renderedP_PLinks.length; - // const renderedParticipantsLinkedTo = new Set(); - // //let countExternal = 0; - // for (let link of this.renderedP_PLinks) { - // if (link.crosslinks[0].isSelfLink() === false) { - // if (link.isPassingFilter()) { - // //countExternal++; - // renderedParticipantsLinkedTo.add(link.getOtherEnd(this).getRenderedInteractor()); - // } - // } - // } - // return renderedParticipantsLinkedTo.size; - // - // } - -} - -RenderedProtein.STICKHEIGHT = 20; // height of stick in pixels -RenderedProtein.LABELMAXLENGTH = 60; // maximal width reserved for protein-labels -RenderedProtein.transitionTime = 650; -RenderedProtein.stepsInArc = 5; -RenderedProtein.rotOffset = 25 * 0.7; // see xiNET.Rotator.js -RenderedProtein.minXDist = 30; -RenderedProtein.disulfide = "disulfide bond"; - - -/***/ }), - -/***/ "./crosslink-viewer/js/views/xinet/interactor/rotator.js": -/*!***************************************************************!*\ - !*** ./crosslink-viewer/js/views/xinet/interactor/rotator.js ***! - \***************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ Rotator: () => (/* binding */ Rotator) -/* harmony export */ }); -/* harmony import */ var _crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../crosslink-viewer-BB */ "./crosslink-viewer/js/views/xinet/crosslink-viewer-BB.js"); - - -class Rotator { - constructor(protein, upperOrLower, controller) { - const self = this; - this.controller = controller; - this.protein = protein; - this.upperOrLower = upperOrLower; - - const RADIUS = 14; - const SYMBOL_RADIUS = 20; // not really, gets scaled down - - this.svg = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_0__.CrosslinkViewer.svgns, "g"); - this.rotatorSymbol = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_0__.CrosslinkViewer.svgns, "g"); - - const rotatorCircle = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_0__.CrosslinkViewer.svgns, "circle"); - rotatorCircle.setAttribute("r", "" + RADIUS); - rotatorCircle.setAttribute("stroke", "none"); - rotatorCircle.setAttribute("fill", "gray"); - rotatorCircle.setAttribute("fill-opacity", "0.0"); - this.svg.appendChild(rotatorCircle); - - const symbolCircle = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_0__.CrosslinkViewer.svgns, "circle"); - symbolCircle.setAttribute("r", "" + SYMBOL_RADIUS); - symbolCircle.setAttribute("stroke", "black"); - symbolCircle.setAttribute("stroke-width", "1"); - symbolCircle.setAttribute("fill", "none"); - this.rotatorSymbol.appendChild(symbolCircle); - - const arrow1 = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_0__.CrosslinkViewer.svgns, "path"); - arrow1.setAttribute("d", "M 19.818182,-3 L 16,3.10345 L 23.636363,3.10345 L 19.818182,-3 z "); - arrow1.setAttribute("stroke", "black"); - arrow1.setAttribute("stroke-width", "1"); - arrow1.setAttribute("fill", "black"); - - this.rotatorSymbol.appendChild(arrow1); - const arrow2 = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_0__.CrosslinkViewer.svgns, "path"); - arrow2.setAttribute("d", "M 19.818182,-3 L 16,3.10345 L 23.636363,3.10345 L 19.818182,-3 z "); - arrow2.setAttribute("stroke", "black"); - arrow2.setAttribute("stroke-width", "1"); - arrow2.setAttribute("fill", "black"); - arrow2.setAttribute("transform", "rotate(180)"); - this.rotatorSymbol.appendChild(arrow2); - this.rotatorSymbol.setAttribute("transform", "rotate(45) scale (0.7, 0.7)"); - - this.rotatorSymbol.setAttribute("display", "none"); - - this.inner = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_0__.CrosslinkViewer.svgns, "g"); - this.inner.setAttribute("class", "PV_rotator"); - this.inner.appendChild(this.rotatorSymbol); - - this.svg.appendChild(this.inner); - - this.svg.onmouseover = function (evt) { - self.rotatorMouseOver(evt); - }; - this.svg.onmouseout = function (evt) { - self.rotatorMouseOut(evt); - }; - this.svg.onmousedown = function (evt) { - self.rotatorMouseDown(evt); - }; - } - - rotatorMouseOver() { - this.rotatorSymbol.setAttribute("display", "block"); - } - - rotatorMouseOut() { - this.rotatorSymbol.setAttribute("display", "none"); - } - - rotatorMouseDown() { - this.controller.state = _crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_0__.CrosslinkViewer.STATES.ROTATING; - this.controller.dragElement = this.protein; - this.controller.whichRotator = this.upperOrLower; - } -} - -/***/ }), - -/***/ "./crosslink-viewer/js/views/xinet/link/g_g-link.js": -/*!**********************************************************!*\ - !*** ./crosslink-viewer/js/views/xinet/link/g_g-link.js ***! - \**********************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ G_GLink: () => (/* binding */ G_GLink) -/* harmony export */ }); -/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/modules/index-all.js"); -/* harmony import */ var _link__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./link */ "./crosslink-viewer/js/views/xinet/link/link.js"); -/* harmony import */ var _crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../crosslink-viewer-BB */ "./crosslink-viewer/js/views/xinet/crosslink-viewer-BB.js"); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! d3 */ "./node_modules/d3/d3.js"); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(d3__WEBPACK_IMPORTED_MODULE_3__); - - - - - -class G_GLink extends _link__WEBPACK_IMPORTED_MODULE_1__.Link { - - constructor(id, group1, group2, crosslinkViewer) { - super(crosslinkViewer); - - this.id = id; - this.isAggregateLink = true; - - this.p_pLinks = new Map(); - this.group1 = group1; - this.group2 = group2; - } - - getCrosslinks() { - let allCrosslinks = []; - for (let pp of this.p_pLinks.values()) { - allCrosslinks = allCrosslinks.concat(pp.crosslinks); - } - return allCrosslinks; - } - - initSVG() { - if (this.group1 !== this.group2) { - this.line = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.svgns, "line"); - this.highlightLine = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.svgns, "line"); - this.thickLine = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.svgns, "line"); - } else { - this.group1.selfLink = this; - - this.line = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.svgns, "path"); - this.highlightLine = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.svgns, "path"); - this.thickLine = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.svgns, "path"); - - this.initSelfLinkSVG(); - } - - this.line.setAttribute("class", "link"); - this.line.setAttribute("fill", "none"); - this.line.setAttribute("stroke-width", _crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.linkWidth); - this.line.setAttribute("stroke-linecap", "round"); - - this.highlightLine.setAttribute("class", "link highlightedLink"); - this.highlightLine.setAttribute("fill", "none"); - this.highlightLine.setAttribute("stroke-width", "10"); - this.highlightLine.setAttribute("stroke-linecap", "round"); - this.highlightLine.setAttribute("stroke-opacity", "0"); - - this.thickLine.setAttribute("class", "link"); - this.thickLine.setAttribute("fill", "none"); - this.thickLine.setAttribute("stroke", "#ddd"); - this.thickLine.setAttribute("stroke-linecap", "round"); - this.thickLine.setAttribute("stroke-linejoin", "round"); - - this.controller.p_pLinksWide.appendChild(this.thickLine); - this.controller.highlights.appendChild(this.highlightLine); - this.controller.p_pLinks.appendChild(this.line); - - //set the events for it - const self = this; - const setMouseEvents = function (svgElement) { - svgElement.onmousedown = function (evt) { - self.mouseDown(evt); - }; - svgElement.onmouseover = function (evt) { - self.mouseOver(evt); - }; - svgElement.onmouseout = function (evt) { - self.mouseOut(evt); - }; - // this.line.ontouchstart = function(evt) { - // self.touchStart(evt); - // }; - svgElement.oncontextmenu = function () { - return false; - }; - }; - setMouseEvents(this.line); - setMouseEvents(this.highlightLine); - setMouseEvents(this.thickLine); - } - - mouseOver(evt) { - const p = this.controller.getEventPoint(evt); - let allCrosslinks = []; - this.filteredCrosslinkCount = 0; - let filteredMatchCount = 0; - let ppiCount = 0; - for (let pp of this.p_pLinks.values()) { - if (pp.filteredCrossLinkCount > 0) { - allCrosslinks = allCrosslinks.concat(pp.crosslinks); - ppiCount++; - this.filteredCrosslinkCount += pp.filteredCrossLinkCount; - filteredMatchCount += pp.filteredMatchCount; - } - } - this.controller.model.setMarkedCrossLinks("highlights", allCrosslinks, true, false); - this.controller.model.get("tooltipModel") - //TODO - reuse other multiLink tooltips in CLM-UI? - .set("header", "Group to Group Links") - .set("contents", [ - ["From", this.group1.name], - ["To", this.group2.name], - ["PPI count", ppiCount], - ["Unique Linked Residue Pairs", this.filteredCrosslinkCount], - ["Matches", filteredMatchCount ? filteredMatchCount : "filter not yet applied"] - //highest score - ]) - .set("location", { - pageX: p.x, - pageY: p.y - }); - } - - // event handler for starting dragging or rotation (or flipping internal links) - mouseDown(evt) { - this.controller.d3cola.stop(); - let allCrosslinks = []; - for (let pp of this.p_pLinks.values()) { - allCrosslinks = allCrosslinks.concat(pp.crosslinks); - } - this.controller.dragElement = this; - if (evt.shiftKey || evt.ctrlKey) { - let selection = this.controller.model.get("selection"); - if (this.isSelected) { - selection = selection.filter(function (d) { - return allCrosslinks.indexOf(d) === -1; - }); - } else { - selection = selection.concat(allCrosslinks); - } - this.controller.model.setMarkedCrossLinks("selection", selection); - } else { - this.controller.model.setMarkedCrossLinks("selection", underscore__WEBPACK_IMPORTED_MODULE_0__.clone(allCrosslinks)); - } - //store start location - this.controller.dragStart = evt; - d3__WEBPACK_IMPORTED_MODULE_3___default().select(".custom-menu-margin").style("display", "none"); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(".group-custom-menu-margin").style("display", "none"); - } - - /*xiNET.P_PLink.prototype.touchStart = function(evt) { - this.controller.d3cola.stop(); - this.controller.dragElement = this; - this.controller.model.setMarkedCrossLinks("selection", this.crosslinks); - //store start location - //var p = this.controller.getTouchEventPoint(evt);// oh dear, now broken - this.controller.dragStart = evt; - }*/ - - initSelfLinkSVG() { - const path = this.group1.getAggregateSelfLinkPath(); - this.line.setAttribute("d", path); - this.highlightLine.setAttribute("d", path); - this.thickLine.setAttribute("d", path); - } - - checkHighlight() { - for (let pp of this.p_pLinks.values()) { - // if (pp.filteredCrossLinkCount > 0) { ? // shouldn't be needed - if (pp.isHighlighted) { - this.showHighlight(true); - return; - } - } - this.showHighlight(false); - } - - checkSelected() { - for (let pp of this.p_pLinks.values()) { - // if (pp.filteredCrossLinkCount > 0) { ? // shouldn't be needed - if (pp.isSelected) { - this.setSelected(true); - return; - } - } - this.setSelected(false); - } - - showHighlight(show) { - if (this.shown) { - if (show) { - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).classed("selectedLink", false); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).classed("highlightedLink", true); - this.highlightLine.setAttribute("stroke-opacity", "1"); - } else { - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).classed("selectedLink", true); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).classed("highlightedLink", false); - if (this.isSelected === false) { - this.highlightLine.setAttribute("stroke-opacity", "0"); - } - } - } - } - - setSelected(select) { - if (this.shown) { - if (select === true) { - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).classed("selectedLink", true); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).classed("highlightedLink", false); - this.highlightLine.setAttribute("stroke-opacity", "1"); - } else { - this.highlightLine.setAttribute("stroke-opacity", "0"); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).classed("selectedLink", false); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).classed("highlightedLink", true); - } - } - this.isSelected = select; - } - - check() { - for (let pp of this.p_pLinks.values()) { - if (pp.filteredCrossLinkCount > 0) { - return true; - } - } - return false; - } - - // xiNET.P_PLink.prototype.check = function () { - // // this.ambiguous = true; // todo - looks like this could be removed - // this.hd = false; - // - // const filteredCrossLinks = new Set(); - // const filteredMatches = new Set(); - // const altP_PLinks = new Set(); - // - // // this.colours.clear(); - // - // for (let crosslink of this.crosslinks) { - // - // if (crosslink.filteredMatches_pp.length > 0) { - // filteredCrossLinks.add(crosslink.id); - // // this.colours.add(window.compositeModelInst.get("linkColourAssignment").getColour(crosslink)); - // } - // - // for (let m of crosslink.filteredMatches_pp) { - // // i think there's a performance improvement to be had here - // const match = m.match; // oh dear, this... - // filteredMatches.add(match.id); - // if (match.hd === true) { - // this.hd = true; - // } - // if (match.crosslinks.length === 1) { - // // this.ambiguous = false; //yeah... whats this doing when this.ambiguous gets set later, just before end of function - // } else { - // for (let matchCrossLink of match.crosslinks) { - // if (!matchCrossLink.isDecoyLink()) { - // altP_PLinks.add(matchCrossLink.p_pLink.id); - // } - // } - // } - // } - // } - // - // this.filteredMatchCount = filteredMatches.size; - // this.filteredCrossLinkCount = filteredCrossLinks.size; - // if (this.filteredCrossLinkCount > 0) { - // this.ambiguous = altP_PLinks.size > 1; - // } - // return this.filteredCrossLinkCount; - // }; - - // xiNET.P_PLink.prototype.update = function () { - // if (!this.renderedToProtein || // todo - ok... check why this is here - // //hide if prot either end is hidden - // this.renderedFromProtein.participant.hidden || - // this.renderedToProtein.participant.hidden || - // // or either end is expanded to bar and not in collapsed group - // (this.renderedFromProtein.expanded && !this.renderedFromProtein.inCollapsedGroup()) || - // (this.renderedToProtein.expanded && !this.renderedToProtein.inCollapsedGroup()) || - // // or no matches pass filter - // this.filteredCrossLinkCount === 0 || - // // or is self link in collapsed group - // (this.crosslinks[0].isSelfLink() && this.renderedFromProtein.inCollapsedGroup())) { - // this.hide(); - // } else { - // - // // if (both ends in collapsed groups) { - // // - // // } - // // - // this.show(); - // } - // } - - show() { - //if (!this.shown) { - causing problems with load layout, TODO - look at again - if (typeof this.line === "undefined") { - this.initSVG(); - } - this.shown = true; - if (this.group1 === this.group2) { - this.thickLine.setAttribute("transform", "translate(" + - this.group1.ix + " " + this.group2.iy + ")" // possibly not neccessary - + - " scale(" + (this.controller.z) + ")"); - this.line.setAttribute("transform", "translate(" + this.group1.ix + - " " + this.group1.iy + ")" + " scale(" + (this.controller.z) + ")"); - this.highlightLine.setAttribute("transform", "translate(" + this.group1.ix + - " " + this.group1.iy + ")" + " scale(" + (this.controller.z) + ")"); - - } else { - this.line.setAttribute("stroke-width", (this.controller.z * _crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.linkWidth).toString()); - this.highlightLine.setAttribute("stroke-width", (this.controller.z * 10).toString()); - this.setLineCoordinates(); - } - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.thickLine).style("display", null); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.line).style("display", null); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).style("display", null); - //} - - if (this.controller.model.get("xinetThickLinks") === false) { - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.thickLine).style("display", "none"); - } else { - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.thickLine).style("display", null); - this.updateThickLineWidth(); - } - - // this.dashedLine(this.ambiguous); - - this.line.setAttribute("stroke", window.compositeModelInst.get("linkColourAssignment").getColour(this)); - - this.setSelected(this.isSelected); - } - - updateThickLineWidth() { - const steps = this.controller.model.get("xinetPpiSteps"); - - let thickLineWidth; - if (this.filteredCrosslinkCount < steps[0]) { - thickLineWidth = 1; - } else if (this.filteredCrosslinkCount < steps[1]) { - thickLineWidth = 5; - } else { - thickLineWidth = 10; - } - if (this.group1 === this.group2) { - this.thickLine.setAttribute("stroke-width", thickLineWidth); - } else { - this.thickLine.setAttribute("stroke-width", (this.controller.z * thickLineWidth).toString()); - } - } - - hide() { - // if (this.shown) { - // this.shown = false; - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.thickLine).style("display", "none"); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).style("display", "none"); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.line).style("display", "none"); - // } - } - - setLineCoordinates() { - if (this.group1 !== this.group2) { - if (this.shown) { - const source = this.group1;//.getRenderedInteractor(); - const target = this.group2;//renderedToProtein.getRenderedInteractor(); - if (!source.ix || !source.iy) { - console.log("NOT"); - } - - // if (this.renderedFromProtein === participant) { - this.line.setAttribute("x1", source.ix); - this.line.setAttribute("y1", source.iy); - this.highlightLine.setAttribute("x1", source.ix); - this.highlightLine.setAttribute("y1", source.iy); - this.thickLine.setAttribute("x1", source.ix); - this.thickLine.setAttribute("y1", source.iy); - // } else if (this.renderedToProtein === participant) { - this.line.setAttribute("x2", target.ix); - this.line.setAttribute("y2", target.iy); - this.highlightLine.setAttribute("x2", target.ix); - this.highlightLine.setAttribute("y2", target.iy); - this.thickLine.setAttribute("x2", target.ix); - this.thickLine.setAttribute("y2", target.iy); - // } - } - } - } -} - -/* -xiNET.P_PLink.prototype.getOtherEnd = function(protein) { - if (this.fromProtein === protein) { - return this.toProtein; - } else { - return this.fromProtein; - } -};*/ - - -/***/ }), - -/***/ "./crosslink-viewer/js/views/xinet/link/link.js": -/*!******************************************************!*\ - !*** ./crosslink-viewer/js/views/xinet/link/link.js ***! - \******************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ Link: () => (/* binding */ Link) -/* harmony export */ }); -class Link { - - constructor(crosslinkViewer) { - this.controller = crosslinkViewer; - this.shown = false; //used to avoid some unnecessary manipulation of DOM - this.isSelected = false; - } - - mouseOut() { - this.controller.model.setMarkedCrossLinks("highlights", []); // which pokes highlighted matches into changing too - this.controller.model.get("tooltipModel").set("contents", null); - } - - dashedLine(dash) { - if (this.shown) { - if (dash) { - if (this.renderedFromProtein === this.renderedToProtein) { - this.line.setAttribute("stroke-dasharray", (4) + ", " + (4)); - } else { - this.line.setAttribute("stroke-dasharray", (4 * this.controller.z) + ", " + (4 * this.controller.z)); - } - } else { - this.line.removeAttribute("stroke-dasharray"); - } - } - } -} - - -/***/ }), - -/***/ "./crosslink-viewer/js/views/xinet/link/p_p-link.js": -/*!**********************************************************!*\ - !*** ./crosslink-viewer/js/views/xinet/link/p_p-link.js ***! - \**********************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ P_PLink: () => (/* binding */ P_PLink) -/* harmony export */ }); -/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/modules/index-all.js"); -/* harmony import */ var _link__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./link */ "./crosslink-viewer/js/views/xinet/link/link.js"); -/* harmony import */ var _crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../crosslink-viewer-BB */ "./crosslink-viewer/js/views/xinet/crosslink-viewer-BB.js"); -/* harmony import */ var _g_g_link__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./g_g-link */ "./crosslink-viewer/js/views/xinet/link/g_g-link.js"); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! d3 */ "./node_modules/d3/d3.js"); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(d3__WEBPACK_IMPORTED_MODULE_4__); - - - - - - - -class P_PLink extends _link__WEBPACK_IMPORTED_MODULE_1__.Link { - - constructor(p_pId, crosslink, crosslinkViewer) { - super(crosslinkViewer); - this.isAggregateLink = true; - this.id = p_pId; - this.crosslinks = []; - this.renderedFromProtein = this.controller.renderedProteins.get(crosslink.fromProtein.id); - this.renderedFromProtein.renderedP_PLinks.push(this); - if (crosslink.toProtein) { - this.renderedToProtein = this.controller.renderedProteins.get(crosslink.toProtein.id); - this.renderedToProtein.renderedP_PLinks.push(this); - } - } - - getCrosslinks() { - return this.crosslinks; - } - - initSVG() { - if (this.crosslinks[0].isSelfLink() === false) { - this.line = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.svgns, "line"); - this.highlightLine = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.svgns, "line"); - this.thickLine = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.svgns, "line"); - } else { - this.renderedFromProtein.selfLink = this; - - this.line = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.svgns, "path"); - this.highlightLine = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.svgns, "path"); - this.thickLine = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.svgns, "path"); - - this.initSelfLinkSVG(); - } - - this.line.setAttribute("class", "link"); - this.line.setAttribute("fill", "none"); - this.line.setAttribute("stroke-width", _crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.linkWidth); - this.line.setAttribute("stroke-linecap", "round"); - - this.highlightLine.setAttribute("class", "link highlightedLink"); - this.highlightLine.setAttribute("fill", "none"); - this.highlightLine.setAttribute("stroke-width", "10"); - this.highlightLine.setAttribute("stroke-linecap", "round"); - this.highlightLine.setAttribute("stroke-opacity", "0"); - - this.thickLine.setAttribute("class", "link"); - this.thickLine.setAttribute("fill", "none"); - this.thickLine.setAttribute("stroke", "#ddd"); - this.thickLine.setAttribute("stroke-linecap", "round"); - this.thickLine.setAttribute("stroke-linejoin", "round"); - - this.controller.p_pLinksWide.appendChild(this.thickLine); - this.controller.highlights.appendChild(this.highlightLine); - this.controller.p_pLinks.appendChild(this.line); - - //set the events for it - const self = this; - const setMouseEvents = function (svgElement) { - svgElement.onmousedown = function (evt) { - self.mouseDown(evt); - }; - svgElement.onmouseover = function (evt) { - self.mouseOver(evt); - }; - svgElement.onmouseout = function (evt) { - self.mouseOut(evt); - }; - // this.line.ontouchstart = function(evt) { - // self.touchStart(evt); - // }; - svgElement.oncontextmenu = function () { - return false; - }; - }; - setMouseEvents(this.line); - setMouseEvents(this.highlightLine); - setMouseEvents(this.thickLine); - } - - mouseOver(evt) { - const p = this.controller.getEventPoint(evt); - const toHighlight = this.crosslinks.slice(0); - this.controller.model.setMarkedCrossLinks("highlights", toHighlight, true, false); - this.controller.model.get("tooltipModel") - .set("header", "Linked Protein Pair") - .set("contents", [ - ["From", this.renderedFromProtein.participant.name], - ["To", this.renderedToProtein.participant.name], - ["Unique Linked Residue Pairs", this.filteredCrossLinkCount ? this.filteredCrossLinkCount : "filter not yet applied"], - ["Matches", this.filteredMatchCount ? this.filteredMatchCount : "filter not yet applied"] - //highest score - ]) - .set("location", { - pageX: p.x, - pageY: p.y - }); - } - - // event handler for starting dragging or rotation (or flipping internal links) - mouseDown(evt) { - //stop layout - this.controller.d3cola.stop(); - - this.controller.dragElement = this; - if (evt.shiftKey || evt.ctrlKey) { - let selection = this.controller.model.get("selection"); - if (this.isSelected) { - const self = this; - selection = selection.filter(function (d) { - return self.crosslinks.indexOf(d) === -1; - }); - } else { - selection = selection.concat(this.crosslinks); - } - this.controller.model.setMarkedCrossLinks("selection", selection); - } else { - this.controller.model.setMarkedCrossLinks("selection", underscore__WEBPACK_IMPORTED_MODULE_0__.clone(this.crosslinks)); - } - - //store start location - this.controller.dragStart = evt; - - d3__WEBPACK_IMPORTED_MODULE_4___default().select(".custom-menu-margin").style("display", "none"); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(".group-custom-menu-margin").style("display", "none"); - } - - /*xiNET.P_PLink.prototype.touchStart = function(evt) { - this.controller.d3cola.stop(); - this.controller.dragElement = this; - this.controller.model.setMarkedCrossLinks("selection", this.crosslinks); - //store start location - //var p = this.controller.getTouchEventPoint(evt);// oh dear, now broken - this.controller.dragStart = evt; - }*/ - - initSelfLinkSVG() { - const path = this.renderedFromProtein.getAggregateSelfLinkPath(); - this.line.setAttribute("d", path); - this.highlightLine.setAttribute("d", path); - this.thickLine.setAttribute("d", path); - } - - showHighlight(show) { - if (this.shown) { - if (show) { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.highlightLine).classed("selectedLink", false); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.highlightLine).classed("highlightedLink", true); - this.highlightLine.setAttribute("stroke-opacity", "1"); - } else { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.highlightLine).classed("selectedLink", true); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.highlightLine).classed("highlightedLink", false); - if (this.isSelected === false) { - this.highlightLine.setAttribute("stroke-opacity", "0"); - } - } - } - this.isHighlighted = show; - } - - setSelected(select) { - if (this.shown) { - if (select === true) { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.highlightLine).classed("selectedLink", true); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.highlightLine).classed("highlightedLink", false); - this.highlightLine.setAttribute("stroke-opacity", "1"); - } else { - this.highlightLine.setAttribute("stroke-opacity", "0"); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.highlightLine).classed("selectedLink", false); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.highlightLine).classed("highlightedLink", true); - } - } - this.isSelected = select; - } - - update() { - if (!this.renderedToProtein || // not linear - //or either end hidden hidden - this.renderedFromProtein.participant.hidden || - this.renderedToProtein.participant.hidden || - // or is self link in collapsed group - (this.crosslinks[0].isSelfLink() && this.renderedFromProtein.inCollapsedGroup()) || - // or either end is expanded to bar and not in collapsed group - (this.renderedFromProtein.expanded && !this.renderedFromProtein.inCollapsedGroup()) || - (this.renderedToProtein.expanded && !this.renderedToProtein.inCollapsedGroup()) // || - ) { - this.hide(); - } else { - this.hd = false; - const filteredCrossLinks = new Set(); - const filteredMatches = new Set(); - const altP_PLinks = new Set(); - - for (let crosslink of this.crosslinks) { - if (crosslink.filteredMatches_pp.length > 0) { - filteredCrossLinks.add(crosslink.id); - for (let m of crosslink.filteredMatches_pp) { - const match = m.match; // oh dear, this... - filteredMatches.add(match.id); - if (match.hd === true) { - this.hd = true; - } - if (match.crosslinks.length > 1) { - for (let matchCrossLink of match.crosslinks) { - if (!matchCrossLink.isDecoyLink()) { - altP_PLinks.add(matchCrossLink.p_pLink.id); - } - } - } - } - } - - this.filteredMatchCount = filteredMatches.size; - this.filteredCrossLinkCount = filteredCrossLinks.size; - - if (this.filteredCrossLinkCount === 0) { - this.hide(); - } else { - this.ambiguous = altP_PLinks.size > 1; - - if (this.renderedFromProtein.inCollapsedGroup() && this.renderedToProtein.inCollapsedGroup()) { - const source = this.renderedFromProtein.getRenderedInteractor(); - const target = this.renderedToProtein.getRenderedInteractor(); - let ggId; - if (source.id < target.id) { - ggId = source.id + "_" + target.id; - } else { - ggId = target.id + "_" + source.id; - } - let ggLink = this.controller.g_gLinks.get(ggId); - if (!ggLink) { - if (source.id < target.id) { - ggLink = new _g_g_link__WEBPACK_IMPORTED_MODULE_3__.G_GLink(ggId, source, target, this.controller); - } else { - ggLink = new _g_g_link__WEBPACK_IMPORTED_MODULE_3__.G_GLink(ggId, target, source, this.controller); - } - this.controller.g_gLinks.set(ggId, ggLink); - } - ggLink.p_pLinks.set(this.id, this); - this.hide(); - // ggLink.show(); - } else { - this.show(); - } - - } - } - } - } - - show() { - //if (!this.shown) { - causing problems with load layout, TODO - look at again - if (typeof this.line === "undefined") { - this.initSVG(); - } - this.shown = true; - if (this.renderedFromProtein === this.renderedToProtein) { - this.thickLine.setAttribute("transform", "translate(" + - this.renderedFromProtein.ix + " " + this.renderedFromProtein.iy + ")" // possibly not necessary - + - " scale(" + (this.controller.z) + ")"); - this.line.setAttribute("transform", "translate(" + this.renderedFromProtein.ix + - " " + this.renderedFromProtein.iy + ")" + " scale(" + (this.controller.z) + ")"); - this.highlightLine.setAttribute("transform", "translate(" + this.renderedFromProtein.ix + - " " + this.renderedFromProtein.iy + ")" + " scale(" + (this.controller.z) + ")"); - - } else { - this.line.setAttribute("stroke-width", (this.controller.z * _crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_2__.CrosslinkViewer.linkWidth).toString()); - this.highlightLine.setAttribute("stroke-width", (this.controller.z * 10).toString()); - this.setLineCoordinates(this.renderedFromProtein); - this.setLineCoordinates(this.renderedToProtein); - } - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.thickLine).style("display", null); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.line).style("display", null); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.highlightLine).style("display", null); - //} - - if (this.controller.model.get("xinetThickLinks") === false) { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.thickLine).style("display", "none"); - } else { - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.thickLine).style("display", null); - this.updateThickLineWidth(); - } - - this.dashedLine(this.ambiguous); - this.line.setAttribute("stroke", window.compositeModelInst.get("linkColourAssignment").getColour(this)); - this.setSelected(this.isSelected); - } - - // isPassingFilter() { - // for (let crosslink of this.crosslinks) { - // if (crosslink.filteredMatches_pp.length > 0) { - // return true; - // } - // } - // return false; - // } - - updateThickLineWidth() { - const steps = this.controller.model.get("xinetPpiSteps"); - - let thickLineWidth; - if (this.filteredCrossLinkCount < steps[0]) { - thickLineWidth = 1; - } else if (this.filteredCrossLinkCount < steps[1]) { - thickLineWidth = 5; - } else { - thickLineWidth = 10; - } - if (this.renderedFromProtein === this.renderedToProtein) { - this.thickLine.setAttribute("stroke-width", thickLineWidth); - } else { - this.thickLine.setAttribute("stroke-width", (this.controller.z * thickLineWidth).toString()); - } - } - - hide() { - if (this.shown) { - this.shown = false; - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.thickLine).style("display", "none"); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.highlightLine).style("display", "none"); - d3__WEBPACK_IMPORTED_MODULE_4___default().select(this.line).style("display", "none"); - } - } - - setLineCoordinates() { - if (this.renderedToProtein && this.renderedFromProtein !== this.renderedToProtein) { - if (this.shown) { - const source = this.renderedFromProtein.getRenderedInteractor(); - const target = this.renderedToProtein.getRenderedInteractor(); - if (isNaN(source.ix) || isNaN(source.iy)) { - console.log("prot coords are NaN"); - } - - // if (this.renderedFromProtein === participant) { - this.line.setAttribute("x1", source.ix); - this.line.setAttribute("y1", source.iy); - this.highlightLine.setAttribute("x1", source.ix); - this.highlightLine.setAttribute("y1", source.iy); - this.thickLine.setAttribute("x1", source.ix); - this.thickLine.setAttribute("y1", source.iy); - // } else if (this.renderedToProtein === participant) { - this.line.setAttribute("x2", target.ix); - this.line.setAttribute("y2", target.iy); - this.highlightLine.setAttribute("x2", target.ix); - this.highlightLine.setAttribute("y2", target.iy); - this.thickLine.setAttribute("x2", target.ix); - this.thickLine.setAttribute("y2", target.iy); - // } - } - } - } - - // getOtherEnd (protein) { - // if (this.renderedFromProtein === protein) { - // return this.renderedToProtein; - // } else { - // return this.renderedFromProtein; - // } - // } - // - // getFromProtein(){ - // return this.fromProtein; - // } - // - // getToProtein(){ - // return this.fromProtein; - // } -} - - -/***/ }), - -/***/ "./crosslink-viewer/js/views/xinet/link/rendered-crosslink.js": -/*!********************************************************************!*\ - !*** ./crosslink-viewer/js/views/xinet/link/rendered-crosslink.js ***! - \********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ RenderedCrosslink: () => (/* binding */ RenderedCrosslink) -/* harmony export */ }); -/* harmony import */ var _link__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./link */ "./crosslink-viewer/js/views/xinet/link/link.js"); -/* harmony import */ var _crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../crosslink-viewer-BB */ "./crosslink-viewer/js/views/xinet/crosslink-viewer-BB.js"); -/* harmony import */ var _interactor_rendered_protein__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../interactor/rendered-protein */ "./crosslink-viewer/js/views/xinet/interactor/rendered-protein.js"); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! d3 */ "./node_modules/d3/d3.js"); -/* harmony import */ var d3__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(d3__WEBPACK_IMPORTED_MODULE_3__); -/* harmony import */ var _xiview_js_make_tooltip__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../../../../xiview/js/make-tooltip */ "./xiview/js/make-tooltip.js"); -/* harmony import */ var _trig__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../trig */ "./crosslink-viewer/js/views/xinet/trig.js"); - - - - - - - -class RenderedCrosslink extends _link__WEBPACK_IMPORTED_MODULE_0__.Link { - constructor(crosslink, crosslinkViewer) { - super(crosslinkViewer); - this.isAggregateLink = false; - this.crosslink = crosslink; - - this.renderedFromProtein = this.controller.renderedProteins.get(this.crosslink.fromProtein.id); - this.renderedFromProtein.renderedCrosslinks.push(this); - if (this.crosslink.toProtein) { - this.renderedToProtein = this.controller.renderedProteins.get(this.crosslink.toProtein.id); - this.renderedToProtein.renderedCrosslinks.push(this); - } - - this.pepSvgArr = []; - } - - initSVG() { - if (this.crosslink.isSelfLink() || this.crosslink.isMonoLink()) { - this.line = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_1__.CrosslinkViewer.svgns, "path"); - this.line.setAttribute("stroke-width", _crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_1__.CrosslinkViewer.linkWidth); - this.highlightLine = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_1__.CrosslinkViewer.svgns, "path"); - this.renderedFromProtein.selfLinksHighlights.appendChild(this.highlightLine); - this.renderedFromProtein.selfLinks.appendChild(this.line); - } else { - this.line = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_1__.CrosslinkViewer.svgns, "line"); - this.line.setAttribute("stroke-linecap", "round"); - this.highlightLine = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_1__.CrosslinkViewer.svgns, "line"); - this.highlightLine.setAttribute("stroke-linecap", "round"); - this.controller.highlights.appendChild(this.highlightLine); - this.controller.res_resLinks.appendChild(this.line); - } - this.line.setAttribute("class", "link"); - this.line.setAttribute("fill", "none"); - this.highlightLine.setAttribute("class", "link highlightedLink"); - this.highlightLine.setAttribute("fill", "none"); - //this.highlightLine.setAttribute("stroke", CLMS.xiNET.highlightColour.toRGB()); - this.highlightLine.setAttribute("stroke-width", "10"); - this.highlightLine.setAttribute("stroke-opacity", "0"); - //set the events for it - const self = this; - const setMouseEvents = function (svgElement) { - svgElement.onmousedown = function (evt) { - self.mouseDown(evt); - }; - svgElement.onmouseover = function (evt) { - self.mouseOver(evt); - }; - svgElement.onmouseout = function (evt) { - self.mouseOut(evt); - }; - // this.line.ontouchstart = function(evt) { - // self.touchStart(evt); - // }; - svgElement.oncontextmenu = function () { - return false; - }; - }; - setMouseEvents(this.line); - setMouseEvents(this.highlightLine); - } - - mouseOver(evt) { - this.controller.preventDefaultsAndStopPropagation(evt); - if (this.renderedFromProtein.busy === false && (!this.renderedToProtein || this.renderedToProtein.busy === false)) { - const p = this.controller.getEventPoint(evt); - - const toHighlight = [this.crosslink]; - - this.controller.model.setMarkedCrossLinks("highlights", toHighlight, true, false); - - this.controller.model.get("tooltipModel") - .set("header", _xiview_js_make_tooltip__WEBPACK_IMPORTED_MODULE_4__.makeTooltipTitle.link()) - .set("contents", _xiview_js_make_tooltip__WEBPACK_IMPORTED_MODULE_4__.makeTooltipContents.link(this.crosslink)) - .set("location", { - pageX: p.x, - pageY: p.y - }); - } - } - - mouseDown(evt) { - this.controller.preventDefaultsAndStopPropagation(evt); - this.controller.d3cola.stop(); - this.controller.dragElement = this; - - let rightClick = (evt.button === 2); - - if (rightClick && this.crosslink.isSelfLink()) { - this.renderedFromProtein.toggleFlipped(); - } else { - const add = evt.shiftKey || evt.ctrlKey; - this.controller.model.setMarkedCrossLinks("selection", [this.crosslink], false, add); - } - //store start location - this.controller.dragStart = evt; - - d3__WEBPACK_IMPORTED_MODULE_3___default().select(".custom-menu-margin").style("display", "none"); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(".group-custom-menu-margin").style("display", "none"); - } - - /*xiNET.RenderedCrosslink.prototype.touchStart = function(evt) { - this.controller.d3cola.stop(); - this.controller.dragElement = this; - var add = evt.shiftKey || evt.ctrlKey; - this.controller.model.setMarkedCrossLinks("selection", [this.crosslink], false, add); - //store start location - //var p = this.controller.getTouchEventPoint(evt);// broke - this.controller.dragStart = evt; //this.controller.mouseToSVG(p.x, p.y); - }*/ - - // andAlternatives means highlight alternative links in case of site ambiguity, - // need to be able to switch this on and off to avoid infinite loop - showHighlight(show) { - //~ if (!this.renderedFromProtein.busy && (!this.renderedToProtein || !this.renderedToProtein.busy)) { - if (this.shown) { - if (show) { - //this.highlightLine.setAttribute("stroke", CLMS.xiNET.highlightColour.toRGB()); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).classed("selectedLink", false); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).classed("highlightedLink", true); - this.highlightLine.setAttribute("stroke-opacity", "0.7"); - if (this.crosslink.filteredMatches_pp[0].match.matchedPeptides[0].seq_mods) { - const fromPeptides = [], - toPeptides = []; - //this is where we need the peptide positions - const filteredMatchesAndPeptidePositions = this.crosslink.filteredMatches_pp; - const fm_ppCount = filteredMatchesAndPeptidePositions.length; - for (let fm_pp = 0; fm_pp < fm_ppCount; fm_pp++) { - const matchAndPepPos = filteredMatchesAndPeptidePositions[fm_pp]; - const match = matchAndPepPos.match; - - const fromPepStart = matchAndPepPos.pepPos[0].start - 1; - const fromPepLength = matchAndPepPos.pepPos[0].length; - const toPepStart = matchAndPepPos.pepPos[1].start - 1; - const toPepLength = matchAndPepPos.pepPos[1].length; - - fromPeptides.push([fromPepStart, fromPepLength, match.overlap[0], match.overlap[1]]); - toPeptides.push([toPepStart, toPepLength, match.overlap[0], match.overlap[1]]); - } - if (this.renderedFromProtein.expanded) { - this.showPeptides(fromPeptides, this.renderedFromProtein); - } - if (this.renderedToProtein && this.renderedToProtein.expanded) { - this.showPeptides(toPeptides, this.renderedToProtein); - } - } - } else { - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).classed("selectedLink", true); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).classed("highlightedLink", false); - if (this.isSelected === false) { - this.highlightLine.setAttribute("stroke-opacity", "0"); - } - this.removePeptides(); - } - } - } - - showPeptides(pepBounds, renderedProtein) { - let y = -_interactor_rendered_protein__WEBPACK_IMPORTED_MODULE_2__.RenderedProtein.STICKHEIGHT / 2; - const count = pepBounds.length; - const yIncrement = _interactor_rendered_protein__WEBPACK_IMPORTED_MODULE_2__.RenderedProtein.STICKHEIGHT / count; - for (let i = 0; i < count; i++) { - const pep = pepBounds[i]; - let annoColouredRect = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_1__.CrosslinkViewer.svgns, "rect"); - annoColouredRect.setAttribute("class", "protein"); - - //make domain rectangles - const annoSize = pep[1] - 0.2; - let annoX = ((pep[0] + 0.6) - (renderedProtein.participant.size / 2)); - let annoLength = annoSize; - annoColouredRect.setAttribute("x", annoX.toString()); - annoColouredRect.setAttribute("y", y.toString()); - annoColouredRect.setAttribute("width", annoLength.toString()); - annoColouredRect.setAttribute("height", yIncrement.toString()); - //style 'em - d3__WEBPACK_IMPORTED_MODULE_3___default().select(annoColouredRect).classed("highlightedPeptide", true); - //annotColouredRect.setAttribute("fill-opacity", "0.7"); - renderedProtein.peptides.appendChild(annoColouredRect); - this.pepSvgArr.push(annoColouredRect); - - if (typeof pep[2] != "undefined") { //homomultimer like - annoColouredRect = document.createElementNS(_crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_1__.CrosslinkViewer.svgns, "rect"); - annoColouredRect.setAttribute("class", "protein"); - annoX = ((pep[2] + 0.5) - (renderedProtein.participant.size / 2)); - annoLength = (pep[3] - pep[2]); - annoColouredRect.setAttribute("x", annoX.toString()); - annoColouredRect.setAttribute("y", y.toString()); - annoColouredRect.setAttribute("width", annoLength.toString()); - annoColouredRect.setAttribute("height", yIncrement.toString()); - - //style 'em - d3__WEBPACK_IMPORTED_MODULE_3___default().select(annoColouredRect).classed("peptideOverlap", true); - annoColouredRect.setAttribute("fill-opacity", "0.5"); - - renderedProtein.peptides.appendChild(annoColouredRect); - this.pepSvgArr.push(annoColouredRect); - } - y += yIncrement; - } - } - - removePeptides() { - const pepSvgArrCount = this.pepSvgArr.length; - for (let p = 0; p < pepSvgArrCount; p++) { - _crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_1__.CrosslinkViewer.removeDomElement(this.pepSvgArr[p]); - } - } - - setSelected(select) { - if (this.shown) { - if (select === true) { - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).classed("selectedLink", true); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).classed("highlightedLink", false); - this.highlightLine.setAttribute("stroke-opacity", "0.7"); - } else { - this.highlightLine.setAttribute("stroke-opacity", "0"); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).classed("selectedLink", false); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).classed("highlightedLink", true); - } - } - this.isSelected = select; - } - - - //used when filter changed - check() { - // neither end is a bar which isn't in a collapsed group? then hide - if ((!this.renderedFromProtein.expanded || (this.renderedFromProtein.inCollapsedGroup())) && - (this.renderedToProtein ? (!this.renderedToProtein.expanded || this.renderedToProtein.inCollapsedGroup()) : false)) { - this.hide(); - return false; - } - - // either end manually hidden? then hide - if (this.renderedFromProtein.participant.hidden === true || - (this.renderedToProtein && this.renderedToProtein.participant.hidden === true)) { - this.hide(); - return false; - } - - // no crosslinks passed filter? then hide - if (this.crosslink.filteredMatches_pp.length > 0) { - this.show(); - return true; - } else { - this.hide(); - return false; - } - } - - show() { - if (!this.shown) { - this.shown = true; - if (typeof this.line === "undefined") { - this.initSVG(); - } - if (!this.renderedToProtein) { - let path; - if (this.renderedFromProtein.expanded) { - path = this.renderedFromProtein.getCrossLinkPath(this); - } else { - path = this.crosslink.isMonoLink() ? "M 0,0 L 0,0 L 0,0 L 0,0" : this.renderedFromProtein.getAggregateSelfLinkPath(); - } - this.highlightLine.setAttribute("d", path); - this.line.setAttribute("d", path); - } else { - if (!this.crosslink.isSelfLink()) { - this.line.setAttribute("stroke-width", (this.controller.z * _crosslink_viewer_BB__WEBPACK_IMPORTED_MODULE_1__.CrosslinkViewer.linkWidth).toString()); - this.highlightLine.setAttribute("stroke-width", (this.controller.z * 10).toString()); - this.setLineCoordinates(this.renderedFromProtein); - this.setLineCoordinates(this.renderedToProtein); - } - } - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).style("display", null); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.line).style("display", null); - } - - if (this.crosslink.isSelfLink() && this.renderedToProtein) { - if (this.homomultimer !== this.crosslink.confirmedHomomultimer) { - let path; - if (this.renderedFromProtein.expanded) { - path = this.renderedFromProtein.getCrossLinkPath(this); - } else { - path = this.renderedFromProtein.getAggregateSelfLinkPath(); - } - this.highlightLine.setAttribute("d", path); - this.line.setAttribute("d", path); - this.homomultimer = this.crosslink.confirmedHomomultimer; - } - } - - this.dashedLine(this.crosslink.ambiguous && this.crosslink.isMonoLink() === false); - - if (this.crosslink.isMonoLink()) { - this.line.setAttribute("fill", this.crosslink.ambiguous ? "none" : this.controller.model.get("linkColourAssignment").getColour(this.crosslink)); - } - - this.line.setAttribute("stroke", - this.controller.model.get("linkColourAssignment").getColour(this.crosslink)); - - this.setSelected(this.isSelected); - } - - hide() { - if (this.shown) { - this.shown = false; - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.highlightLine).style("display", "none"); - d3__WEBPACK_IMPORTED_MODULE_3___default().select(this.line).style("display", "none"); - this.removePeptides(); - } - } - - // there's an efficiency saving possible by passing in the renderedInteractor that's moved, - // then only need to change that end - setLineCoordinates() { - if (this.shown) { - //if not self link && not linker modified pep - if (!this.crosslink.isSelfLink() && this.crosslink.toProtein) { - let x, y; - const source = this.renderedFromProtein.getRenderedInteractor(); - const target = this.renderedToProtein.getRenderedInteractor(); - if (!source.ix || !source.iy) { - console.log("NOT"); - } - // from end - if (source.type === "group" || !source.expanded) { - x = source.ix; - y = source.iy; - } else { - const coord = this.getResidueCoordinates(this.crosslink.fromResidue, this.renderedFromProtein); - x = coord[0]; - y = coord[1]; - } - this.line.setAttribute("x1", x); - this.line.setAttribute("y1", y); - this.highlightLine.setAttribute("x1", x); - this.highlightLine.setAttribute("y1", y); - - // to end - if (target.type === "group" || !target.expanded) { - x = target.ix; - y = target.iy; - } else { - const coord = this.getResidueCoordinates(this.crosslink.toResidue, this.renderedToProtein); - x = coord[0]; - y = coord[1]; - } - this.line.setAttribute("x2", x); - this.line.setAttribute("y2", y); - this.highlightLine.setAttribute("x2", x); - this.highlightLine.setAttribute("y2", y); - - } - } - } - - //calculate the coordinates of a residue (relative to this.controller.container) - getResidueCoordinates(r, renderedInteractor) { - let x = renderedInteractor.getResXwithStickZoom(r) * this.controller.z; - let y = 0; - if (renderedInteractor.stickZoom >= 8) { //if sequence shown - const from = this.renderedFromProtein, - to = this.renderedToProtein; - const deltaX = from.ix - to.ix; - const deltaY = from.iy - to.iy; - const angleBetweenMidPoints = Math.atan2(deltaY, deltaX); - //todo: tidy up trig code so everything is always in radians? - let abmpDeg = angleBetweenMidPoints / (2 * Math.PI) * 360; - if (abmpDeg < 0) { - abmpDeg += 360; - } - - let out; //'out' is value we use to decide which side of letter the line is drawn - if (renderedInteractor === from) { - out = (abmpDeg - from.rotation); - if (out < 0) { - out += 360; - } - let fyOffset = 5; - if (out < 180) { - fyOffset = -5; - } - - y = fyOffset * this.controller.z; - } else { // renderedInteractor === to - out = (abmpDeg - to.rotation); - if (out < 0) { - out += 360; - } - let tyOffset = 5; - if (out > 180) { - tyOffset = -5; - } - y = tyOffset * this.controller.z; - } - } - - const rotated = (0,_trig__WEBPACK_IMPORTED_MODULE_5__.rotatePointAboutPoint)([x, y], [0, 0], renderedInteractor.rotation); - - x = rotated[0] + renderedInteractor.ix; - y = rotated[1] + renderedInteractor.iy; - return [x, y]; - } -} - - -/***/ }), - -/***/ "./crosslink-viewer/js/views/xinet/trig.js": -/*!*************************************************!*\ - !*** ./crosslink-viewer/js/views/xinet/trig.js ***! - \*************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ rotatePointAboutPoint: () => (/* binding */ rotatePointAboutPoint), -/* harmony export */ trig: () => (/* binding */ trig) -/* harmony export */ }); -function trig(radius, angleDegrees) { //TODO: change theta arg to radians not degrees - //x = rx + radius * cos(theta) and y = ry + radius * sin(theta) - const radians = (angleDegrees / 360) * Math.PI * 2; - return { - x: (radius * Math.cos(radians)), - y: (radius * Math.sin(radians)) - }; -} - -function rotatePointAboutPoint(p, o, theta) { // todo: change format of p and o to be {x,y}? - theta = (theta / 360) * Math.PI * 2; //TODO: change theta arg to radians not degrees - const rx = Math.cos(theta) * (p[0] - o[0]) - Math.sin(theta) * (p[1] - o[1]) + o[0]; - const ry = Math.sin(theta) * (p[0] - o[0]) + Math.cos(theta) * (p[1] - o[1]) + o[1]; - return [rx, ry]; -} - -/***/ }), - -/***/ "./crosslink-viewer/vendor/cola.js": -/*!*****************************************!*\ - !*** ./crosslink-viewer/vendor/cola.js ***! - \*****************************************/ -/***/ ((module) => { - -(function(f){if(true){module.exports=f()}else { var g; }})(function(){var define,module,exports;return (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c=undefined;if(!f&&c)return require(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u=undefined,i=0;i i) { - var d = D[i][j]; - if (d > 0 && d < this.minD) { - this.minD = d; - } - } - } - if (this.minD === Number.MAX_VALUE) - this.minD = 1; - i = this.k; - while (i--) { - this.g[i] = new Array(n); - this.H[i] = new Array(n); - j = n; - while (j--) { - this.H[i][j] = new Array(n); - } - this.Hd[i] = new Array(n); - this.a[i] = new Array(n); - this.b[i] = new Array(n); - this.c[i] = new Array(n); - this.d[i] = new Array(n); - this.e[i] = new Array(n); - this.ia[i] = new Array(n); - this.ib[i] = new Array(n); - this.xtmp[i] = new Array(n); - } - } - Descent.createSquareMatrix = function (n, f) { - var M = new Array(n); - for (var i = 0; i < n; ++i) { - M[i] = new Array(n); - for (var j = 0; j < n; ++j) { - M[i][j] = f(i, j); - } - } - return M; - }; - Descent.prototype.offsetDir = function () { - var _this = this; - var u = new Array(this.k); - var l = 0; - for (var i = 0; i < this.k; ++i) { - var x = u[i] = this.random.getNextBetween(0.01, 1) - 0.5; - l += x * x; - } - l = Math.sqrt(l); - return u.map(function (x) { return x *= _this.minD / l; }); - }; - Descent.prototype.computeDerivatives = function (x) { - var _this = this; - var n = this.n; - if (n < 1) - return; - var i; - var d = new Array(this.k); - var d2 = new Array(this.k); - var Huu = new Array(this.k); - var maxH = 0; - for (var u_1 = 0; u_1 < n; ++u_1) { - for (i = 0; i < this.k; ++i) - Huu[i] = this.g[i][u_1] = 0; - for (var v = 0; v < n; ++v) { - if (u_1 === v) - continue; - var maxDisplaces = n; - var distanceSquared = 0; - while (maxDisplaces--) { - distanceSquared = 0; - for (i = 0; i < this.k; ++i) { - var dx_1 = d[i] = x[i][u_1] - x[i][v]; - distanceSquared += d2[i] = dx_1 * dx_1; - } - if (distanceSquared > 1e-9) - break; - var rd = this.offsetDir(); - for (i = 0; i < this.k; ++i) - x[i][v] += rd[i]; - } - var distance = Math.sqrt(distanceSquared); - var idealDistance = this.D[u_1][v]; - var weight = this.G != null ? this.G[u_1][v] : 1; - if (weight > 1 && distance > idealDistance || !isFinite(idealDistance)) { - for (i = 0; i < this.k; ++i) - this.H[i][u_1][v] = 0; - continue; - } - if (weight > 1) { - weight = 1; - } - var idealDistSquared = idealDistance * idealDistance, gs = 2 * weight * (distance - idealDistance) / (idealDistSquared * distance), distanceCubed = distanceSquared * distance, hs = 2 * -weight / (idealDistSquared * distanceCubed); - if (!isFinite(gs)) - console.log(gs); - for (i = 0; i < this.k; ++i) { - this.g[i][u_1] += d[i] * gs; - Huu[i] -= this.H[i][u_1][v] = hs * (2 * distanceCubed + idealDistance * (d2[i] - distanceSquared)); - } - } - for (i = 0; i < this.k; ++i) - maxH = Math.max(maxH, this.H[i][u_1][u_1] = Huu[i]); - } - var r = this.snapGridSize / 2; - var g = this.snapGridSize; - var w = this.snapStrength; - var k = w / (r * r); - var numNodes = this.numGridSnapNodes; - for (var u = 0; u < numNodes; ++u) { - for (i = 0; i < this.k; ++i) { - var xiu = this.x[i][u]; - var m = xiu / g; - var f = m % 1; - var q = m - f; - var a = Math.abs(f); - var dx = (a <= 0.5) ? xiu - q * g : - (xiu > 0) ? xiu - (q + 1) * g : xiu - (q - 1) * g; - if (-r < dx && dx <= r) { - if (this.scaleSnapByMaxH) { - this.g[i][u] += maxH * k * dx; - this.H[i][u][u] += maxH * k; - } - else { - this.g[i][u] += k * dx; - this.H[i][u][u] += k; - } - } - } - } - if (!this.locks.isEmpty()) { - this.locks.apply(function (u, p) { - for (i = 0; i < _this.k; ++i) { - _this.H[i][u][u] += maxH; - _this.g[i][u] -= maxH * (p[i] - x[i][u]); - } - }); - } - }; - Descent.dotProd = function (a, b) { - var x = 0, i = a.length; - while (i--) - x += a[i] * b[i]; - return x; - }; - Descent.rightMultiply = function (m, v, r) { - var i = m.length; - while (i--) - r[i] = Descent.dotProd(m[i], v); - }; - Descent.prototype.computeStepSize = function (d) { - var numerator = 0, denominator = 0; - for (var i = 0; i < this.k; ++i) { - numerator += Descent.dotProd(this.g[i], d[i]); - Descent.rightMultiply(this.H[i], d[i], this.Hd[i]); - denominator += Descent.dotProd(d[i], this.Hd[i]); - } - if (denominator === 0 || !isFinite(denominator)) - return 0; - return 1 * numerator / denominator; - }; - Descent.prototype.reduceStress = function () { - this.computeDerivatives(this.x); - var alpha = this.computeStepSize(this.g); - for (var i = 0; i < this.k; ++i) { - this.takeDescentStep(this.x[i], this.g[i], alpha); - } - return this.computeStress(); - }; - Descent.copy = function (a, b) { - var m = a.length, n = b[0].length; - for (var i = 0; i < m; ++i) { - for (var j = 0; j < n; ++j) { - b[i][j] = a[i][j]; - } - } - }; - Descent.prototype.stepAndProject = function (x0, r, d, stepSize) { - Descent.copy(x0, r); - this.takeDescentStep(r[0], d[0], stepSize); - if (this.project) - this.project[0](x0[0], x0[1], r[0]); - this.takeDescentStep(r[1], d[1], stepSize); - if (this.project) - this.project[1](r[0], x0[1], r[1]); - for (var i = 2; i < this.k; i++) - this.takeDescentStep(r[i], d[i], stepSize); - }; - Descent.mApply = function (m, n, f) { - var i = m; - while (i-- > 0) { - var j = n; - while (j-- > 0) - f(i, j); - } - }; - Descent.prototype.matrixApply = function (f) { - Descent.mApply(this.k, this.n, f); - }; - Descent.prototype.computeNextPosition = function (x0, r) { - var _this = this; - this.computeDerivatives(x0); - var alpha = this.computeStepSize(this.g); - this.stepAndProject(x0, r, this.g, alpha); - if (this.project) { - this.matrixApply(function (i, j) { return _this.e[i][j] = x0[i][j] - r[i][j]; }); - var beta = this.computeStepSize(this.e); - beta = Math.max(0.2, Math.min(beta, 1)); - this.stepAndProject(x0, r, this.e, beta); - } - }; - Descent.prototype.run = function (iterations) { - var stress = Number.MAX_VALUE, converged = false; - while (!converged && iterations-- > 0) { - var s = this.rungeKutta(); - converged = Math.abs(stress / s - 1) < this.threshold; - stress = s; - } - return stress; - }; - Descent.prototype.rungeKutta = function () { - var _this = this; - this.computeNextPosition(this.x, this.a); - Descent.mid(this.x, this.a, this.ia); - this.computeNextPosition(this.ia, this.b); - Descent.mid(this.x, this.b, this.ib); - this.computeNextPosition(this.ib, this.c); - this.computeNextPosition(this.c, this.d); - var disp = 0; - this.matrixApply(function (i, j) { - var x = (_this.a[i][j] + 2.0 * _this.b[i][j] + 2.0 * _this.c[i][j] + _this.d[i][j]) / 6.0, d = _this.x[i][j] - x; - disp += d * d; - _this.x[i][j] = x; - }); - return disp; - }; - Descent.mid = function (a, b, m) { - Descent.mApply(a.length, a[0].length, function (i, j) { - return m[i][j] = a[i][j] + (b[i][j] - a[i][j]) / 2.0; - }); - }; - Descent.prototype.takeDescentStep = function (x, d, stepSize) { - for (var i = 0; i < this.n; ++i) { - x[i] = x[i] - stepSize * d[i]; - } - }; - Descent.prototype.computeStress = function () { - var stress = 0; - for (var u = 0, nMinus1 = this.n - 1; u < nMinus1; ++u) { - for (var v = u + 1, n = this.n; v < n; ++v) { - var l = 0; - for (var i = 0; i < this.k; ++i) { - var dx = this.x[i][u] - this.x[i][v]; - l += dx * dx; - } - l = Math.sqrt(l); - var d = this.D[u][v]; - if (!isFinite(d)) - continue; - var rl = d - l; - var d2 = d * d; - stress += rl * rl / d2; - } - } - return stress; - }; - Descent.zeroDistance = 1e-10; - return Descent; -}()); -exports.Descent = Descent; -var PseudoRandom = (function () { - function PseudoRandom(seed) { - if (seed === void 0) { seed = 1; } - this.seed = seed; - this.a = 214013; - this.c = 2531011; - this.m = 2147483648; - this.range = 32767; - } - PseudoRandom.prototype.getNext = function () { - this.seed = (this.seed * this.a + this.c) % this.m; - return (this.seed >> 16) / this.range; - }; - PseudoRandom.prototype.getNextBetween = function (min, max) { - return min + this.getNext() * (max - min); - }; - return PseudoRandom; -}()); -exports.PseudoRandom = PseudoRandom; - -},{}],8:[function(require,module,exports){ -"use strict"; -var __extends = (this && this.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); -Object.defineProperty(exports, "__esModule", { value: true }); -var rectangle_1 = require("./rectangle"); -var Point = (function () { - function Point() { - } - return Point; -}()); -exports.Point = Point; -var LineSegment = (function () { - function LineSegment(x1, y1, x2, y2) { - this.x1 = x1; - this.y1 = y1; - this.x2 = x2; - this.y2 = y2; - } - return LineSegment; -}()); -exports.LineSegment = LineSegment; -var PolyPoint = (function (_super) { - __extends(PolyPoint, _super); - function PolyPoint() { - return _super !== null && _super.apply(this, arguments) || this; - } - return PolyPoint; -}(Point)); -exports.PolyPoint = PolyPoint; -function isLeft(P0, P1, P2) { - return (P1.x - P0.x) * (P2.y - P0.y) - (P2.x - P0.x) * (P1.y - P0.y); -} -exports.isLeft = isLeft; -function above(p, vi, vj) { - return isLeft(p, vi, vj) > 0; -} -function below(p, vi, vj) { - return isLeft(p, vi, vj) < 0; -} -function ConvexHull(S) { - var P = S.slice(0).sort(function (a, b) { return a.x !== b.x ? b.x - a.x : b.y - a.y; }); - var n = S.length, i; - var minmin = 0; - var xmin = P[0].x; - for (i = 1; i < n; ++i) { - if (P[i].x !== xmin) - break; - } - var minmax = i - 1; - var H = []; - H.push(P[minmin]); - if (minmax === n - 1) { - if (P[minmax].y !== P[minmin].y) - H.push(P[minmax]); - } - else { - var maxmin, maxmax = n - 1; - var xmax = P[n - 1].x; - for (i = n - 2; i >= 0; i--) - if (P[i].x !== xmax) - break; - maxmin = i + 1; - i = minmax; - while (++i <= maxmin) { - if (isLeft(P[minmin], P[maxmin], P[i]) >= 0 && i < maxmin) - continue; - while (H.length > 1) { - if (isLeft(H[H.length - 2], H[H.length - 1], P[i]) > 0) - break; - else - H.length -= 1; - } - if (i != minmin) - H.push(P[i]); - } - if (maxmax != maxmin) - H.push(P[maxmax]); - var bot = H.length; - i = maxmin; - while (--i >= minmax) { - if (isLeft(P[maxmax], P[minmax], P[i]) >= 0 && i > minmax) - continue; - while (H.length > bot) { - if (isLeft(H[H.length - 2], H[H.length - 1], P[i]) > 0) - break; - else - H.length -= 1; - } - if (i != minmin) - H.push(P[i]); - } - } - return H; -} -exports.ConvexHull = ConvexHull; -function clockwiseRadialSweep(p, P, f) { - P.slice(0).sort(function (a, b) { return Math.atan2(a.y - p.y, a.x - p.x) - Math.atan2(b.y - p.y, b.x - p.x); }).forEach(f); -} -exports.clockwiseRadialSweep = clockwiseRadialSweep; -function nextPolyPoint(p, ps) { - if (p.polyIndex === ps.length - 1) - return ps[0]; - return ps[p.polyIndex + 1]; -} -function prevPolyPoint(p, ps) { - if (p.polyIndex === 0) - return ps[ps.length - 1]; - return ps[p.polyIndex - 1]; -} -function tangent_PointPolyC(P, V) { - var Vclosed = V.slice(0); - Vclosed.push(V[0]); - return { rtan: Rtangent_PointPolyC(P, Vclosed), ltan: Ltangent_PointPolyC(P, Vclosed) }; -} -function Rtangent_PointPolyC(P, V) { - var n = V.length - 1; - var a, b, c; - var upA, dnC; - if (below(P, V[1], V[0]) && !above(P, V[n - 1], V[0])) - return 0; - for (a = 0, b = n;;) { - if (b - a === 1) - if (above(P, V[a], V[b])) - return a; - else - return b; - c = Math.floor((a + b) / 2); - dnC = below(P, V[c + 1], V[c]); - if (dnC && !above(P, V[c - 1], V[c])) - return c; - upA = above(P, V[a + 1], V[a]); - if (upA) { - if (dnC) - b = c; - else { - if (above(P, V[a], V[c])) - b = c; - else - a = c; - } - } - else { - if (!dnC) - a = c; - else { - if (below(P, V[a], V[c])) - b = c; - else - a = c; - } - } - } -} -function Ltangent_PointPolyC(P, V) { - var n = V.length - 1; - var a, b, c; - var dnA, dnC; - if (above(P, V[n - 1], V[0]) && !below(P, V[1], V[0])) - return 0; - for (a = 0, b = n;;) { - if (b - a === 1) - if (below(P, V[a], V[b])) - return a; - else - return b; - c = Math.floor((a + b) / 2); - dnC = below(P, V[c + 1], V[c]); - if (above(P, V[c - 1], V[c]) && !dnC) - return c; - dnA = below(P, V[a + 1], V[a]); - if (dnA) { - if (!dnC) - b = c; - else { - if (below(P, V[a], V[c])) - b = c; - else - a = c; - } - } - else { - if (dnC) - a = c; - else { - if (above(P, V[a], V[c])) - b = c; - else - a = c; - } - } - } -} -function tangent_PolyPolyC(V, W, t1, t2, cmp1, cmp2) { - var ix1, ix2; - ix1 = t1(W[0], V); - ix2 = t2(V[ix1], W); - var done = false; - while (!done) { - done = true; - while (true) { - if (ix1 === V.length - 1) - ix1 = 0; - if (cmp1(W[ix2], V[ix1], V[ix1 + 1])) - break; - ++ix1; - } - while (true) { - if (ix2 === 0) - ix2 = W.length - 1; - if (cmp2(V[ix1], W[ix2], W[ix2 - 1])) - break; - --ix2; - done = false; - } - } - return { t1: ix1, t2: ix2 }; -} -exports.tangent_PolyPolyC = tangent_PolyPolyC; -function LRtangent_PolyPolyC(V, W) { - var rl = RLtangent_PolyPolyC(W, V); - return { t1: rl.t2, t2: rl.t1 }; -} -exports.LRtangent_PolyPolyC = LRtangent_PolyPolyC; -function RLtangent_PolyPolyC(V, W) { - return tangent_PolyPolyC(V, W, Rtangent_PointPolyC, Ltangent_PointPolyC, above, below); -} -exports.RLtangent_PolyPolyC = RLtangent_PolyPolyC; -function LLtangent_PolyPolyC(V, W) { - return tangent_PolyPolyC(V, W, Ltangent_PointPolyC, Ltangent_PointPolyC, below, below); -} -exports.LLtangent_PolyPolyC = LLtangent_PolyPolyC; -function RRtangent_PolyPolyC(V, W) { - return tangent_PolyPolyC(V, W, Rtangent_PointPolyC, Rtangent_PointPolyC, above, above); -} -exports.RRtangent_PolyPolyC = RRtangent_PolyPolyC; -var BiTangent = (function () { - function BiTangent(t1, t2) { - this.t1 = t1; - this.t2 = t2; - } - return BiTangent; -}()); -exports.BiTangent = BiTangent; -var BiTangents = (function () { - function BiTangents() { - } - return BiTangents; -}()); -exports.BiTangents = BiTangents; -var TVGPoint = (function (_super) { - __extends(TVGPoint, _super); - function TVGPoint() { - return _super !== null && _super.apply(this, arguments) || this; - } - return TVGPoint; -}(Point)); -exports.TVGPoint = TVGPoint; -var VisibilityVertex = (function () { - function VisibilityVertex(id, polyid, polyvertid, p) { - this.id = id; - this.polyid = polyid; - this.polyvertid = polyvertid; - this.p = p; - p.vv = this; - } - return VisibilityVertex; -}()); -exports.VisibilityVertex = VisibilityVertex; -var VisibilityEdge = (function () { - function VisibilityEdge(source, target) { - this.source = source; - this.target = target; - } - VisibilityEdge.prototype.length = function () { - var dx = this.source.p.x - this.target.p.x; - var dy = this.source.p.y - this.target.p.y; - return Math.sqrt(dx * dx + dy * dy); - }; - return VisibilityEdge; -}()); -exports.VisibilityEdge = VisibilityEdge; -var TangentVisibilityGraph = (function () { - function TangentVisibilityGraph(P, g0) { - this.P = P; - this.V = []; - this.E = []; - if (!g0) { - var n = P.length; - for (var i = 0; i < n; i++) { - var p = P[i]; - for (var j = 0; j < p.length; ++j) { - var pj = p[j], vv = new VisibilityVertex(this.V.length, i, j, pj); - this.V.push(vv); - if (j > 0) - this.E.push(new VisibilityEdge(p[j - 1].vv, vv)); - } - if (p.length > 1) - this.E.push(new VisibilityEdge(p[0].vv, p[p.length - 1].vv)); - } - for (var i = 0; i < n - 1; i++) { - var Pi = P[i]; - for (var j = i + 1; j < n; j++) { - var Pj = P[j], t = tangents(Pi, Pj); - for (var q in t) { - var c = t[q], source = Pi[c.t1], target = Pj[c.t2]; - this.addEdgeIfVisible(source, target, i, j); - } - } - } - } - else { - this.V = g0.V.slice(0); - this.E = g0.E.slice(0); - } - } - TangentVisibilityGraph.prototype.addEdgeIfVisible = function (u, v, i1, i2) { - if (!this.intersectsPolys(new LineSegment(u.x, u.y, v.x, v.y), i1, i2)) { - this.E.push(new VisibilityEdge(u.vv, v.vv)); - } - }; - TangentVisibilityGraph.prototype.addPoint = function (p, i1) { - var n = this.P.length; - this.V.push(new VisibilityVertex(this.V.length, n, 0, p)); - for (var i = 0; i < n; ++i) { - if (i === i1) - continue; - var poly = this.P[i], t = tangent_PointPolyC(p, poly); - this.addEdgeIfVisible(p, poly[t.ltan], i1, i); - this.addEdgeIfVisible(p, poly[t.rtan], i1, i); - } - return p.vv; - }; - TangentVisibilityGraph.prototype.intersectsPolys = function (l, i1, i2) { - for (var i = 0, n = this.P.length; i < n; ++i) { - if (i != i1 && i != i2 && intersects(l, this.P[i]).length > 0) { - return true; - } - } - return false; - }; - return TangentVisibilityGraph; -}()); -exports.TangentVisibilityGraph = TangentVisibilityGraph; -function intersects(l, P) { - var ints = []; - for (var i = 1, n = P.length; i < n; ++i) { - var int = rectangle_1.Rectangle.lineIntersection(l.x1, l.y1, l.x2, l.y2, P[i - 1].x, P[i - 1].y, P[i].x, P[i].y); - if (int) - ints.push(int); - } - return ints; -} -function tangents(V, W) { - var m = V.length - 1, n = W.length - 1; - var bt = new BiTangents(); - for (var i = 0; i <= m; ++i) { - for (var j = 0; j <= n; ++j) { - var v1 = V[i == 0 ? m : i - 1]; - var v2 = V[i]; - var v3 = V[i == m ? 0 : i + 1]; - var w1 = W[j == 0 ? n : j - 1]; - var w2 = W[j]; - var w3 = W[j == n ? 0 : j + 1]; - var v1v2w2 = isLeft(v1, v2, w2); - var v2w1w2 = isLeft(v2, w1, w2); - var v2w2w3 = isLeft(v2, w2, w3); - var w1w2v2 = isLeft(w1, w2, v2); - var w2v1v2 = isLeft(w2, v1, v2); - var w2v2v3 = isLeft(w2, v2, v3); - if (v1v2w2 >= 0 && v2w1w2 >= 0 && v2w2w3 < 0 - && w1w2v2 >= 0 && w2v1v2 >= 0 && w2v2v3 < 0) { - bt.ll = new BiTangent(i, j); - } - else if (v1v2w2 <= 0 && v2w1w2 <= 0 && v2w2w3 > 0 - && w1w2v2 <= 0 && w2v1v2 <= 0 && w2v2v3 > 0) { - bt.rr = new BiTangent(i, j); - } - else if (v1v2w2 <= 0 && v2w1w2 > 0 && v2w2w3 <= 0 - && w1w2v2 >= 0 && w2v1v2 < 0 && w2v2v3 >= 0) { - bt.rl = new BiTangent(i, j); - } - else if (v1v2w2 >= 0 && v2w1w2 < 0 && v2w2w3 >= 0 - && w1w2v2 <= 0 && w2v1v2 > 0 && w2v2v3 <= 0) { - bt.lr = new BiTangent(i, j); - } - } - } - return bt; -} -exports.tangents = tangents; -function isPointInsidePoly(p, poly) { - for (var i = 1, n = poly.length; i < n; ++i) - if (below(poly[i - 1], poly[i], p)) - return false; - return true; -} -function isAnyPInQ(p, q) { - return !p.every(function (v) { return !isPointInsidePoly(v, q); }); -} -function polysOverlap(p, q) { - if (isAnyPInQ(p, q)) - return true; - if (isAnyPInQ(q, p)) - return true; - for (var i = 1, n = p.length; i < n; ++i) { - var v = p[i], u = p[i - 1]; - if (intersects(new LineSegment(u.x, u.y, v.x, v.y), q).length > 0) - return true; - } - return false; -} -exports.polysOverlap = polysOverlap; - -},{"./rectangle":17}],9:[function(require,module,exports){ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -var rectangle_1 = require("./rectangle"); -var vpsc_1 = require("./vpsc"); -var shortestpaths_1 = require("./shortestpaths"); -var NodeWrapper = (function () { - function NodeWrapper(id, rect, children) { - this.id = id; - this.rect = rect; - this.children = children; - this.leaf = typeof children === 'undefined' || children.length === 0; - } - return NodeWrapper; -}()); -exports.NodeWrapper = NodeWrapper; -var Vert = (function () { - function Vert(id, x, y, node, line) { - if (node === void 0) { node = null; } - if (line === void 0) { line = null; } - this.id = id; - this.x = x; - this.y = y; - this.node = node; - this.line = line; - } - return Vert; -}()); -exports.Vert = Vert; -var LongestCommonSubsequence = (function () { - function LongestCommonSubsequence(s, t) { - this.s = s; - this.t = t; - var mf = LongestCommonSubsequence.findMatch(s, t); - var tr = t.slice(0).reverse(); - var mr = LongestCommonSubsequence.findMatch(s, tr); - if (mf.length >= mr.length) { - this.length = mf.length; - this.si = mf.si; - this.ti = mf.ti; - this.reversed = false; - } - else { - this.length = mr.length; - this.si = mr.si; - this.ti = t.length - mr.ti - mr.length; - this.reversed = true; - } - } - LongestCommonSubsequence.findMatch = function (s, t) { - var m = s.length; - var n = t.length; - var match = { length: 0, si: -1, ti: -1 }; - var l = new Array(m); - for (var i = 0; i < m; i++) { - l[i] = new Array(n); - for (var j = 0; j < n; j++) - if (s[i] === t[j]) { - var v = l[i][j] = (i === 0 || j === 0) ? 1 : l[i - 1][j - 1] + 1; - if (v > match.length) { - match.length = v; - match.si = i - v + 1; - match.ti = j - v + 1; - } - ; - } - else - l[i][j] = 0; - } - return match; - }; - LongestCommonSubsequence.prototype.getSequence = function () { - return this.length >= 0 ? this.s.slice(this.si, this.si + this.length) : []; - }; - return LongestCommonSubsequence; -}()); -exports.LongestCommonSubsequence = LongestCommonSubsequence; -var GridRouter = (function () { - function GridRouter(originalnodes, accessor, groupPadding) { - var _this = this; - if (groupPadding === void 0) { groupPadding = 12; } - this.originalnodes = originalnodes; - this.groupPadding = groupPadding; - this.leaves = null; - this.nodes = originalnodes.map(function (v, i) { return new NodeWrapper(i, accessor.getBounds(v), accessor.getChildren(v)); }); - this.leaves = this.nodes.filter(function (v) { return v.leaf; }); - this.groups = this.nodes.filter(function (g) { return !g.leaf; }); - this.cols = this.getGridLines('x'); - this.rows = this.getGridLines('y'); - this.groups.forEach(function (v) { - return v.children.forEach(function (c) { return _this.nodes[c].parent = v; }); - }); - this.root = { children: [] }; - this.nodes.forEach(function (v) { - if (typeof v.parent === 'undefined') { - v.parent = _this.root; - _this.root.children.push(v.id); - } - v.ports = []; - }); - this.backToFront = this.nodes.slice(0); - this.backToFront.sort(function (x, y) { return _this.getDepth(x) - _this.getDepth(y); }); - var frontToBackGroups = this.backToFront.slice(0).reverse().filter(function (g) { return !g.leaf; }); - frontToBackGroups.forEach(function (v) { - var r = rectangle_1.Rectangle.empty(); - v.children.forEach(function (c) { return r = r.union(_this.nodes[c].rect); }); - v.rect = r.inflate(_this.groupPadding); - }); - var colMids = this.midPoints(this.cols.map(function (r) { return r.pos; })); - var rowMids = this.midPoints(this.rows.map(function (r) { return r.pos; })); - var rowx = colMids[0], rowX = colMids[colMids.length - 1]; - var coly = rowMids[0], colY = rowMids[rowMids.length - 1]; - var hlines = this.rows.map(function (r) { return ({ x1: rowx, x2: rowX, y1: r.pos, y2: r.pos }); }) - .concat(rowMids.map(function (m) { return ({ x1: rowx, x2: rowX, y1: m, y2: m }); })); - var vlines = this.cols.map(function (c) { return ({ x1: c.pos, x2: c.pos, y1: coly, y2: colY }); }) - .concat(colMids.map(function (m) { return ({ x1: m, x2: m, y1: coly, y2: colY }); })); - var lines = hlines.concat(vlines); - lines.forEach(function (l) { return l.verts = []; }); - this.verts = []; - this.edges = []; - hlines.forEach(function (h) { - return vlines.forEach(function (v) { - var p = new Vert(_this.verts.length, v.x1, h.y1); - h.verts.push(p); - v.verts.push(p); - _this.verts.push(p); - var i = _this.backToFront.length; - while (i-- > 0) { - var node = _this.backToFront[i], r = node.rect; - var dx = Math.abs(p.x - r.cx()), dy = Math.abs(p.y - r.cy()); - if (dx < r.width() / 2 && dy < r.height() / 2) { - p.node = node; - break; - } - } - }); - }); - lines.forEach(function (l, li) { - _this.nodes.forEach(function (v, i) { - v.rect.lineIntersections(l.x1, l.y1, l.x2, l.y2).forEach(function (intersect, j) { - var p = new Vert(_this.verts.length, intersect.x, intersect.y, v, l); - _this.verts.push(p); - l.verts.push(p); - v.ports.push(p); - }); - }); - var isHoriz = Math.abs(l.y1 - l.y2) < 0.1; - var delta = function (a, b) { return isHoriz ? b.x - a.x : b.y - a.y; }; - l.verts.sort(delta); - for (var i = 1; i < l.verts.length; i++) { - var u = l.verts[i - 1], v = l.verts[i]; - if (u.node && u.node === v.node && u.node.leaf) - continue; - _this.edges.push({ source: u.id, target: v.id, length: Math.abs(delta(u, v)) }); - } - }); - } - GridRouter.prototype.avg = function (a) { return a.reduce(function (x, y) { return x + y; }) / a.length; }; - GridRouter.prototype.getGridLines = function (axis) { - var columns = []; - var ls = this.leaves.slice(0, this.leaves.length); - while (ls.length > 0) { - var overlapping = ls.filter(function (v) { return v.rect['overlap' + axis.toUpperCase()](ls[0].rect); }); - var col = { - nodes: overlapping, - pos: this.avg(overlapping.map(function (v) { return v.rect['c' + axis](); })) - }; - columns.push(col); - col.nodes.forEach(function (v) { return ls.splice(ls.indexOf(v), 1); }); - } - columns.sort(function (a, b) { return a.pos - b.pos; }); - return columns; - }; - GridRouter.prototype.getDepth = function (v) { - var depth = 0; - while (v.parent !== this.root) { - depth++; - v = v.parent; - } - return depth; - }; - GridRouter.prototype.midPoints = function (a) { - var gap = a[1] - a[0]; - var mids = [a[0] - gap / 2]; - for (var i = 1; i < a.length; i++) { - mids.push((a[i] + a[i - 1]) / 2); - } - mids.push(a[a.length - 1] + gap / 2); - return mids; - }; - GridRouter.prototype.findLineage = function (v) { - var lineage = [v]; - do { - v = v.parent; - lineage.push(v); - } while (v !== this.root); - return lineage.reverse(); - }; - GridRouter.prototype.findAncestorPathBetween = function (a, b) { - var aa = this.findLineage(a), ba = this.findLineage(b), i = 0; - while (aa[i] === ba[i]) - i++; - return { commonAncestor: aa[i - 1], lineages: aa.slice(i).concat(ba.slice(i)) }; - }; - GridRouter.prototype.siblingObstacles = function (a, b) { - var _this = this; - var path = this.findAncestorPathBetween(a, b); - var lineageLookup = {}; - path.lineages.forEach(function (v) { return lineageLookup[v.id] = {}; }); - var obstacles = path.commonAncestor.children.filter(function (v) { return !(v in lineageLookup); }); - path.lineages - .filter(function (v) { return v.parent !== path.commonAncestor; }) - .forEach(function (v) { return obstacles = obstacles.concat(v.parent.children.filter(function (c) { return c !== v.id; })); }); - return obstacles.map(function (v) { return _this.nodes[v]; }); - }; - GridRouter.getSegmentSets = function (routes, x, y) { - var vsegments = []; - for (var ei = 0; ei < routes.length; ei++) { - var route = routes[ei]; - for (var si = 0; si < route.length; si++) { - var s = route[si]; - s.edgeid = ei; - s.i = si; - var sdx = s[1][x] - s[0][x]; - if (Math.abs(sdx) < 0.1) { - vsegments.push(s); - } - } - } - vsegments.sort(function (a, b) { return a[0][x] - b[0][x]; }); - var vsegmentsets = []; - var segmentset = null; - for (var i = 0; i < vsegments.length; i++) { - var s = vsegments[i]; - if (!segmentset || Math.abs(s[0][x] - segmentset.pos) > 0.1) { - segmentset = { pos: s[0][x], segments: [] }; - vsegmentsets.push(segmentset); - } - segmentset.segments.push(s); - } - return vsegmentsets; - }; - GridRouter.nudgeSegs = function (x, y, routes, segments, leftOf, gap) { - var n = segments.length; - if (n <= 1) - return; - var vs = segments.map(function (s) { return new vpsc_1.Variable(s[0][x]); }); - var cs = []; - for (var i = 0; i < n; i++) { - for (var j = 0; j < n; j++) { - if (i === j) - continue; - var s1 = segments[i], s2 = segments[j], e1 = s1.edgeid, e2 = s2.edgeid, lind = -1, rind = -1; - if (x == 'x') { - if (leftOf(e1, e2)) { - if (s1[0][y] < s1[1][y]) { - lind = j, rind = i; - } - else { - lind = i, rind = j; - } - } - } - else { - if (leftOf(e1, e2)) { - if (s1[0][y] < s1[1][y]) { - lind = i, rind = j; - } - else { - lind = j, rind = i; - } - } - } - if (lind >= 0) { - cs.push(new vpsc_1.Constraint(vs[lind], vs[rind], gap)); - } - } - } - var solver = new vpsc_1.Solver(vs, cs); - solver.solve(); - vs.forEach(function (v, i) { - var s = segments[i]; - var pos = v.position(); - s[0][x] = s[1][x] = pos; - var route = routes[s.edgeid]; - if (s.i > 0) - route[s.i - 1][1][x] = pos; - if (s.i < route.length - 1) - route[s.i + 1][0][x] = pos; - }); - }; - GridRouter.nudgeSegments = function (routes, x, y, leftOf, gap) { - var vsegmentsets = GridRouter.getSegmentSets(routes, x, y); - for (var i = 0; i < vsegmentsets.length; i++) { - var ss = vsegmentsets[i]; - var events = []; - for (var j = 0; j < ss.segments.length; j++) { - var s = ss.segments[j]; - events.push({ type: 0, s: s, pos: Math.min(s[0][y], s[1][y]) }); - events.push({ type: 1, s: s, pos: Math.max(s[0][y], s[1][y]) }); - } - events.sort(function (a, b) { return a.pos - b.pos + a.type - b.type; }); - var open = []; - var openCount = 0; - events.forEach(function (e) { - if (e.type === 0) { - open.push(e.s); - openCount++; - } - else { - openCount--; - } - if (openCount == 0) { - GridRouter.nudgeSegs(x, y, routes, open, leftOf, gap); - open = []; - } - }); - } - }; - GridRouter.prototype.routeEdges = function (edges, nudgeGap, source, target) { - var _this = this; - var routePaths = edges.map(function (e) { return _this.route(source(e), target(e)); }); - var order = GridRouter.orderEdges(routePaths); - var routes = routePaths.map(function (e) { return GridRouter.makeSegments(e); }); - GridRouter.nudgeSegments(routes, 'x', 'y', order, nudgeGap); - GridRouter.nudgeSegments(routes, 'y', 'x', order, nudgeGap); - GridRouter.unreverseEdges(routes, routePaths); - return routes; - }; - GridRouter.unreverseEdges = function (routes, routePaths) { - routes.forEach(function (segments, i) { - var path = routePaths[i]; - if (path.reversed) { - segments.reverse(); - segments.forEach(function (segment) { - segment.reverse(); - }); - } - }); - }; - GridRouter.angleBetween2Lines = function (line1, line2) { - var angle1 = Math.atan2(line1[0].y - line1[1].y, line1[0].x - line1[1].x); - var angle2 = Math.atan2(line2[0].y - line2[1].y, line2[0].x - line2[1].x); - var diff = angle1 - angle2; - if (diff > Math.PI || diff < -Math.PI) { - diff = angle2 - angle1; - } - return diff; - }; - GridRouter.isLeft = function (a, b, c) { - return ((b.x - a.x) * (c.y - a.y) - (b.y - a.y) * (c.x - a.x)) <= 0; - }; - GridRouter.getOrder = function (pairs) { - var outgoing = {}; - for (var i = 0; i < pairs.length; i++) { - var p = pairs[i]; - if (typeof outgoing[p.l] === 'undefined') - outgoing[p.l] = {}; - outgoing[p.l][p.r] = true; - } - return function (l, r) { return typeof outgoing[l] !== 'undefined' && outgoing[l][r]; }; - }; - GridRouter.orderEdges = function (edges) { - var edgeOrder = []; - for (var i = 0; i < edges.length - 1; i++) { - for (var j = i + 1; j < edges.length; j++) { - var e = edges[i], f = edges[j], lcs = new LongestCommonSubsequence(e, f); - var u, vi, vj; - if (lcs.length === 0) - continue; - if (lcs.reversed) { - f.reverse(); - f.reversed = true; - lcs = new LongestCommonSubsequence(e, f); - } - if ((lcs.si <= 0 || lcs.ti <= 0) && - (lcs.si + lcs.length >= e.length || lcs.ti + lcs.length >= f.length)) { - edgeOrder.push({ l: i, r: j }); - continue; - } - if (lcs.si + lcs.length >= e.length || lcs.ti + lcs.length >= f.length) { - u = e[lcs.si + 1]; - vj = e[lcs.si - 1]; - vi = f[lcs.ti - 1]; - } - else { - u = e[lcs.si + lcs.length - 2]; - vi = e[lcs.si + lcs.length]; - vj = f[lcs.ti + lcs.length]; - } - if (GridRouter.isLeft(u, vi, vj)) { - edgeOrder.push({ l: j, r: i }); - } - else { - edgeOrder.push({ l: i, r: j }); - } - } - } - return GridRouter.getOrder(edgeOrder); - }; - GridRouter.makeSegments = function (path) { - function copyPoint(p) { - return { x: p.x, y: p.y }; - } - var isStraight = function (a, b, c) { return Math.abs((b.x - a.x) * (c.y - a.y) - (b.y - a.y) * (c.x - a.x)) < 0.001; }; - var segments = []; - var a = copyPoint(path[0]); - for (var i = 1; i < path.length; i++) { - var b = copyPoint(path[i]), c = i < path.length - 1 ? path[i + 1] : null; - if (!c || !isStraight(a, b, c)) { - segments.push([a, b]); - a = b; - } - } - return segments; - }; - GridRouter.prototype.route = function (s, t) { - var _this = this; - var source = this.nodes[s], target = this.nodes[t]; - this.obstacles = this.siblingObstacles(source, target); - var obstacleLookup = {}; - this.obstacles.forEach(function (o) { return obstacleLookup[o.id] = o; }); - this.passableEdges = this.edges.filter(function (e) { - var u = _this.verts[e.source], v = _this.verts[e.target]; - return !(u.node && u.node.id in obstacleLookup - || v.node && v.node.id in obstacleLookup); - }); - for (var i = 1; i < source.ports.length; i++) { - var u = source.ports[0].id; - var v = source.ports[i].id; - this.passableEdges.push({ - source: u, - target: v, - length: 0 - }); - } - for (var i = 1; i < target.ports.length; i++) { - var u = target.ports[0].id; - var v = target.ports[i].id; - this.passableEdges.push({ - source: u, - target: v, - length: 0 - }); - } - var getSource = function (e) { return e.source; }, getTarget = function (e) { return e.target; }, getLength = function (e) { return e.length; }; - var shortestPathCalculator = new shortestpaths_1.Calculator(this.verts.length, this.passableEdges, getSource, getTarget, getLength); - var bendPenalty = function (u, v, w) { - var a = _this.verts[u], b = _this.verts[v], c = _this.verts[w]; - var dx = Math.abs(c.x - a.x), dy = Math.abs(c.y - a.y); - if (a.node === source && a.node === b.node || b.node === target && b.node === c.node) - return 0; - return dx > 1 && dy > 1 ? 1000 : 0; - }; - var shortestPath = shortestPathCalculator.PathFromNodeToNodeWithPrevCost(source.ports[0].id, target.ports[0].id, bendPenalty); - var pathPoints = shortestPath.reverse().map(function (vi) { return _this.verts[vi]; }); - pathPoints.push(this.nodes[target.id].ports[0]); - return pathPoints.filter(function (v, i) { - return !(i < pathPoints.length - 1 && pathPoints[i + 1].node === source && v.node === source - || i > 0 && v.node === target && pathPoints[i - 1].node === target); - }); - }; - GridRouter.getRoutePath = function (route, cornerradius, arrowwidth, arrowheight) { - var result = { - routepath: 'M ' + route[0][0].x + ' ' + route[0][0].y + ' ', - arrowpath: '' - }; - if (route.length > 1) { - for (var i = 0; i < route.length; i++) { - var li = route[i]; - var x = li[1].x, y = li[1].y; - var dx = x - li[0].x; - var dy = y - li[0].y; - if (i < route.length - 1) { - if (Math.abs(dx) > 0) { - x -= dx / Math.abs(dx) * cornerradius; - } - else { - y -= dy / Math.abs(dy) * cornerradius; - } - result.routepath += 'L ' + x + ' ' + y + ' '; - var l = route[i + 1]; - var x0 = l[0].x, y0 = l[0].y; - var x1 = l[1].x; - var y1 = l[1].y; - dx = x1 - x0; - dy = y1 - y0; - var angle = GridRouter.angleBetween2Lines(li, l) < 0 ? 1 : 0; - var x2, y2; - if (Math.abs(dx) > 0) { - x2 = x0 + dx / Math.abs(dx) * cornerradius; - y2 = y0; - } - else { - x2 = x0; - y2 = y0 + dy / Math.abs(dy) * cornerradius; - } - var cx = Math.abs(x2 - x); - var cy = Math.abs(y2 - y); - result.routepath += 'A ' + cx + ' ' + cy + ' 0 0 ' + angle + ' ' + x2 + ' ' + y2 + ' '; - } - else { - var arrowtip = [x, y]; - var arrowcorner1, arrowcorner2; - if (Math.abs(dx) > 0) { - x -= dx / Math.abs(dx) * arrowheight; - arrowcorner1 = [x, y + arrowwidth]; - arrowcorner2 = [x, y - arrowwidth]; - } - else { - y -= dy / Math.abs(dy) * arrowheight; - arrowcorner1 = [x + arrowwidth, y]; - arrowcorner2 = [x - arrowwidth, y]; - } - result.routepath += 'L ' + x + ' ' + y + ' '; - if (arrowheight > 0) { - result.arrowpath = 'M ' + arrowtip[0] + ' ' + arrowtip[1] + ' L ' + arrowcorner1[0] + ' ' + arrowcorner1[1] - + ' L ' + arrowcorner2[0] + ' ' + arrowcorner2[1]; - } - } - } - } - else { - var li = route[0]; - var x = li[1].x, y = li[1].y; - var dx = x - li[0].x; - var dy = y - li[0].y; - var arrowtip = [x, y]; - var arrowcorner1, arrowcorner2; - if (Math.abs(dx) > 0) { - x -= dx / Math.abs(dx) * arrowheight; - arrowcorner1 = [x, y + arrowwidth]; - arrowcorner2 = [x, y - arrowwidth]; - } - else { - y -= dy / Math.abs(dy) * arrowheight; - arrowcorner1 = [x + arrowwidth, y]; - arrowcorner2 = [x - arrowwidth, y]; - } - result.routepath += 'L ' + x + ' ' + y + ' '; - if (arrowheight > 0) { - result.arrowpath = 'M ' + arrowtip[0] + ' ' + arrowtip[1] + ' L ' + arrowcorner1[0] + ' ' + arrowcorner1[1] - + ' L ' + arrowcorner2[0] + ' ' + arrowcorner2[1]; - } - } - return result; - }; - return GridRouter; -}()); -exports.GridRouter = GridRouter; - -},{"./rectangle":17,"./shortestpaths":18,"./vpsc":19}],10:[function(require,module,exports){ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -var packingOptions = { - PADDING: 10, - GOLDEN_SECTION: (1 + Math.sqrt(5)) / 2, - FLOAT_EPSILON: 0.0001, - MAX_INERATIONS: 100 -}; -function applyPacking(graphs, w, h, node_size, desired_ratio, centerGraph) { - if (desired_ratio === void 0) { desired_ratio = 1; } - if (centerGraph === void 0) { centerGraph = true; } - var init_x = 0, init_y = 0, svg_width = w, svg_height = h, desired_ratio = typeof desired_ratio !== 'undefined' ? desired_ratio : 1, node_size = typeof node_size !== 'undefined' ? node_size : 0, real_width = 0, real_height = 0, min_width = 0, global_bottom = 0, line = []; - if (graphs.length == 0) - return; - calculate_bb(graphs); - apply(graphs, desired_ratio); - if (centerGraph) { - put_nodes_to_right_positions(graphs); - } - function calculate_bb(graphs) { - graphs.forEach(function (g) { - calculate_single_bb(g); - }); - function calculate_single_bb(graph) { - var min_x = Number.MAX_VALUE, min_y = Number.MAX_VALUE, max_x = 0, max_y = 0; - graph.array.forEach(function (v) { - var w = typeof v.width !== 'undefined' ? v.width : node_size; - var h = typeof v.height !== 'undefined' ? v.height : node_size; - w /= 2; - h /= 2; - max_x = Math.max(v.x + w, max_x); - min_x = Math.min(v.x - w, min_x); - max_y = Math.max(v.y + h, max_y); - min_y = Math.min(v.y - h, min_y); - }); - graph.width = max_x - min_x; - graph.height = max_y - min_y; - } - } - function put_nodes_to_right_positions(graphs) { - graphs.forEach(function (g) { - var center = { x: 0, y: 0 }; - g.array.forEach(function (node) { - center.x += node.x; - center.y += node.y; - }); - center.x /= g.array.length; - center.y /= g.array.length; - var corner = { x: center.x - g.width / 2, y: center.y - g.height / 2 }; - var offset = { x: g.x - corner.x + svg_width / 2 - real_width / 2, y: g.y - corner.y + svg_height / 2 - real_height / 2 }; - g.array.forEach(function (node) { - node.x += offset.x; - node.y += offset.y; - }); - }); - } - function apply(data, desired_ratio) { - var curr_best_f = Number.POSITIVE_INFINITY; - var curr_best = 0; - data.sort(function (a, b) { return b.height - a.height; }); - min_width = data.reduce(function (a, b) { - return a.width < b.width ? a.width : b.width; - }); - var left = x1 = min_width; - var right = x2 = get_entire_width(data); - var iterationCounter = 0; - var f_x1 = Number.MAX_VALUE; - var f_x2 = Number.MAX_VALUE; - var flag = -1; - var dx = Number.MAX_VALUE; - var df = Number.MAX_VALUE; - while ((dx > min_width) || df > packingOptions.FLOAT_EPSILON) { - if (flag != 1) { - var x1 = right - (right - left) / packingOptions.GOLDEN_SECTION; - var f_x1 = step(data, x1); - } - if (flag != 0) { - var x2 = left + (right - left) / packingOptions.GOLDEN_SECTION; - var f_x2 = step(data, x2); - } - dx = Math.abs(x1 - x2); - df = Math.abs(f_x1 - f_x2); - if (f_x1 < curr_best_f) { - curr_best_f = f_x1; - curr_best = x1; - } - if (f_x2 < curr_best_f) { - curr_best_f = f_x2; - curr_best = x2; - } - if (f_x1 > f_x2) { - left = x1; - x1 = x2; - f_x1 = f_x2; - flag = 1; - } - else { - right = x2; - x2 = x1; - f_x2 = f_x1; - flag = 0; - } - if (iterationCounter++ > 100) { - break; - } - } - step(data, curr_best); - } - function step(data, max_width) { - line = []; - real_width = 0; - real_height = 0; - global_bottom = init_y; - for (var i = 0; i < data.length; i++) { - var o = data[i]; - put_rect(o, max_width); - } - return Math.abs(get_real_ratio() - desired_ratio); - } - function put_rect(rect, max_width) { - var parent = undefined; - for (var i = 0; i < line.length; i++) { - if ((line[i].space_left >= rect.height) && (line[i].x + line[i].width + rect.width + packingOptions.PADDING - max_width) <= packingOptions.FLOAT_EPSILON) { - parent = line[i]; - break; - } - } - line.push(rect); - if (parent !== undefined) { - rect.x = parent.x + parent.width + packingOptions.PADDING; - rect.y = parent.bottom; - rect.space_left = rect.height; - rect.bottom = rect.y; - parent.space_left -= rect.height + packingOptions.PADDING; - parent.bottom += rect.height + packingOptions.PADDING; - } - else { - rect.y = global_bottom; - global_bottom += rect.height + packingOptions.PADDING; - rect.x = init_x; - rect.bottom = rect.y; - rect.space_left = rect.height; - } - if (rect.y + rect.height - real_height > -packingOptions.FLOAT_EPSILON) - real_height = rect.y + rect.height - init_y; - if (rect.x + rect.width - real_width > -packingOptions.FLOAT_EPSILON) - real_width = rect.x + rect.width - init_x; - } - ; - function get_entire_width(data) { - var width = 0; - data.forEach(function (d) { return width += d.width + packingOptions.PADDING; }); - return width; - } - function get_real_ratio() { - return (real_width / real_height); - } -} -exports.applyPacking = applyPacking; -function separateGraphs(nodes, links) { - var marks = {}; - var ways = {}; - var graphs = []; - var clusters = 0; - for (var i = 0; i < links.length; i++) { - var link = links[i]; - var n1 = link.source; - var n2 = link.target; - if (ways[n1.index]) - ways[n1.index].push(n2); - else - ways[n1.index] = [n2]; - if (ways[n2.index]) - ways[n2.index].push(n1); - else - ways[n2.index] = [n1]; - } - for (var i = 0; i < nodes.length; i++) { - var node = nodes[i]; - if (marks[node.index]) - continue; - explore_node(node, true); - } - function explore_node(n, is_new) { - if (marks[n.index] !== undefined) - return; - if (is_new) { - clusters++; - graphs.push({ array: [] }); - } - marks[n.index] = clusters; - graphs[clusters - 1].array.push(n); - var adjacent = ways[n.index]; - if (!adjacent) - return; - for (var j = 0; j < adjacent.length; j++) { - explore_node(adjacent[j], false); - } - } - return graphs; -} -exports.separateGraphs = separateGraphs; - -},{}],11:[function(require,module,exports){ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -var powergraph = require("./powergraph"); -var linklengths_1 = require("./linklengths"); -var descent_1 = require("./descent"); -var rectangle_1 = require("./rectangle"); -var shortestpaths_1 = require("./shortestpaths"); -var geom_1 = require("./geom"); -var handledisconnected_1 = require("./handledisconnected"); -var EventType; -(function (EventType) { - EventType[EventType["start"] = 0] = "start"; - EventType[EventType["tick"] = 1] = "tick"; - EventType[EventType["end"] = 2] = "end"; -})(EventType = exports.EventType || (exports.EventType = {})); -; -function isGroup(g) { - return typeof g.leaves !== 'undefined' || typeof g.groups !== 'undefined'; -} -var Layout = (function () { - function Layout() { - var _this = this; - this._canvasSize = [1, 1]; - this._linkDistance = 20; - this._defaultNodeSize = 10; - this._linkLengthCalculator = null; - this._linkType = null; - this._avoidOverlaps = false; - this._handleDisconnected = true; - this._running = false; - this._nodes = []; - this._groups = []; - this._rootGroup = null; - this._links = []; - this._constraints = []; - this._distanceMatrix = null; - this._descent = null; - this._directedLinkConstraints = null; - this._threshold = 0.01; - this._visibilityGraph = null; - this._groupCompactness = 1e-6; - this.event = null; - this.linkAccessor = { - getSourceIndex: Layout.getSourceIndex, - getTargetIndex: Layout.getTargetIndex, - setLength: Layout.setLinkLength, - getType: function (l) { return typeof _this._linkType === "function" ? _this._linkType(l) : 0; } - }; - } - Layout.prototype.on = function (e, listener) { - if (!this.event) - this.event = {}; - if (typeof e === 'string') { - this.event[EventType[e]] = listener; - } - else { - this.event[e] = listener; - } - return this; - }; - Layout.prototype.trigger = function (e) { - if (this.event && typeof this.event[e.type] !== 'undefined') { - this.event[e.type](e); - } - }; - Layout.prototype.kick = function () { - while (!this.tick()) - ; - }; - Layout.prototype.tick = function () { - if (this._alpha < this._threshold) { - this._running = false; - this.trigger({ type: EventType.end, alpha: this._alpha = 0, stress: this._lastStress }); - return true; - } - var n = this._nodes.length, m = this._links.length; - var o, i; - this._descent.locks.clear(); - for (i = 0; i < n; ++i) { - o = this._nodes[i]; - if (o.fixed) { - if (typeof o.px === 'undefined' || typeof o.py === 'undefined') { - o.px = o.x; - o.py = o.y; - } - var p = [o.px, o.py]; - this._descent.locks.add(i, p); - } - } - var s1 = this._descent.rungeKutta(); - if (s1 === 0) { - this._alpha = 0; - } - else if (typeof this._lastStress !== 'undefined') { - this._alpha = s1; - } - this._lastStress = s1; - this.updateNodePositions(); - this.trigger({ type: EventType.tick, alpha: this._alpha, stress: this._lastStress }); - return false; - }; - Layout.prototype.updateNodePositions = function () { - var x = this._descent.x[0], y = this._descent.x[1]; - var o, i = this._nodes.length; - while (i--) { - o = this._nodes[i]; - o.x = x[i]; - o.y = y[i]; - } - }; - Layout.prototype.nodes = function (v) { - if (!v) { - if (this._nodes.length === 0 && this._links.length > 0) { - var n = 0; - this._links.forEach(function (l) { - n = Math.max(n, l.source, l.target); - }); - this._nodes = new Array(++n); - for (var i = 0; i < n; ++i) { - this._nodes[i] = {}; - } - } - return this._nodes; - } - this._nodes = v; - return this; - }; - Layout.prototype.groups = function (x) { - var _this = this; - if (!x) - return this._groups; - this._groups = x; - this._rootGroup = {}; - this._groups.forEach(function (g) { - if (typeof g.padding === "undefined") - g.padding = 1; - if (typeof g.leaves !== "undefined") { - g.leaves.forEach(function (v, i) { - if (typeof v === 'number') - (g.leaves[i] = _this._nodes[v]).parent = g; - }); - } - if (typeof g.groups !== "undefined") { - g.groups.forEach(function (gi, i) { - if (typeof gi === 'number') - (g.groups[i] = _this._groups[gi]).parent = g; - }); - } - }); - this._rootGroup.leaves = this._nodes.filter(function (v) { return typeof v.parent === 'undefined'; }); - this._rootGroup.groups = this._groups.filter(function (g) { return typeof g.parent === 'undefined'; }); - return this; - }; - Layout.prototype.powerGraphGroups = function (f) { - var g = powergraph.getGroups(this._nodes, this._links, this.linkAccessor, this._rootGroup); - this.groups(g.groups); - f(g); - return this; - }; - Layout.prototype.avoidOverlaps = function (v) { - if (!arguments.length) - return this._avoidOverlaps; - this._avoidOverlaps = v; - return this; - }; - Layout.prototype.handleDisconnected = function (v) { - if (!arguments.length) - return this._handleDisconnected; - this._handleDisconnected = v; - return this; - }; - Layout.prototype.flowLayout = function (axis, minSeparation) { - if (!arguments.length) - axis = 'y'; - this._directedLinkConstraints = { - axis: axis, - getMinSeparation: typeof minSeparation === 'number' ? function () { return minSeparation; } : minSeparation - }; - return this; - }; - Layout.prototype.links = function (x) { - if (!arguments.length) - return this._links; - this._links = x; - return this; - }; - Layout.prototype.constraints = function (c) { - if (!arguments.length) - return this._constraints; - this._constraints = c; - return this; - }; - Layout.prototype.distanceMatrix = function (d) { - if (!arguments.length) - return this._distanceMatrix; - this._distanceMatrix = d; - return this; - }; - Layout.prototype.size = function (x) { - if (!x) - return this._canvasSize; - this._canvasSize = x; - return this; - }; - Layout.prototype.defaultNodeSize = function (x) { - if (!x) - return this._defaultNodeSize; - this._defaultNodeSize = x; - return this; - }; - Layout.prototype.groupCompactness = function (x) { - if (!x) - return this._groupCompactness; - this._groupCompactness = x; - return this; - }; - Layout.prototype.linkDistance = function (x) { - if (!x) { - return this._linkDistance; - } - this._linkDistance = typeof x === "function" ? x : +x; - this._linkLengthCalculator = null; - return this; - }; - Layout.prototype.linkType = function (f) { - this._linkType = f; - return this; - }; - Layout.prototype.convergenceThreshold = function (x) { - if (!x) - return this._threshold; - this._threshold = typeof x === "function" ? x : +x; - return this; - }; - Layout.prototype.alpha = function (x) { - if (!arguments.length) - return this._alpha; - else { - x = +x; - if (this._alpha) { - if (x > 0) - this._alpha = x; - else - this._alpha = 0; - } - else if (x > 0) { - if (!this._running) { - this._running = true; - this.trigger({ type: EventType.start, alpha: this._alpha = x }); - this.kick(); - } - } - return this; - } - }; - Layout.prototype.getLinkLength = function (link) { - return typeof this._linkDistance === "function" ? +(this._linkDistance(link)) : this._linkDistance; - }; - Layout.setLinkLength = function (link, length) { - link.length = length; - }; - Layout.prototype.getLinkType = function (link) { - return typeof this._linkType === "function" ? this._linkType(link) : 0; - }; - Layout.prototype.symmetricDiffLinkLengths = function (idealLength, w) { - var _this = this; - if (w === void 0) { w = 1; } - this.linkDistance(function (l) { return idealLength * l.length; }); - this._linkLengthCalculator = function () { return linklengths_1.symmetricDiffLinkLengths(_this._links, _this.linkAccessor, w); }; - return this; - }; - Layout.prototype.jaccardLinkLengths = function (idealLength, w) { - var _this = this; - if (w === void 0) { w = 1; } - this.linkDistance(function (l) { return idealLength * l.length; }); - this._linkLengthCalculator = function () { return linklengths_1.jaccardLinkLengths(_this._links, _this.linkAccessor, w); }; - return this; - }; - Layout.prototype.start = function (initialUnconstrainedIterations, initialUserConstraintIterations, initialAllConstraintsIterations, gridSnapIterations, keepRunning, centerGraph) { - var _this = this; - if (initialUnconstrainedIterations === void 0) { initialUnconstrainedIterations = 0; } - if (initialUserConstraintIterations === void 0) { initialUserConstraintIterations = 0; } - if (initialAllConstraintsIterations === void 0) { initialAllConstraintsIterations = 0; } - if (gridSnapIterations === void 0) { gridSnapIterations = 0; } - if (keepRunning === void 0) { keepRunning = true; } - if (centerGraph === void 0) { centerGraph = true; } - var i, j, n = this.nodes().length, N = n + 2 * this._groups.length, m = this._links.length, w = this._canvasSize[0], h = this._canvasSize[1]; - var x = new Array(N), y = new Array(N); - var G = null; - var ao = this._avoidOverlaps; - this._nodes.forEach(function (v, i) { - v.index = i; - if (typeof v.x === 'undefined') { - v.x = w / 2, v.y = h / 2; - } - x[i] = v.x, y[i] = v.y; - }); - if (this._linkLengthCalculator) - this._linkLengthCalculator(); - var distances; - if (this._distanceMatrix) { - distances = this._distanceMatrix; - } - else { - distances = (new shortestpaths_1.Calculator(N, this._links, Layout.getSourceIndex, Layout.getTargetIndex, function (l) { return _this.getLinkLength(l); })).DistanceMatrix(); - G = descent_1.Descent.createSquareMatrix(N, function () { return 2; }); - this._links.forEach(function (l) { - if (typeof l.source == "number") - l.source = _this._nodes[l.source]; - if (typeof l.target == "number") - l.target = _this._nodes[l.target]; - }); - this._links.forEach(function (e) { - var u = Layout.getSourceIndex(e), v = Layout.getTargetIndex(e); - G[u][v] = G[v][u] = e.weight || 1; - }); - } - var D = descent_1.Descent.createSquareMatrix(N, function (i, j) { - return distances[i][j]; - }); - if (this._rootGroup && typeof this._rootGroup.groups !== 'undefined') { - var i = n; - var addAttraction = function (i, j, strength, idealDistance) { - G[i][j] = G[j][i] = strength; - D[i][j] = D[j][i] = idealDistance; - }; - this._groups.forEach(function (g) { - addAttraction(i, i + 1, _this._groupCompactness, 0.1); - x[i] = 0, y[i++] = 0; - x[i] = 0, y[i++] = 0; - }); - } - else - this._rootGroup = { leaves: this._nodes, groups: [] }; - var curConstraints = this._constraints || []; - if (this._directedLinkConstraints) { - this.linkAccessor.getMinSeparation = this._directedLinkConstraints.getMinSeparation; - curConstraints = curConstraints.concat(linklengths_1.generateDirectedEdgeConstraints(n, this._links, this._directedLinkConstraints.axis, (this.linkAccessor))); - } - this.avoidOverlaps(false); - this._descent = new descent_1.Descent([x, y], D); - this._descent.locks.clear(); - for (var i = 0; i < n; ++i) { - var o = this._nodes[i]; - if (o.fixed) { - o.px = o.x; - o.py = o.y; - var p = [o.x, o.y]; - this._descent.locks.add(i, p); - } - } - this._descent.threshold = this._threshold; - this.initialLayout(initialUnconstrainedIterations, x, y); - if (curConstraints.length > 0) - this._descent.project = new rectangle_1.Projection(this._nodes, this._groups, this._rootGroup, curConstraints).projectFunctions(); - this._descent.run(initialUserConstraintIterations); - this.separateOverlappingComponents(w, h, centerGraph); - this.avoidOverlaps(ao); - if (ao) { - this._nodes.forEach(function (v, i) { v.x = x[i], v.y = y[i]; }); - this._descent.project = new rectangle_1.Projection(this._nodes, this._groups, this._rootGroup, curConstraints, true).projectFunctions(); - this._nodes.forEach(function (v, i) { x[i] = v.x, y[i] = v.y; }); - } - this._descent.G = G; - this._descent.run(initialAllConstraintsIterations); - if (gridSnapIterations) { - this._descent.snapStrength = 1000; - this._descent.snapGridSize = this._nodes[0].width; - this._descent.numGridSnapNodes = n; - this._descent.scaleSnapByMaxH = n != N; - var G0 = descent_1.Descent.createSquareMatrix(N, function (i, j) { - if (i >= n || j >= n) - return G[i][j]; - return 0; - }); - this._descent.G = G0; - this._descent.run(gridSnapIterations); - } - this.updateNodePositions(); - this.separateOverlappingComponents(w, h, centerGraph); - return keepRunning ? this.resume() : this; - }; - Layout.prototype.initialLayout = function (iterations, x, y) { - if (this._groups.length > 0 && iterations > 0) { - var n = this._nodes.length; - var edges = this._links.map(function (e) { return ({ source: e.source.index, target: e.target.index }); }); - var vs = this._nodes.map(function (v) { return ({ index: v.index }); }); - this._groups.forEach(function (g, i) { - vs.push({ index: g.index = n + i }); - }); - this._groups.forEach(function (g, i) { - if (typeof g.leaves !== 'undefined') - g.leaves.forEach(function (v) { return edges.push({ source: g.index, target: v.index }); }); - if (typeof g.groups !== 'undefined') - g.groups.forEach(function (gg) { return edges.push({ source: g.index, target: gg.index }); }); - }); - new Layout() - .size(this.size()) - .nodes(vs) - .links(edges) - .avoidOverlaps(false) - .linkDistance(this.linkDistance()) - .symmetricDiffLinkLengths(5) - .convergenceThreshold(1e-4) - .start(iterations, 0, 0, 0, false); - this._nodes.forEach(function (v) { - x[v.index] = vs[v.index].x; - y[v.index] = vs[v.index].y; - }); - } - else { - this._descent.run(iterations); - } - }; - Layout.prototype.separateOverlappingComponents = function (width, height, centerGraph) { - var _this = this; - if (centerGraph === void 0) { centerGraph = true; } - if (!this._distanceMatrix && this._handleDisconnected) { - var x_1 = this._descent.x[0], y_1 = this._descent.x[1]; - this._nodes.forEach(function (v, i) { v.x = x_1[i], v.y = y_1[i]; }); - var graphs = handledisconnected_1.separateGraphs(this._nodes, this._links); - handledisconnected_1.applyPacking(graphs, width, height, this._defaultNodeSize, (height / width), centerGraph); - this._nodes.forEach(function (v, i) { - _this._descent.x[0][i] = v.x, _this._descent.x[1][i] = v.y; - if (v.bounds) { - v.bounds.setXCentre(v.x); - v.bounds.setYCentre(v.y); - } - }); - } - }; - Layout.prototype.resume = function () { - return this.alpha(0.1); - }; - Layout.prototype.stop = function () { - return this.alpha(0); - }; - Layout.prototype.prepareEdgeRouting = function (nodeMargin) { - if (nodeMargin === void 0) { nodeMargin = 0; } - this._visibilityGraph = new geom_1.TangentVisibilityGraph(this._nodes.map(function (v) { - return v.bounds.inflate(-nodeMargin).vertices(); - })); - }; - Layout.prototype.routeEdge = function (edge, ah, draw) { - if (ah === void 0) { ah = 5; } - var lineData = []; - var vg2 = new geom_1.TangentVisibilityGraph(this._visibilityGraph.P, { V: this._visibilityGraph.V, E: this._visibilityGraph.E }), port1 = { x: edge.source.x, y: edge.source.y }, port2 = { x: edge.target.x, y: edge.target.y }, start = vg2.addPoint(port1, edge.source.index), end = vg2.addPoint(port2, edge.target.index); - vg2.addEdgeIfVisible(port1, port2, edge.source.index, edge.target.index); - if (typeof draw !== 'undefined') { - draw(vg2); - } - var sourceInd = function (e) { return e.source.id; }, targetInd = function (e) { return e.target.id; }, length = function (e) { return e.length(); }, spCalc = new shortestpaths_1.Calculator(vg2.V.length, vg2.E, sourceInd, targetInd, length), shortestPath = spCalc.PathFromNodeToNode(start.id, end.id); - if (shortestPath.length === 1 || shortestPath.length === vg2.V.length) { - var route = rectangle_1.makeEdgeBetween(edge.source.innerBounds, edge.target.innerBounds, ah); - lineData = [route.sourceIntersection, route.arrowStart]; - } - else { - var n = shortestPath.length - 2, p = vg2.V[shortestPath[n]].p, q = vg2.V[shortestPath[0]].p, lineData = [edge.source.innerBounds.rayIntersection(p.x, p.y)]; - for (var i = n; i >= 0; --i) - lineData.push(vg2.V[shortestPath[i]].p); - lineData.push(rectangle_1.makeEdgeTo(q, edge.target.innerBounds, ah)); - } - return lineData; - }; - Layout.getSourceIndex = function (e) { - return typeof e.source === 'number' ? e.source : e.source.index; - }; - Layout.getTargetIndex = function (e) { - return typeof e.target === 'number' ? e.target : e.target.index; - }; - Layout.linkId = function (e) { - return Layout.getSourceIndex(e) + "-" + Layout.getTargetIndex(e); - }; - Layout.dragStart = function (d) { - if (isGroup(d)) { - Layout.storeOffset(d, Layout.dragOrigin(d)); - } - else { - Layout.stopNode(d); - d.fixed |= 2; - } - }; - Layout.stopNode = function (v) { - v.px = v.x; - v.py = v.y; - }; - Layout.storeOffset = function (d, origin) { - if (typeof d.leaves !== 'undefined') { - d.leaves.forEach(function (v) { - v.fixed |= 2; - Layout.stopNode(v); - v._dragGroupOffsetX = v.x - origin.x; - v._dragGroupOffsetY = v.y - origin.y; - }); - } - if (typeof d.groups !== 'undefined') { - d.groups.forEach(function (g) { return Layout.storeOffset(g, origin); }); - } - }; - Layout.dragOrigin = function (d) { - if (isGroup(d)) { - return { - x: d.bounds.cx(), - y: d.bounds.cy() - }; - } - else { - return d; - } - }; - Layout.drag = function (d, position) { - if (isGroup(d)) { - if (typeof d.leaves !== 'undefined') { - d.leaves.forEach(function (v) { - d.bounds.setXCentre(position.x); - d.bounds.setYCentre(position.y); - v.px = v._dragGroupOffsetX + position.x; - v.py = v._dragGroupOffsetY + position.y; - }); - } - if (typeof d.groups !== 'undefined') { - d.groups.forEach(function (g) { return Layout.drag(g, position); }); - } - } - else { - d.px = position.x; - d.py = position.y; - } - }; - Layout.dragEnd = function (d) { - if (isGroup(d)) { - if (typeof d.leaves !== 'undefined') { - d.leaves.forEach(function (v) { - Layout.dragEnd(v); - delete v._dragGroupOffsetX; - delete v._dragGroupOffsetY; - }); - } - if (typeof d.groups !== 'undefined') { - d.groups.forEach(Layout.dragEnd); - } - } - else { - d.fixed &= ~6; - } - }; - Layout.mouseOver = function (d) { - d.fixed |= 4; - d.px = d.x, d.py = d.y; - }; - Layout.mouseOut = function (d) { - d.fixed &= ~4; - }; - return Layout; -}()); -exports.Layout = Layout; - -},{"./descent":7,"./geom":8,"./handledisconnected":10,"./linklengths":13,"./powergraph":14,"./rectangle":17,"./shortestpaths":18}],12:[function(require,module,exports){ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -var shortestpaths_1 = require("./shortestpaths"); -var descent_1 = require("./descent"); -var rectangle_1 = require("./rectangle"); -var linklengths_1 = require("./linklengths"); -var Link3D = (function () { - function Link3D(source, target) { - this.source = source; - this.target = target; - } - Link3D.prototype.actualLength = function (x) { - var _this = this; - return Math.sqrt(x.reduce(function (c, v) { - var dx = v[_this.target] - v[_this.source]; - return c + dx * dx; - }, 0)); - }; - return Link3D; -}()); -exports.Link3D = Link3D; -var Node3D = (function () { - function Node3D(x, y, z) { - if (x === void 0) { x = 0; } - if (y === void 0) { y = 0; } - if (z === void 0) { z = 0; } - this.x = x; - this.y = y; - this.z = z; - } - return Node3D; -}()); -exports.Node3D = Node3D; -var Layout3D = (function () { - function Layout3D(nodes, links, idealLinkLength) { - var _this = this; - if (idealLinkLength === void 0) { idealLinkLength = 1; } - this.nodes = nodes; - this.links = links; - this.idealLinkLength = idealLinkLength; - this.constraints = null; - this.useJaccardLinkLengths = true; - this.result = new Array(Layout3D.k); - for (var i = 0; i < Layout3D.k; ++i) { - this.result[i] = new Array(nodes.length); - } - nodes.forEach(function (v, i) { - for (var _i = 0, _a = Layout3D.dims; _i < _a.length; _i++) { - var dim = _a[_i]; - if (typeof v[dim] == 'undefined') - v[dim] = Math.random(); - } - _this.result[0][i] = v.x; - _this.result[1][i] = v.y; - _this.result[2][i] = v.z; - }); - } - ; - Layout3D.prototype.linkLength = function (l) { - return l.actualLength(this.result); - }; - Layout3D.prototype.start = function (iterations) { - var _this = this; - if (iterations === void 0) { iterations = 100; } - var n = this.nodes.length; - var linkAccessor = new LinkAccessor(); - if (this.useJaccardLinkLengths) - linklengths_1.jaccardLinkLengths(this.links, linkAccessor, 1.5); - this.links.forEach(function (e) { return e.length *= _this.idealLinkLength; }); - var distanceMatrix = (new shortestpaths_1.Calculator(n, this.links, function (e) { return e.source; }, function (e) { return e.target; }, function (e) { return e.length; })).DistanceMatrix(); - var D = descent_1.Descent.createSquareMatrix(n, function (i, j) { return distanceMatrix[i][j]; }); - var G = descent_1.Descent.createSquareMatrix(n, function () { return 2; }); - this.links.forEach(function (_a) { - var source = _a.source, target = _a.target; - return G[source][target] = G[target][source] = 1; - }); - this.descent = new descent_1.Descent(this.result, D); - this.descent.threshold = 1e-3; - this.descent.G = G; - if (this.constraints) - this.descent.project = new rectangle_1.Projection(this.nodes, null, null, this.constraints).projectFunctions(); - for (var i = 0; i < this.nodes.length; i++) { - var v = this.nodes[i]; - if (v.fixed) { - this.descent.locks.add(i, [v.x, v.y, v.z]); - } - } - this.descent.run(iterations); - return this; - }; - Layout3D.prototype.tick = function () { - this.descent.locks.clear(); - for (var i = 0; i < this.nodes.length; i++) { - var v = this.nodes[i]; - if (v.fixed) { - this.descent.locks.add(i, [v.x, v.y, v.z]); - } - } - return this.descent.rungeKutta(); - }; - Layout3D.dims = ['x', 'y', 'z']; - Layout3D.k = Layout3D.dims.length; - return Layout3D; -}()); -exports.Layout3D = Layout3D; -var LinkAccessor = (function () { - function LinkAccessor() { - } - LinkAccessor.prototype.getSourceIndex = function (e) { return e.source; }; - LinkAccessor.prototype.getTargetIndex = function (e) { return e.target; }; - LinkAccessor.prototype.getLength = function (e) { return e.length; }; - LinkAccessor.prototype.setLength = function (e, l) { e.length = l; }; - return LinkAccessor; -}()); - -},{"./descent":7,"./linklengths":13,"./rectangle":17,"./shortestpaths":18}],13:[function(require,module,exports){ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -function unionCount(a, b) { - var u = {}; - for (var i in a) - u[i] = {}; - for (var i in b) - u[i] = {}; - return Object.keys(u).length; -} -function intersectionCount(a, b) { - var n = 0; - for (var i in a) - if (typeof b[i] !== 'undefined') - ++n; - return n; -} -function getNeighbours(links, la) { - var neighbours = {}; - var addNeighbours = function (u, v) { - if (typeof neighbours[u] === 'undefined') - neighbours[u] = {}; - neighbours[u][v] = {}; - }; - links.forEach(function (e) { - var u = la.getSourceIndex(e), v = la.getTargetIndex(e); - addNeighbours(u, v); - addNeighbours(v, u); - }); - return neighbours; -} -function computeLinkLengths(links, w, f, la) { - var neighbours = getNeighbours(links, la); - links.forEach(function (l) { - var a = neighbours[la.getSourceIndex(l)]; - var b = neighbours[la.getTargetIndex(l)]; - la.setLength(l, 1 + w * f(a, b)); - }); -} -function symmetricDiffLinkLengths(links, la, w) { - if (w === void 0) { w = 1; } - computeLinkLengths(links, w, function (a, b) { return Math.sqrt(unionCount(a, b) - intersectionCount(a, b)); }, la); -} -exports.symmetricDiffLinkLengths = symmetricDiffLinkLengths; -function jaccardLinkLengths(links, la, w) { - if (w === void 0) { w = 1; } - computeLinkLengths(links, w, function (a, b) { - return Math.min(Object.keys(a).length, Object.keys(b).length) < 1.1 ? 0 : intersectionCount(a, b) / unionCount(a, b); - }, la); -} -exports.jaccardLinkLengths = jaccardLinkLengths; -function generateDirectedEdgeConstraints(n, links, axis, la) { - var components = stronglyConnectedComponents(n, links, la); - var nodes = {}; - components.forEach(function (c, i) { - return c.forEach(function (v) { return nodes[v] = i; }); - }); - var constraints = []; - links.forEach(function (l) { - var ui = la.getSourceIndex(l), vi = la.getTargetIndex(l), u = nodes[ui], v = nodes[vi]; - if (u !== v) { - constraints.push({ - axis: axis, - left: ui, - right: vi, - gap: la.getMinSeparation(l) - }); - } - }); - return constraints; -} -exports.generateDirectedEdgeConstraints = generateDirectedEdgeConstraints; -function stronglyConnectedComponents(numVertices, edges, la) { - var nodes = []; - var index = 0; - var stack = []; - var components = []; - function strongConnect(v) { - v.index = v.lowlink = index++; - stack.push(v); - v.onStack = true; - for (var _i = 0, _a = v.out; _i < _a.length; _i++) { - var w = _a[_i]; - if (typeof w.index === 'undefined') { - strongConnect(w); - v.lowlink = Math.min(v.lowlink, w.lowlink); - } - else if (w.onStack) { - v.lowlink = Math.min(v.lowlink, w.index); - } - } - if (v.lowlink === v.index) { - var component = []; - while (stack.length) { - w = stack.pop(); - w.onStack = false; - component.push(w); - if (w === v) - break; - } - components.push(component.map(function (v) { return v.id; })); - } - } - for (var i = 0; i < numVertices; i++) { - nodes.push({ id: i, out: [] }); - } - for (var _i = 0, edges_1 = edges; _i < edges_1.length; _i++) { - var e = edges_1[_i]; - var v_1 = nodes[la.getSourceIndex(e)], w = nodes[la.getTargetIndex(e)]; - v_1.out.push(w); - } - for (var _a = 0, nodes_1 = nodes; _a < nodes_1.length; _a++) { - var v = nodes_1[_a]; - if (typeof v.index === 'undefined') - strongConnect(v); - } - return components; -} -exports.stronglyConnectedComponents = stronglyConnectedComponents; - -},{}],14:[function(require,module,exports){ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -var PowerEdge = (function () { - function PowerEdge(source, target, type) { - this.source = source; - this.target = target; - this.type = type; - } - return PowerEdge; -}()); -exports.PowerEdge = PowerEdge; -var Configuration = (function () { - function Configuration(n, edges, linkAccessor, rootGroup) { - var _this = this; - this.linkAccessor = linkAccessor; - this.modules = new Array(n); - this.roots = []; - if (rootGroup) { - this.initModulesFromGroup(rootGroup); - } - else { - this.roots.push(new ModuleSet()); - for (var i = 0; i < n; ++i) - this.roots[0].add(this.modules[i] = new Module(i)); - } - this.R = edges.length; - edges.forEach(function (e) { - var s = _this.modules[linkAccessor.getSourceIndex(e)], t = _this.modules[linkAccessor.getTargetIndex(e)], type = linkAccessor.getType(e); - s.outgoing.add(type, t); - t.incoming.add(type, s); - }); - } - Configuration.prototype.initModulesFromGroup = function (group) { - var moduleSet = new ModuleSet(); - this.roots.push(moduleSet); - for (var i = 0; i < group.leaves.length; ++i) { - var node = group.leaves[i]; - var module = new Module(node.id); - this.modules[node.id] = module; - moduleSet.add(module); - } - if (group.groups) { - for (var j = 0; j < group.groups.length; ++j) { - var child = group.groups[j]; - var definition = {}; - for (var prop in child) - if (prop !== "leaves" && prop !== "groups" && child.hasOwnProperty(prop)) - definition[prop] = child[prop]; - moduleSet.add(new Module(-1 - j, new LinkSets(), new LinkSets(), this.initModulesFromGroup(child), definition)); - } - } - return moduleSet; - }; - Configuration.prototype.merge = function (a, b, k) { - if (k === void 0) { k = 0; } - var inInt = a.incoming.intersection(b.incoming), outInt = a.outgoing.intersection(b.outgoing); - var children = new ModuleSet(); - children.add(a); - children.add(b); - var m = new Module(this.modules.length, outInt, inInt, children); - this.modules.push(m); - var update = function (s, i, o) { - s.forAll(function (ms, linktype) { - ms.forAll(function (n) { - var nls = n[i]; - nls.add(linktype, m); - nls.remove(linktype, a); - nls.remove(linktype, b); - a[o].remove(linktype, n); - b[o].remove(linktype, n); - }); - }); - }; - update(outInt, "incoming", "outgoing"); - update(inInt, "outgoing", "incoming"); - this.R -= inInt.count() + outInt.count(); - this.roots[k].remove(a); - this.roots[k].remove(b); - this.roots[k].add(m); - return m; - }; - Configuration.prototype.rootMerges = function (k) { - if (k === void 0) { k = 0; } - var rs = this.roots[k].modules(); - var n = rs.length; - var merges = new Array(n * (n - 1)); - var ctr = 0; - for (var i = 0, i_ = n - 1; i < i_; ++i) { - for (var j = i + 1; j < n; ++j) { - var a = rs[i], b = rs[j]; - merges[ctr] = { id: ctr, nEdges: this.nEdges(a, b), a: a, b: b }; - ctr++; - } - } - return merges; - }; - Configuration.prototype.greedyMerge = function () { - for (var i = 0; i < this.roots.length; ++i) { - if (this.roots[i].modules().length < 2) - continue; - var ms = this.rootMerges(i).sort(function (a, b) { return a.nEdges == b.nEdges ? a.id - b.id : a.nEdges - b.nEdges; }); - var m = ms[0]; - if (m.nEdges >= this.R) - continue; - this.merge(m.a, m.b, i); - return true; - } - }; - Configuration.prototype.nEdges = function (a, b) { - var inInt = a.incoming.intersection(b.incoming), outInt = a.outgoing.intersection(b.outgoing); - return this.R - inInt.count() - outInt.count(); - }; - Configuration.prototype.getGroupHierarchy = function (retargetedEdges) { - var _this = this; - var groups = []; - var root = {}; - toGroups(this.roots[0], root, groups); - var es = this.allEdges(); - es.forEach(function (e) { - var a = _this.modules[e.source]; - var b = _this.modules[e.target]; - retargetedEdges.push(new PowerEdge(typeof a.gid === "undefined" ? e.source : groups[a.gid], typeof b.gid === "undefined" ? e.target : groups[b.gid], e.type)); - }); - return groups; - }; - Configuration.prototype.allEdges = function () { - var es = []; - Configuration.getEdges(this.roots[0], es); - return es; - }; - Configuration.getEdges = function (modules, es) { - modules.forAll(function (m) { - m.getEdges(es); - Configuration.getEdges(m.children, es); - }); - }; - return Configuration; -}()); -exports.Configuration = Configuration; -function toGroups(modules, group, groups) { - modules.forAll(function (m) { - if (m.isLeaf()) { - if (!group.leaves) - group.leaves = []; - group.leaves.push(m.id); - } - else { - var g = group; - m.gid = groups.length; - if (!m.isIsland() || m.isPredefined()) { - g = { id: m.gid }; - if (m.isPredefined()) - for (var prop in m.definition) - g[prop] = m.definition[prop]; - if (!group.groups) - group.groups = []; - group.groups.push(m.gid); - groups.push(g); - } - toGroups(m.children, g, groups); - } - }); -} -var Module = (function () { - function Module(id, outgoing, incoming, children, definition) { - if (outgoing === void 0) { outgoing = new LinkSets(); } - if (incoming === void 0) { incoming = new LinkSets(); } - if (children === void 0) { children = new ModuleSet(); } - this.id = id; - this.outgoing = outgoing; - this.incoming = incoming; - this.children = children; - this.definition = definition; - } - Module.prototype.getEdges = function (es) { - var _this = this; - this.outgoing.forAll(function (ms, edgetype) { - ms.forAll(function (target) { - es.push(new PowerEdge(_this.id, target.id, edgetype)); - }); - }); - }; - Module.prototype.isLeaf = function () { - return this.children.count() === 0; - }; - Module.prototype.isIsland = function () { - return this.outgoing.count() === 0 && this.incoming.count() === 0; - }; - Module.prototype.isPredefined = function () { - return typeof this.definition !== "undefined"; - }; - return Module; -}()); -exports.Module = Module; -function intersection(m, n) { - var i = {}; - for (var v in m) - if (v in n) - i[v] = m[v]; - return i; -} -var ModuleSet = (function () { - function ModuleSet() { - this.table = {}; - } - ModuleSet.prototype.count = function () { - return Object.keys(this.table).length; - }; - ModuleSet.prototype.intersection = function (other) { - var result = new ModuleSet(); - result.table = intersection(this.table, other.table); - return result; - }; - ModuleSet.prototype.intersectionCount = function (other) { - return this.intersection(other).count(); - }; - ModuleSet.prototype.contains = function (id) { - return id in this.table; - }; - ModuleSet.prototype.add = function (m) { - this.table[m.id] = m; - }; - ModuleSet.prototype.remove = function (m) { - delete this.table[m.id]; - }; - ModuleSet.prototype.forAll = function (f) { - for (var mid in this.table) { - f(this.table[mid]); - } - }; - ModuleSet.prototype.modules = function () { - var vs = []; - this.forAll(function (m) { - if (!m.isPredefined()) - vs.push(m); - }); - return vs; - }; - return ModuleSet; -}()); -exports.ModuleSet = ModuleSet; -var LinkSets = (function () { - function LinkSets() { - this.sets = {}; - this.n = 0; - } - LinkSets.prototype.count = function () { - return this.n; - }; - LinkSets.prototype.contains = function (id) { - var result = false; - this.forAllModules(function (m) { - if (!result && m.id == id) { - result = true; - } - }); - return result; - }; - LinkSets.prototype.add = function (linktype, m) { - var s = linktype in this.sets ? this.sets[linktype] : this.sets[linktype] = new ModuleSet(); - s.add(m); - ++this.n; - }; - LinkSets.prototype.remove = function (linktype, m) { - var ms = this.sets[linktype]; - ms.remove(m); - if (ms.count() === 0) { - delete this.sets[linktype]; - } - --this.n; - }; - LinkSets.prototype.forAll = function (f) { - for (var linktype in this.sets) { - f(this.sets[linktype], Number(linktype)); - } - }; - LinkSets.prototype.forAllModules = function (f) { - this.forAll(function (ms, lt) { return ms.forAll(f); }); - }; - LinkSets.prototype.intersection = function (other) { - var result = new LinkSets(); - this.forAll(function (ms, lt) { - if (lt in other.sets) { - var i = ms.intersection(other.sets[lt]), n = i.count(); - if (n > 0) { - result.sets[lt] = i; - result.n += n; - } - } - }); - return result; - }; - return LinkSets; -}()); -exports.LinkSets = LinkSets; -function intersectionCount(m, n) { - return Object.keys(intersection(m, n)).length; -} -function getGroups(nodes, links, la, rootGroup) { - var n = nodes.length, c = new Configuration(n, links, la, rootGroup); - while (c.greedyMerge()) - ; - var powerEdges = []; - var g = c.getGroupHierarchy(powerEdges); - powerEdges.forEach(function (e) { - var f = function (end) { - var g = e[end]; - if (typeof g == "number") - e[end] = nodes[g]; - }; - f("source"); - f("target"); - }); - return { groups: g, powerEdges: powerEdges }; -} -exports.getGroups = getGroups; - -},{}],15:[function(require,module,exports){ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -var PairingHeap = (function () { - function PairingHeap(elem) { - this.elem = elem; - this.subheaps = []; - } - PairingHeap.prototype.toString = function (selector) { - var str = "", needComma = false; - for (var i = 0; i < this.subheaps.length; ++i) { - var subheap = this.subheaps[i]; - if (!subheap.elem) { - needComma = false; - continue; - } - if (needComma) { - str = str + ","; - } - str = str + subheap.toString(selector); - needComma = true; - } - if (str !== "") { - str = "(" + str + ")"; - } - return (this.elem ? selector(this.elem) : "") + str; - }; - PairingHeap.prototype.forEach = function (f) { - if (!this.empty()) { - f(this.elem, this); - this.subheaps.forEach(function (s) { return s.forEach(f); }); - } - }; - PairingHeap.prototype.count = function () { - return this.empty() ? 0 : 1 + this.subheaps.reduce(function (n, h) { - return n + h.count(); - }, 0); - }; - PairingHeap.prototype.min = function () { - return this.elem; - }; - PairingHeap.prototype.empty = function () { - return this.elem == null; - }; - PairingHeap.prototype.contains = function (h) { - if (this === h) - return true; - for (var i = 0; i < this.subheaps.length; i++) { - if (this.subheaps[i].contains(h)) - return true; - } - return false; - }; - PairingHeap.prototype.isHeap = function (lessThan) { - var _this = this; - return this.subheaps.every(function (h) { return lessThan(_this.elem, h.elem) && h.isHeap(lessThan); }); - }; - PairingHeap.prototype.insert = function (obj, lessThan) { - return this.merge(new PairingHeap(obj), lessThan); - }; - PairingHeap.prototype.merge = function (heap2, lessThan) { - if (this.empty()) - return heap2; - else if (heap2.empty()) - return this; - else if (lessThan(this.elem, heap2.elem)) { - this.subheaps.push(heap2); - return this; - } - else { - heap2.subheaps.push(this); - return heap2; - } - }; - PairingHeap.prototype.removeMin = function (lessThan) { - if (this.empty()) - return null; - else - return this.mergePairs(lessThan); - }; - PairingHeap.prototype.mergePairs = function (lessThan) { - if (this.subheaps.length == 0) - return new PairingHeap(null); - else if (this.subheaps.length == 1) { - return this.subheaps[0]; - } - else { - var firstPair = this.subheaps.pop().merge(this.subheaps.pop(), lessThan); - var remaining = this.mergePairs(lessThan); - return firstPair.merge(remaining, lessThan); - } - }; - PairingHeap.prototype.decreaseKey = function (subheap, newValue, setHeapNode, lessThan) { - var newHeap = subheap.removeMin(lessThan); - subheap.elem = newHeap.elem; - subheap.subheaps = newHeap.subheaps; - if (setHeapNode !== null && newHeap.elem !== null) { - setHeapNode(subheap.elem, subheap); - } - var pairingNode = new PairingHeap(newValue); - if (setHeapNode !== null) { - setHeapNode(newValue, pairingNode); - } - return this.merge(pairingNode, lessThan); - }; - return PairingHeap; -}()); -exports.PairingHeap = PairingHeap; -var PriorityQueue = (function () { - function PriorityQueue(lessThan) { - this.lessThan = lessThan; - } - PriorityQueue.prototype.top = function () { - if (this.empty()) { - return null; - } - return this.root.elem; - }; - PriorityQueue.prototype.push = function () { - var args = []; - for (var _i = 0; _i < arguments.length; _i++) { - args[_i] = arguments[_i]; - } - var pairingNode; - for (var i = 0, arg; arg = args[i]; ++i) { - pairingNode = new PairingHeap(arg); - this.root = this.empty() ? - pairingNode : this.root.merge(pairingNode, this.lessThan); - } - return pairingNode; - }; - PriorityQueue.prototype.empty = function () { - return !this.root || !this.root.elem; - }; - PriorityQueue.prototype.isHeap = function () { - return this.root.isHeap(this.lessThan); - }; - PriorityQueue.prototype.forEach = function (f) { - this.root.forEach(f); - }; - PriorityQueue.prototype.pop = function () { - if (this.empty()) { - return null; - } - var obj = this.root.min(); - this.root = this.root.removeMin(this.lessThan); - return obj; - }; - PriorityQueue.prototype.reduceKey = function (heapNode, newKey, setHeapNode) { - if (setHeapNode === void 0) { setHeapNode = null; } - this.root = this.root.decreaseKey(heapNode, newKey, setHeapNode, this.lessThan); - }; - PriorityQueue.prototype.toString = function (selector) { - return this.root.toString(selector); - }; - PriorityQueue.prototype.count = function () { - return this.root.count(); - }; - return PriorityQueue; -}()); -exports.PriorityQueue = PriorityQueue; - -},{}],16:[function(require,module,exports){ -"use strict"; -var __extends = (this && this.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); -Object.defineProperty(exports, "__esModule", { value: true }); -var TreeBase = (function () { - function TreeBase() { - this.findIter = function (data) { - var res = this._root; - var iter = this.iterator(); - while (res !== null) { - var c = this._comparator(data, res.data); - if (c === 0) { - iter._cursor = res; - return iter; - } - else { - iter._ancestors.push(res); - res = res.get_child(c > 0); - } - } - return null; - }; - } - TreeBase.prototype.clear = function () { - this._root = null; - this.size = 0; - }; - ; - TreeBase.prototype.find = function (data) { - var res = this._root; - while (res !== null) { - var c = this._comparator(data, res.data); - if (c === 0) { - return res.data; - } - else { - res = res.get_child(c > 0); - } - } - return null; - }; - ; - TreeBase.prototype.lowerBound = function (data) { - return this._bound(data, this._comparator); - }; - ; - TreeBase.prototype.upperBound = function (data) { - var cmp = this._comparator; - function reverse_cmp(a, b) { - return cmp(b, a); - } - return this._bound(data, reverse_cmp); - }; - ; - TreeBase.prototype.min = function () { - var res = this._root; - if (res === null) { - return null; - } - while (res.left !== null) { - res = res.left; - } - return res.data; - }; - ; - TreeBase.prototype.max = function () { - var res = this._root; - if (res === null) { - return null; - } - while (res.right !== null) { - res = res.right; - } - return res.data; - }; - ; - TreeBase.prototype.iterator = function () { - return new Iterator(this); - }; - ; - TreeBase.prototype.each = function (cb) { - var it = this.iterator(), data; - while ((data = it.next()) !== null) { - cb(data); - } - }; - ; - TreeBase.prototype.reach = function (cb) { - var it = this.iterator(), data; - while ((data = it.prev()) !== null) { - cb(data); - } - }; - ; - TreeBase.prototype._bound = function (data, cmp) { - var cur = this._root; - var iter = this.iterator(); - while (cur !== null) { - var c = this._comparator(data, cur.data); - if (c === 0) { - iter._cursor = cur; - return iter; - } - iter._ancestors.push(cur); - cur = cur.get_child(c > 0); - } - for (var i = iter._ancestors.length - 1; i >= 0; --i) { - cur = iter._ancestors[i]; - if (cmp(data, cur.data) > 0) { - iter._cursor = cur; - iter._ancestors.length = i; - return iter; - } - } - iter._ancestors.length = 0; - return iter; - }; - ; - return TreeBase; -}()); -exports.TreeBase = TreeBase; -var Iterator = (function () { - function Iterator(tree) { - this._tree = tree; - this._ancestors = []; - this._cursor = null; - } - Iterator.prototype.data = function () { - return this._cursor !== null ? this._cursor.data : null; - }; - ; - Iterator.prototype.next = function () { - if (this._cursor === null) { - var root = this._tree._root; - if (root !== null) { - this._minNode(root); - } - } - else { - if (this._cursor.right === null) { - var save; - do { - save = this._cursor; - if (this._ancestors.length) { - this._cursor = this._ancestors.pop(); - } - else { - this._cursor = null; - break; - } - } while (this._cursor.right === save); - } - else { - this._ancestors.push(this._cursor); - this._minNode(this._cursor.right); - } - } - return this._cursor !== null ? this._cursor.data : null; - }; - ; - Iterator.prototype.prev = function () { - if (this._cursor === null) { - var root = this._tree._root; - if (root !== null) { - this._maxNode(root); - } - } - else { - if (this._cursor.left === null) { - var save; - do { - save = this._cursor; - if (this._ancestors.length) { - this._cursor = this._ancestors.pop(); - } - else { - this._cursor = null; - break; - } - } while (this._cursor.left === save); - } - else { - this._ancestors.push(this._cursor); - this._maxNode(this._cursor.left); - } - } - return this._cursor !== null ? this._cursor.data : null; - }; - ; - Iterator.prototype._minNode = function (start) { - while (start.left !== null) { - this._ancestors.push(start); - start = start.left; - } - this._cursor = start; - }; - ; - Iterator.prototype._maxNode = function (start) { - while (start.right !== null) { - this._ancestors.push(start); - start = start.right; - } - this._cursor = start; - }; - ; - return Iterator; -}()); -exports.Iterator = Iterator; -var Node = (function () { - function Node(data) { - this.data = data; - this.left = null; - this.right = null; - this.red = true; - } - Node.prototype.get_child = function (dir) { - return dir ? this.right : this.left; - }; - ; - Node.prototype.set_child = function (dir, val) { - if (dir) { - this.right = val; - } - else { - this.left = val; - } - }; - ; - return Node; -}()); -var RBTree = (function (_super) { - __extends(RBTree, _super); - function RBTree(comparator) { - var _this = _super.call(this) || this; - _this._root = null; - _this._comparator = comparator; - _this.size = 0; - return _this; - } - RBTree.prototype.insert = function (data) { - var ret = false; - if (this._root === null) { - this._root = new Node(data); - ret = true; - this.size++; - } - else { - var head = new Node(undefined); - var dir = false; - var last = false; - var gp = null; - var ggp = head; - var p = null; - var node = this._root; - ggp.right = this._root; - while (true) { - if (node === null) { - node = new Node(data); - p.set_child(dir, node); - ret = true; - this.size++; - } - else if (RBTree.is_red(node.left) && RBTree.is_red(node.right)) { - node.red = true; - node.left.red = false; - node.right.red = false; - } - if (RBTree.is_red(node) && RBTree.is_red(p)) { - var dir2 = ggp.right === gp; - if (node === p.get_child(last)) { - ggp.set_child(dir2, RBTree.single_rotate(gp, !last)); - } - else { - ggp.set_child(dir2, RBTree.double_rotate(gp, !last)); - } - } - var cmp = this._comparator(node.data, data); - if (cmp === 0) { - break; - } - last = dir; - dir = cmp < 0; - if (gp !== null) { - ggp = gp; - } - gp = p; - p = node; - node = node.get_child(dir); - } - this._root = head.right; - } - this._root.red = false; - return ret; - }; - ; - RBTree.prototype.remove = function (data) { - if (this._root === null) { - return false; - } - var head = new Node(undefined); - var node = head; - node.right = this._root; - var p = null; - var gp = null; - var found = null; - var dir = true; - while (node.get_child(dir) !== null) { - var last = dir; - gp = p; - p = node; - node = node.get_child(dir); - var cmp = this._comparator(data, node.data); - dir = cmp > 0; - if (cmp === 0) { - found = node; - } - if (!RBTree.is_red(node) && !RBTree.is_red(node.get_child(dir))) { - if (RBTree.is_red(node.get_child(!dir))) { - var sr = RBTree.single_rotate(node, dir); - p.set_child(last, sr); - p = sr; - } - else if (!RBTree.is_red(node.get_child(!dir))) { - var sibling = p.get_child(!last); - if (sibling !== null) { - if (!RBTree.is_red(sibling.get_child(!last)) && !RBTree.is_red(sibling.get_child(last))) { - p.red = false; - sibling.red = true; - node.red = true; - } - else { - var dir2 = gp.right === p; - if (RBTree.is_red(sibling.get_child(last))) { - gp.set_child(dir2, RBTree.double_rotate(p, last)); - } - else if (RBTree.is_red(sibling.get_child(!last))) { - gp.set_child(dir2, RBTree.single_rotate(p, last)); - } - var gpc = gp.get_child(dir2); - gpc.red = true; - node.red = true; - gpc.left.red = false; - gpc.right.red = false; - } - } - } - } - } - if (found !== null) { - found.data = node.data; - p.set_child(p.right === node, node.get_child(node.left === null)); - this.size--; - } - this._root = head.right; - if (this._root !== null) { - this._root.red = false; - } - return found !== null; - }; - ; - RBTree.is_red = function (node) { - return node !== null && node.red; - }; - RBTree.single_rotate = function (root, dir) { - var save = root.get_child(!dir); - root.set_child(!dir, save.get_child(dir)); - save.set_child(dir, root); - root.red = true; - save.red = false; - return save; - }; - RBTree.double_rotate = function (root, dir) { - root.set_child(!dir, RBTree.single_rotate(root.get_child(!dir), !dir)); - return RBTree.single_rotate(root, dir); - }; - return RBTree; -}(TreeBase)); -exports.RBTree = RBTree; - -},{}],17:[function(require,module,exports){ -"use strict"; -var __extends = (this && this.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); -Object.defineProperty(exports, "__esModule", { value: true }); -var vpsc_1 = require("./vpsc"); -var rbtree_1 = require("./rbtree"); -function computeGroupBounds(g) { - g.bounds = typeof g.leaves !== "undefined" ? - g.leaves.reduce(function (r, c) { return c.bounds.union(r); }, Rectangle.empty()) : - Rectangle.empty(); - if (typeof g.groups !== "undefined") - g.bounds = g.groups.reduce(function (r, c) { return computeGroupBounds(c).union(r); }, g.bounds); - g.bounds = g.bounds.inflate(g.padding); - return g.bounds; -} -exports.computeGroupBounds = computeGroupBounds; -var Rectangle = (function () { - function Rectangle(x, X, y, Y) { - this.x = x; - this.X = X; - this.y = y; - this.Y = Y; - } - Rectangle.empty = function () { return new Rectangle(Number.POSITIVE_INFINITY, Number.NEGATIVE_INFINITY, Number.POSITIVE_INFINITY, Number.NEGATIVE_INFINITY); }; - Rectangle.prototype.cx = function () { return (this.x + this.X) / 2; }; - Rectangle.prototype.cy = function () { return (this.y + this.Y) / 2; }; - Rectangle.prototype.overlapX = function (r) { - var ux = this.cx(), vx = r.cx(); - if (ux <= vx && r.x < this.X) - return this.X - r.x; - if (vx <= ux && this.x < r.X) - return r.X - this.x; - return 0; - }; - Rectangle.prototype.overlapY = function (r) { - var uy = this.cy(), vy = r.cy(); - if (uy <= vy && r.y < this.Y) - return this.Y - r.y; - if (vy <= uy && this.y < r.Y) - return r.Y - this.y; - return 0; - }; - Rectangle.prototype.setXCentre = function (cx) { - var dx = cx - this.cx(); - this.x += dx; - this.X += dx; - }; - Rectangle.prototype.setYCentre = function (cy) { - var dy = cy - this.cy(); - this.y += dy; - this.Y += dy; - }; - Rectangle.prototype.width = function () { - return this.X - this.x; - }; - Rectangle.prototype.height = function () { - return this.Y - this.y; - }; - Rectangle.prototype.union = function (r) { - return new Rectangle(Math.min(this.x, r.x), Math.max(this.X, r.X), Math.min(this.y, r.y), Math.max(this.Y, r.Y)); - }; - Rectangle.prototype.lineIntersections = function (x1, y1, x2, y2) { - var sides = [[this.x, this.y, this.X, this.y], - [this.X, this.y, this.X, this.Y], - [this.X, this.Y, this.x, this.Y], - [this.x, this.Y, this.x, this.y]]; - var intersections = []; - for (var i = 0; i < 4; ++i) { - var r = Rectangle.lineIntersection(x1, y1, x2, y2, sides[i][0], sides[i][1], sides[i][2], sides[i][3]); - if (r !== null) - intersections.push({ x: r.x, y: r.y }); - } - return intersections; - }; - Rectangle.prototype.rayIntersection = function (x2, y2) { - var ints = this.lineIntersections(this.cx(), this.cy(), x2, y2); - return ints.length > 0 ? ints[0] : null; - }; - Rectangle.prototype.vertices = function () { - return [ - { x: this.x, y: this.y }, - { x: this.X, y: this.y }, - { x: this.X, y: this.Y }, - { x: this.x, y: this.Y } - ]; - }; - Rectangle.lineIntersection = function (x1, y1, x2, y2, x3, y3, x4, y4) { - var dx12 = x2 - x1, dx34 = x4 - x3, dy12 = y2 - y1, dy34 = y4 - y3, denominator = dy34 * dx12 - dx34 * dy12; - if (denominator == 0) - return null; - var dx31 = x1 - x3, dy31 = y1 - y3, numa = dx34 * dy31 - dy34 * dx31, a = numa / denominator, numb = dx12 * dy31 - dy12 * dx31, b = numb / denominator; - if (a >= 0 && a <= 1 && b >= 0 && b <= 1) { - return { - x: x1 + a * dx12, - y: y1 + a * dy12 - }; - } - return null; - }; - Rectangle.prototype.inflate = function (pad) { - return new Rectangle(this.x - pad, this.X + pad, this.y - pad, this.Y + pad); - }; - return Rectangle; -}()); -exports.Rectangle = Rectangle; -function makeEdgeBetween(source, target, ah) { - var si = source.rayIntersection(target.cx(), target.cy()) || { x: source.cx(), y: source.cy() }, ti = target.rayIntersection(source.cx(), source.cy()) || { x: target.cx(), y: target.cy() }, dx = ti.x - si.x, dy = ti.y - si.y, l = Math.sqrt(dx * dx + dy * dy), al = l - ah; - return { - sourceIntersection: si, - targetIntersection: ti, - arrowStart: { x: si.x + al * dx / l, y: si.y + al * dy / l } - }; -} -exports.makeEdgeBetween = makeEdgeBetween; -function makeEdgeTo(s, target, ah) { - var ti = target.rayIntersection(s.x, s.y); - if (!ti) - ti = { x: target.cx(), y: target.cy() }; - var dx = ti.x - s.x, dy = ti.y - s.y, l = Math.sqrt(dx * dx + dy * dy); - return { x: ti.x - ah * dx / l, y: ti.y - ah * dy / l }; -} -exports.makeEdgeTo = makeEdgeTo; -var Node = (function () { - function Node(v, r, pos) { - this.v = v; - this.r = r; - this.pos = pos; - this.prev = makeRBTree(); - this.next = makeRBTree(); - } - return Node; -}()); -var Event = (function () { - function Event(isOpen, v, pos) { - this.isOpen = isOpen; - this.v = v; - this.pos = pos; - } - return Event; -}()); -function compareEvents(a, b) { - if (a.pos > b.pos) { - return 1; - } - if (a.pos < b.pos) { - return -1; - } - if (a.isOpen) { - return -1; - } - if (b.isOpen) { - return 1; - } - return 0; -} -function makeRBTree() { - return new rbtree_1.RBTree(function (a, b) { return a.pos - b.pos; }); -} -var xRect = { - getCentre: function (r) { return r.cx(); }, - getOpen: function (r) { return r.y; }, - getClose: function (r) { return r.Y; }, - getSize: function (r) { return r.width(); }, - makeRect: function (open, close, center, size) { return new Rectangle(center - size / 2, center + size / 2, open, close); }, - findNeighbours: findXNeighbours -}; -var yRect = { - getCentre: function (r) { return r.cy(); }, - getOpen: function (r) { return r.x; }, - getClose: function (r) { return r.X; }, - getSize: function (r) { return r.height(); }, - makeRect: function (open, close, center, size) { return new Rectangle(open, close, center - size / 2, center + size / 2); }, - findNeighbours: findYNeighbours -}; -function generateGroupConstraints(root, f, minSep, isContained) { - if (isContained === void 0) { isContained = false; } - var padding = root.padding, gn = typeof root.groups !== 'undefined' ? root.groups.length : 0, ln = typeof root.leaves !== 'undefined' ? root.leaves.length : 0, childConstraints = !gn ? [] - : root.groups.reduce(function (ccs, g) { return ccs.concat(generateGroupConstraints(g, f, minSep, true)); }, []), n = (isContained ? 2 : 0) + ln + gn, vs = new Array(n), rs = new Array(n), i = 0, add = function (r, v) { rs[i] = r; vs[i++] = v; }; - if (isContained) { - var b = root.bounds, c = f.getCentre(b), s = f.getSize(b) / 2, open = f.getOpen(b), close = f.getClose(b), min = c - s + padding / 2, max = c + s - padding / 2; - root.minVar.desiredPosition = min; - add(f.makeRect(open, close, min, padding), root.minVar); - root.maxVar.desiredPosition = max; - add(f.makeRect(open, close, max, padding), root.maxVar); - } - if (ln) - root.leaves.forEach(function (l) { return add(l.bounds, l.variable); }); - if (gn) - root.groups.forEach(function (g) { - var b = g.bounds; - add(f.makeRect(f.getOpen(b), f.getClose(b), f.getCentre(b), f.getSize(b)), g.minVar); - }); - var cs = generateConstraints(rs, vs, f, minSep); - if (gn) { - vs.forEach(function (v) { v.cOut = [], v.cIn = []; }); - cs.forEach(function (c) { c.left.cOut.push(c), c.right.cIn.push(c); }); - root.groups.forEach(function (g) { - var gapAdjustment = (g.padding - f.getSize(g.bounds)) / 2; - g.minVar.cIn.forEach(function (c) { return c.gap += gapAdjustment; }); - g.minVar.cOut.forEach(function (c) { c.left = g.maxVar; c.gap += gapAdjustment; }); - }); - } - return childConstraints.concat(cs); -} -function generateConstraints(rs, vars, rect, minSep) { - var i, n = rs.length; - var N = 2 * n; - console.assert(vars.length >= n); - var events = new Array(N); - for (i = 0; i < n; ++i) { - var r = rs[i]; - var v = new Node(vars[i], r, rect.getCentre(r)); - events[i] = new Event(true, v, rect.getOpen(r)); - events[i + n] = new Event(false, v, rect.getClose(r)); - } - events.sort(compareEvents); - var cs = new Array(); - var scanline = makeRBTree(); - for (i = 0; i < N; ++i) { - var e = events[i]; - var v = e.v; - if (e.isOpen) { - scanline.insert(v); - rect.findNeighbours(v, scanline); - } - else { - scanline.remove(v); - var makeConstraint = function (l, r) { - var sep = (rect.getSize(l.r) + rect.getSize(r.r)) / 2 + minSep; - cs.push(new vpsc_1.Constraint(l.v, r.v, sep)); - }; - var visitNeighbours = function (forward, reverse, mkcon) { - var u, it = v[forward].iterator(); - while ((u = it[forward]()) !== null) { - mkcon(u, v); - u[reverse].remove(v); - } - }; - visitNeighbours("prev", "next", function (u, v) { return makeConstraint(u, v); }); - visitNeighbours("next", "prev", function (u, v) { return makeConstraint(v, u); }); - } - } - console.assert(scanline.size === 0); - return cs; -} -function findXNeighbours(v, scanline) { - var f = function (forward, reverse) { - var it = scanline.findIter(v); - var u; - while ((u = it[forward]()) !== null) { - var uovervX = u.r.overlapX(v.r); - if (uovervX <= 0 || uovervX <= u.r.overlapY(v.r)) { - v[forward].insert(u); - u[reverse].insert(v); - } - if (uovervX <= 0) { - break; - } - } - }; - f("next", "prev"); - f("prev", "next"); -} -function findYNeighbours(v, scanline) { - var f = function (forward, reverse) { - var u = scanline.findIter(v)[forward](); - if (u !== null && u.r.overlapX(v.r) > 0) { - v[forward].insert(u); - u[reverse].insert(v); - } - }; - f("next", "prev"); - f("prev", "next"); -} -function generateXConstraints(rs, vars) { - return generateConstraints(rs, vars, xRect, 1e-6); -} -exports.generateXConstraints = generateXConstraints; -function generateYConstraints(rs, vars) { - return generateConstraints(rs, vars, yRect, 1e-6); -} -exports.generateYConstraints = generateYConstraints; -function generateXGroupConstraints(root) { - return generateGroupConstraints(root, xRect, 1e-6); -} -exports.generateXGroupConstraints = generateXGroupConstraints; -function generateYGroupConstraints(root) { - return generateGroupConstraints(root, yRect, 1e-6); -} -exports.generateYGroupConstraints = generateYGroupConstraints; -function removeOverlaps(rs) { - var vs = rs.map(function (r) { return new vpsc_1.Variable(r.cx()); }); - var cs = generateXConstraints(rs, vs); - var solver = new vpsc_1.Solver(vs, cs); - solver.solve(); - vs.forEach(function (v, i) { return rs[i].setXCentre(v.position()); }); - vs = rs.map(function (r) { return new vpsc_1.Variable(r.cy()); }); - cs = generateYConstraints(rs, vs); - solver = new vpsc_1.Solver(vs, cs); - solver.solve(); - vs.forEach(function (v, i) { return rs[i].setYCentre(v.position()); }); -} -exports.removeOverlaps = removeOverlaps; -var IndexedVariable = (function (_super) { - __extends(IndexedVariable, _super); - function IndexedVariable(index, w) { - var _this = _super.call(this, 0, w) || this; - _this.index = index; - return _this; - } - return IndexedVariable; -}(vpsc_1.Variable)); -exports.IndexedVariable = IndexedVariable; -var Projection = (function () { - function Projection(nodes, groups, rootGroup, constraints, avoidOverlaps) { - var _this = this; - if (rootGroup === void 0) { rootGroup = null; } - if (constraints === void 0) { constraints = null; } - if (avoidOverlaps === void 0) { avoidOverlaps = false; } - this.nodes = nodes; - this.groups = groups; - this.rootGroup = rootGroup; - this.avoidOverlaps = avoidOverlaps; - this.variables = nodes.map(function (v, i) { - return v.variable = new IndexedVariable(i, 1); - }); - if (constraints) - this.createConstraints(constraints); - if (avoidOverlaps && rootGroup && typeof rootGroup.groups !== 'undefined') { - nodes.forEach(function (v) { - if (!v.width || !v.height) { - v.bounds = new Rectangle(v.x, v.x, v.y, v.y); - return; - } - var w2 = v.width / 2, h2 = v.height / 2; - v.bounds = new Rectangle(v.x - w2, v.x + w2, v.y - h2, v.y + h2); - }); - computeGroupBounds(rootGroup); - var i = nodes.length; - groups.forEach(function (g) { - _this.variables[i] = g.minVar = new IndexedVariable(i++, typeof g.stiffness !== "undefined" ? g.stiffness : 0.01); - _this.variables[i] = g.maxVar = new IndexedVariable(i++, typeof g.stiffness !== "undefined" ? g.stiffness : 0.01); - }); - } - } - Projection.prototype.createSeparation = function (c) { - return new vpsc_1.Constraint(this.nodes[c.left].variable, this.nodes[c.right].variable, c.gap, typeof c.equality !== "undefined" ? c.equality : false); - }; - Projection.prototype.makeFeasible = function (c) { - var _this = this; - if (!this.avoidOverlaps) - return; - var axis = 'x', dim = 'width'; - if (c.axis === 'x') - axis = 'y', dim = 'height'; - var vs = c.offsets.map(function (o) { return _this.nodes[o.node]; }).sort(function (a, b) { return a[axis] - b[axis]; }); - var p = null; - vs.forEach(function (v) { - if (p) { - var nextPos = p[axis] + p[dim]; - if (nextPos > v[axis]) { - v[axis] = nextPos; - } - } - p = v; - }); - }; - Projection.prototype.createAlignment = function (c) { - var _this = this; - var u = this.nodes[c.offsets[0].node].variable; - this.makeFeasible(c); - var cs = c.axis === 'x' ? this.xConstraints : this.yConstraints; - c.offsets.slice(1).forEach(function (o) { - var v = _this.nodes[o.node].variable; - cs.push(new vpsc_1.Constraint(u, v, o.offset, true)); - }); - }; - Projection.prototype.createConstraints = function (constraints) { - var _this = this; - var isSep = function (c) { return typeof c.type === 'undefined' || c.type === 'separation'; }; - this.xConstraints = constraints - .filter(function (c) { return c.axis === "x" && isSep(c); }) - .map(function (c) { return _this.createSeparation(c); }); - this.yConstraints = constraints - .filter(function (c) { return c.axis === "y" && isSep(c); }) - .map(function (c) { return _this.createSeparation(c); }); - constraints - .filter(function (c) { return c.type === 'alignment'; }) - .forEach(function (c) { return _this.createAlignment(c); }); - }; - Projection.prototype.setupVariablesAndBounds = function (x0, y0, desired, getDesired) { - this.nodes.forEach(function (v, i) { - if (v.fixed) { - v.variable.weight = v.fixedWeight ? v.fixedWeight : 1000; - desired[i] = getDesired(v); - } - else { - v.variable.weight = 1; - } - var w = (v.width || 0) / 2, h = (v.height || 0) / 2; - var ix = x0[i], iy = y0[i]; - v.bounds = new Rectangle(ix - w, ix + w, iy - h, iy + h); - }); - }; - Projection.prototype.xProject = function (x0, y0, x) { - if (!this.rootGroup && !(this.avoidOverlaps || this.xConstraints)) - return; - this.project(x0, y0, x0, x, function (v) { return v.px; }, this.xConstraints, generateXGroupConstraints, function (v) { return v.bounds.setXCentre(x[v.variable.index] = v.variable.position()); }, function (g) { - var xmin = x[g.minVar.index] = g.minVar.position(); - var xmax = x[g.maxVar.index] = g.maxVar.position(); - var p2 = g.padding / 2; - g.bounds.x = xmin - p2; - g.bounds.X = xmax + p2; - }); - }; - Projection.prototype.yProject = function (x0, y0, y) { - if (!this.rootGroup && !this.yConstraints) - return; - this.project(x0, y0, y0, y, function (v) { return v.py; }, this.yConstraints, generateYGroupConstraints, function (v) { return v.bounds.setYCentre(y[v.variable.index] = v.variable.position()); }, function (g) { - var ymin = y[g.minVar.index] = g.minVar.position(); - var ymax = y[g.maxVar.index] = g.maxVar.position(); - var p2 = g.padding / 2; - g.bounds.y = ymin - p2; - ; - g.bounds.Y = ymax + p2; - }); - }; - Projection.prototype.projectFunctions = function () { - var _this = this; - return [ - function (x0, y0, x) { return _this.xProject(x0, y0, x); }, - function (x0, y0, y) { return _this.yProject(x0, y0, y); } - ]; - }; - Projection.prototype.project = function (x0, y0, start, desired, getDesired, cs, generateConstraints, updateNodeBounds, updateGroupBounds) { - this.setupVariablesAndBounds(x0, y0, desired, getDesired); - if (this.rootGroup && this.avoidOverlaps) { - computeGroupBounds(this.rootGroup); - cs = cs.concat(generateConstraints(this.rootGroup)); - } - this.solve(this.variables, cs, start, desired); - this.nodes.forEach(updateNodeBounds); - if (this.rootGroup && this.avoidOverlaps) { - this.groups.forEach(updateGroupBounds); - computeGroupBounds(this.rootGroup); - } - }; - Projection.prototype.solve = function (vs, cs, starting, desired) { - var solver = new vpsc_1.Solver(vs, cs); - solver.setStartingPositions(starting); - solver.setDesiredPositions(desired); - solver.solve(); - }; - return Projection; -}()); -exports.Projection = Projection; - -},{"./rbtree":16,"./vpsc":19}],18:[function(require,module,exports){ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -var pqueue_1 = require("./pqueue"); -var Neighbour = (function () { - function Neighbour(id, distance) { - this.id = id; - this.distance = distance; - } - return Neighbour; -}()); -var Node = (function () { - function Node(id) { - this.id = id; - this.neighbours = []; - } - return Node; -}()); -var QueueEntry = (function () { - function QueueEntry(node, prev, d) { - this.node = node; - this.prev = prev; - this.d = d; - } - return QueueEntry; -}()); -var Calculator = (function () { - function Calculator(n, es, getSourceIndex, getTargetIndex, getLength) { - this.n = n; - this.es = es; - this.neighbours = new Array(this.n); - var i = this.n; - while (i--) - this.neighbours[i] = new Node(i); - i = this.es.length; - while (i--) { - var e = this.es[i]; - var u = getSourceIndex(e), v = getTargetIndex(e); - var d = getLength(e); - this.neighbours[u].neighbours.push(new Neighbour(v, d)); - this.neighbours[v].neighbours.push(new Neighbour(u, d)); - } - } - Calculator.prototype.DistanceMatrix = function () { - var D = new Array(this.n); - for (var i = 0; i < this.n; ++i) { - D[i] = this.dijkstraNeighbours(i); - } - return D; - }; - Calculator.prototype.DistancesFromNode = function (start) { - return this.dijkstraNeighbours(start); - }; - Calculator.prototype.PathFromNodeToNode = function (start, end) { - return this.dijkstraNeighbours(start, end); - }; - Calculator.prototype.PathFromNodeToNodeWithPrevCost = function (start, end, prevCost) { - var q = new pqueue_1.PriorityQueue(function (a, b) { return a.d <= b.d; }), u = this.neighbours[start], qu = new QueueEntry(u, null, 0), visitedFrom = {}; - q.push(qu); - while (!q.empty()) { - qu = q.pop(); - u = qu.node; - if (u.id === end) { - break; - } - var i = u.neighbours.length; - while (i--) { - var neighbour = u.neighbours[i], v = this.neighbours[neighbour.id]; - if (qu.prev && v.id === qu.prev.node.id) - continue; - var viduid = v.id + ',' + u.id; - if (viduid in visitedFrom && visitedFrom[viduid] <= qu.d) - continue; - var cc = qu.prev ? prevCost(qu.prev.node.id, u.id, v.id) : 0, t = qu.d + neighbour.distance + cc; - visitedFrom[viduid] = t; - q.push(new QueueEntry(v, qu, t)); - } - } - var path = []; - while (qu.prev) { - qu = qu.prev; - path.push(qu.node.id); - } - return path; - }; - Calculator.prototype.dijkstraNeighbours = function (start, dest) { - if (dest === void 0) { dest = -1; } - var q = new pqueue_1.PriorityQueue(function (a, b) { return a.d <= b.d; }), i = this.neighbours.length, d = new Array(i); - while (i--) { - var node = this.neighbours[i]; - node.d = i === start ? 0 : Number.POSITIVE_INFINITY; - node.q = q.push(node); - } - while (!q.empty()) { - var u = q.pop(); - d[u.id] = u.d; - if (u.id === dest) { - var path = []; - var v = u; - while (typeof v.prev !== 'undefined') { - path.push(v.prev.id); - v = v.prev; - } - return path; - } - i = u.neighbours.length; - while (i--) { - var neighbour = u.neighbours[i]; - var v = this.neighbours[neighbour.id]; - var t = u.d + neighbour.distance; - if (u.d !== Number.MAX_VALUE && v.d > t) { - v.d = t; - v.prev = u; - q.reduceKey(v.q, v, function (e, q) { return e.q = q; }); - } - } - } - return d; - }; - return Calculator; -}()); -exports.Calculator = Calculator; - -},{"./pqueue":15}],19:[function(require,module,exports){ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -var PositionStats = (function () { - function PositionStats(scale) { - this.scale = scale; - this.AB = 0; - this.AD = 0; - this.A2 = 0; - } - PositionStats.prototype.addVariable = function (v) { - var ai = this.scale / v.scale; - var bi = v.offset / v.scale; - var wi = v.weight; - this.AB += wi * ai * bi; - this.AD += wi * ai * v.desiredPosition; - this.A2 += wi * ai * ai; - }; - PositionStats.prototype.getPosn = function () { - return (this.AD - this.AB) / this.A2; - }; - return PositionStats; -}()); -exports.PositionStats = PositionStats; -var Constraint = (function () { - function Constraint(left, right, gap, equality) { - if (equality === void 0) { equality = false; } - this.left = left; - this.right = right; - this.gap = gap; - this.equality = equality; - this.active = false; - this.unsatisfiable = false; - this.left = left; - this.right = right; - this.gap = gap; - this.equality = equality; - } - Constraint.prototype.slack = function () { - return this.unsatisfiable ? Number.MAX_VALUE - : this.right.scale * this.right.position() - this.gap - - this.left.scale * this.left.position(); - }; - return Constraint; -}()); -exports.Constraint = Constraint; -var Variable = (function () { - function Variable(desiredPosition, weight, scale) { - if (weight === void 0) { weight = 1; } - if (scale === void 0) { scale = 1; } - this.desiredPosition = desiredPosition; - this.weight = weight; - this.scale = scale; - this.offset = 0; - } - Variable.prototype.dfdv = function () { - return 2.0 * this.weight * (this.position() - this.desiredPosition); - }; - Variable.prototype.position = function () { - return (this.block.ps.scale * this.block.posn + this.offset) / this.scale; - }; - Variable.prototype.visitNeighbours = function (prev, f) { - var ff = function (c, next) { return c.active && prev !== next && f(c, next); }; - this.cOut.forEach(function (c) { return ff(c, c.right); }); - this.cIn.forEach(function (c) { return ff(c, c.left); }); - }; - return Variable; -}()); -exports.Variable = Variable; -var Block = (function () { - function Block(v) { - this.vars = []; - v.offset = 0; - this.ps = new PositionStats(v.scale); - this.addVariable(v); - } - Block.prototype.addVariable = function (v) { - v.block = this; - this.vars.push(v); - this.ps.addVariable(v); - this.posn = this.ps.getPosn(); - }; - Block.prototype.updateWeightedPosition = function () { - this.ps.AB = this.ps.AD = this.ps.A2 = 0; - for (var i = 0, n = this.vars.length; i < n; ++i) - this.ps.addVariable(this.vars[i]); - this.posn = this.ps.getPosn(); - }; - Block.prototype.compute_lm = function (v, u, postAction) { - var _this = this; - var dfdv = v.dfdv(); - v.visitNeighbours(u, function (c, next) { - var _dfdv = _this.compute_lm(next, v, postAction); - if (next === c.right) { - dfdv += _dfdv * c.left.scale; - c.lm = _dfdv; - } - else { - dfdv += _dfdv * c.right.scale; - c.lm = -_dfdv; - } - postAction(c); - }); - return dfdv / v.scale; - }; - Block.prototype.populateSplitBlock = function (v, prev) { - var _this = this; - v.visitNeighbours(prev, function (c, next) { - next.offset = v.offset + (next === c.right ? c.gap : -c.gap); - _this.addVariable(next); - _this.populateSplitBlock(next, v); - }); - }; - Block.prototype.traverse = function (visit, acc, v, prev) { - var _this = this; - if (v === void 0) { v = this.vars[0]; } - if (prev === void 0) { prev = null; } - v.visitNeighbours(prev, function (c, next) { - acc.push(visit(c)); - _this.traverse(visit, acc, next, v); - }); - }; - Block.prototype.findMinLM = function () { - var m = null; - this.compute_lm(this.vars[0], null, function (c) { - if (!c.equality && (m === null || c.lm < m.lm)) - m = c; - }); - return m; - }; - Block.prototype.findMinLMBetween = function (lv, rv) { - this.compute_lm(lv, null, function () { }); - var m = null; - this.findPath(lv, null, rv, function (c, next) { - if (!c.equality && c.right === next && (m === null || c.lm < m.lm)) - m = c; - }); - return m; - }; - Block.prototype.findPath = function (v, prev, to, visit) { - var _this = this; - var endFound = false; - v.visitNeighbours(prev, function (c, next) { - if (!endFound && (next === to || _this.findPath(next, v, to, visit))) { - endFound = true; - visit(c, next); - } - }); - return endFound; - }; - Block.prototype.isActiveDirectedPathBetween = function (u, v) { - if (u === v) - return true; - var i = u.cOut.length; - while (i--) { - var c = u.cOut[i]; - if (c.active && this.isActiveDirectedPathBetween(c.right, v)) - return true; - } - return false; - }; - Block.split = function (c) { - c.active = false; - return [Block.createSplitBlock(c.left), Block.createSplitBlock(c.right)]; - }; - Block.createSplitBlock = function (startVar) { - var b = new Block(startVar); - b.populateSplitBlock(startVar, null); - return b; - }; - Block.prototype.splitBetween = function (vl, vr) { - var c = this.findMinLMBetween(vl, vr); - if (c !== null) { - var bs = Block.split(c); - return { constraint: c, lb: bs[0], rb: bs[1] }; - } - return null; - }; - Block.prototype.mergeAcross = function (b, c, dist) { - c.active = true; - for (var i = 0, n = b.vars.length; i < n; ++i) { - var v = b.vars[i]; - v.offset += dist; - this.addVariable(v); - } - this.posn = this.ps.getPosn(); - }; - Block.prototype.cost = function () { - var sum = 0, i = this.vars.length; - while (i--) { - var v = this.vars[i], d = v.position() - v.desiredPosition; - sum += d * d * v.weight; - } - return sum; - }; - return Block; -}()); -exports.Block = Block; -var Blocks = (function () { - function Blocks(vs) { - this.vs = vs; - var n = vs.length; - this.list = new Array(n); - while (n--) { - var b = new Block(vs[n]); - this.list[n] = b; - b.blockInd = n; - } - } - Blocks.prototype.cost = function () { - var sum = 0, i = this.list.length; - while (i--) - sum += this.list[i].cost(); - return sum; - }; - Blocks.prototype.insert = function (b) { - b.blockInd = this.list.length; - this.list.push(b); - }; - Blocks.prototype.remove = function (b) { - var last = this.list.length - 1; - var swapBlock = this.list[last]; - this.list.length = last; - if (b !== swapBlock) { - this.list[b.blockInd] = swapBlock; - swapBlock.blockInd = b.blockInd; - } - }; - Blocks.prototype.merge = function (c) { - var l = c.left.block, r = c.right.block; - var dist = c.right.offset - c.left.offset - c.gap; - if (l.vars.length < r.vars.length) { - r.mergeAcross(l, c, dist); - this.remove(l); - } - else { - l.mergeAcross(r, c, -dist); - this.remove(r); - } - }; - Blocks.prototype.forEach = function (f) { - this.list.forEach(f); - }; - Blocks.prototype.updateBlockPositions = function () { - this.list.forEach(function (b) { return b.updateWeightedPosition(); }); - }; - Blocks.prototype.split = function (inactive) { - var _this = this; - this.updateBlockPositions(); - this.list.forEach(function (b) { - var v = b.findMinLM(); - if (v !== null && v.lm < Solver.LAGRANGIAN_TOLERANCE) { - b = v.left.block; - Block.split(v).forEach(function (nb) { return _this.insert(nb); }); - _this.remove(b); - inactive.push(v); - } - }); - }; - return Blocks; -}()); -exports.Blocks = Blocks; -var Solver = (function () { - function Solver(vs, cs) { - this.vs = vs; - this.cs = cs; - this.vs = vs; - vs.forEach(function (v) { - v.cIn = [], v.cOut = []; - }); - this.cs = cs; - cs.forEach(function (c) { - c.left.cOut.push(c); - c.right.cIn.push(c); - }); - this.inactive = cs.map(function (c) { c.active = false; return c; }); - this.bs = null; - } - Solver.prototype.cost = function () { - return this.bs.cost(); - }; - Solver.prototype.setStartingPositions = function (ps) { - this.inactive = this.cs.map(function (c) { c.active = false; return c; }); - this.bs = new Blocks(this.vs); - this.bs.forEach(function (b, i) { return b.posn = ps[i]; }); - }; - Solver.prototype.setDesiredPositions = function (ps) { - this.vs.forEach(function (v, i) { return v.desiredPosition = ps[i]; }); - }; - Solver.prototype.mostViolated = function () { - var minSlack = Number.MAX_VALUE, v = null, l = this.inactive, n = l.length, deletePoint = n; - for (var i = 0; i < n; ++i) { - var c = l[i]; - if (c.unsatisfiable) - continue; - var slack = c.slack(); - if (c.equality || slack < minSlack) { - minSlack = slack; - v = c; - deletePoint = i; - if (c.equality) - break; - } - } - if (deletePoint !== n && - (minSlack < Solver.ZERO_UPPERBOUND && !v.active || v.equality)) { - l[deletePoint] = l[n - 1]; - l.length = n - 1; - } - return v; - }; - Solver.prototype.satisfy = function () { - if (this.bs == null) { - this.bs = new Blocks(this.vs); - } - this.bs.split(this.inactive); - var v = null; - while ((v = this.mostViolated()) && (v.equality || v.slack() < Solver.ZERO_UPPERBOUND && !v.active)) { - var lb = v.left.block, rb = v.right.block; - if (lb !== rb) { - this.bs.merge(v); - } - else { - if (lb.isActiveDirectedPathBetween(v.right, v.left)) { - v.unsatisfiable = true; - continue; - } - var split = lb.splitBetween(v.left, v.right); - if (split !== null) { - this.bs.insert(split.lb); - this.bs.insert(split.rb); - this.bs.remove(lb); - this.inactive.push(split.constraint); - } - else { - v.unsatisfiable = true; - continue; - } - if (v.slack() >= 0) { - this.inactive.push(v); - } - else { - this.bs.merge(v); - } - } - } - }; - Solver.prototype.solve = function () { - this.satisfy(); - var lastcost = Number.MAX_VALUE, cost = this.bs.cost(); - while (Math.abs(lastcost - cost) > 0.0001) { - this.satisfy(); - lastcost = cost; - cost = this.bs.cost(); - } - return cost; - }; - Solver.LAGRANGIAN_TOLERANCE = -1e-4; - Solver.ZERO_UPPERBOUND = -1e-10; - return Solver; -}()); -exports.Solver = Solver; -function removeOverlapInOneDimension(spans, lowerBound, upperBound) { - var vs = spans.map(function (s) { return new Variable(s.desiredCenter); }); - var cs = []; - var n = spans.length; - for (var i = 0; i < n - 1; i++) { - var left = spans[i], right = spans[i + 1]; - cs.push(new Constraint(vs[i], vs[i + 1], (left.size + right.size) / 2)); - } - var leftMost = vs[0], rightMost = vs[n - 1], leftMostSize = spans[0].size / 2, rightMostSize = spans[n - 1].size / 2; - var vLower = null, vUpper = null; - if (lowerBound) { - vLower = new Variable(lowerBound, leftMost.weight * 1000); - vs.push(vLower); - cs.push(new Constraint(vLower, leftMost, leftMostSize)); - } - if (upperBound) { - vUpper = new Variable(upperBound, rightMost.weight * 1000); - vs.push(vUpper); - cs.push(new Constraint(rightMost, vUpper, rightMostSize)); - } - var solver = new Solver(vs, cs); - solver.solve(); - return { - newCenters: vs.slice(0, spans.length).map(function (v) { return v.position(); }), - lowerBound: vLower ? vLower.position() : leftMost.position() - leftMostSize, - upperBound: vUpper ? vUpper.position() : rightMost.position() + rightMostSize - }; -} -exports.removeOverlapInOneDimension = removeOverlapInOneDimension; - -},{}]},{},[1])(1) -}); - -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","dist/index.js","dist/src/adaptor.js","dist/src/batch.js","dist/src/d3adaptor.js","dist/src/d3v3adaptor.js","dist/src/d3v4adaptor.js","dist/src/descent.js","dist/src/geom.js","dist/src/gridrouter.js","dist/src/handledisconnected.js","dist/src/layout.js","dist/src/layout3d.js","dist/src/linklengths.js","dist/src/powergraph.js","dist/src/pqueue.js","dist/src/rbtree.js","dist/src/rectangle.js","dist/src/shortestpaths.js","dist/src/vpsc.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvaA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACriBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5iBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5TA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACndA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c=\"function\"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error(\"Cannot find module '\"+i+\"'\");throw a.code=\"MODULE_NOT_FOUND\",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u=\"function\"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()","\"use strict\";\nfunction __export(m) {\n    for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];\n}\nObject.defineProperty(exports, \"__esModule\", { value: true });\n__export(require(\"./src/adaptor\"));\n__export(require(\"./src/d3adaptor\"));\n__export(require(\"./src/descent\"));\n__export(require(\"./src/geom\"));\n__export(require(\"./src/gridrouter\"));\n__export(require(\"./src/handledisconnected\"));\n__export(require(\"./src/layout\"));\n__export(require(\"./src/layout3d\"));\n__export(require(\"./src/linklengths\"));\n__export(require(\"./src/powergraph\"));\n__export(require(\"./src/pqueue\"));\n__export(require(\"./src/rbtree\"));\n__export(require(\"./src/rectangle\"));\n__export(require(\"./src/shortestpaths\"));\n__export(require(\"./src/vpsc\"));\n__export(require(\"./src/batch\"));\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9XZWJDb2xhL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsbUNBQTZCO0FBQzdCLHFDQUErQjtBQUMvQixtQ0FBNkI7QUFDN0IsZ0NBQTBCO0FBQzFCLHNDQUFnQztBQUNoQyw4Q0FBd0M7QUFDeEMsa0NBQTRCO0FBQzVCLG9DQUE4QjtBQUM5Qix1Q0FBaUM7QUFDakMsc0NBQWdDO0FBQ2hDLGtDQUE0QjtBQUM1QixrQ0FBNEI7QUFDNUIscUNBQStCO0FBQy9CLHlDQUFtQztBQUNuQyxnQ0FBMEI7QUFDMUIsaUNBQTJCIn0=","\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n    var extendStatics = function (d, b) {\n        extendStatics = Object.setPrototypeOf ||\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n            function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n        return extendStatics(d, b);\n    };\n    return function (d, b) {\n        extendStatics(d, b);\n        function __() { this.constructor = d; }\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n    };\n})();\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar layout_1 = require(\"./layout\");\nvar LayoutAdaptor = (function (_super) {\n    __extends(LayoutAdaptor, _super);\n    function LayoutAdaptor(options) {\n        var _this = _super.call(this) || this;\n        var self = _this;\n        var o = options;\n        if (o.trigger) {\n            _this.trigger = o.trigger;\n        }\n        if (o.kick) {\n            _this.kick = o.kick;\n        }\n        if (o.drag) {\n            _this.drag = o.drag;\n        }\n        if (o.on) {\n            _this.on = o.on;\n        }\n        _this.dragstart = _this.dragStart = layout_1.Layout.dragStart;\n        _this.dragend = _this.dragEnd = layout_1.Layout.dragEnd;\n        return _this;\n    }\n    LayoutAdaptor.prototype.trigger = function (e) { };\n    ;\n    LayoutAdaptor.prototype.kick = function () { };\n    ;\n    LayoutAdaptor.prototype.drag = function () { };\n    ;\n    LayoutAdaptor.prototype.on = function (eventType, listener) { return this; };\n    ;\n    return LayoutAdaptor;\n}(layout_1.Layout));\nexports.LayoutAdaptor = LayoutAdaptor;\nfunction adaptor(options) {\n    return new LayoutAdaptor(options);\n}\nexports.adaptor = adaptor;\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRhcHRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL1dlYkNvbGEvc3JjL2FkYXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsbUNBQWlEO0FBRTdDO0lBQW1DLGlDQUFNO0lBYXJDLHVCQUFhLE9BQU87UUFBcEIsWUFDSSxpQkFBTyxTQXlCVjtRQXJCRyxJQUFJLElBQUksR0FBRyxLQUFJLENBQUM7UUFDaEIsSUFBSSxDQUFDLEdBQUcsT0FBTyxDQUFDO1FBRWhCLElBQUssQ0FBQyxDQUFDLE9BQU8sRUFBRztZQUNiLEtBQUksQ0FBQyxPQUFPLEdBQUcsQ0FBQyxDQUFDLE9BQU8sQ0FBQztTQUM1QjtRQUVELElBQUssQ0FBQyxDQUFDLElBQUksRUFBRTtZQUNULEtBQUksQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQztTQUN0QjtRQUVELElBQUssQ0FBQyxDQUFDLElBQUksRUFBRTtZQUNULEtBQUksQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQztTQUN0QjtRQUVELElBQUssQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUNQLEtBQUksQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQztTQUNsQjtRQUVELEtBQUksQ0FBQyxTQUFTLEdBQUcsS0FBSSxDQUFDLFNBQVMsR0FBRyxlQUFNLENBQUMsU0FBUyxDQUFDO1FBQ25ELEtBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSSxDQUFDLE9BQU8sR0FBRyxlQUFNLENBQUMsT0FBTyxDQUFDOztJQUNqRCxDQUFDO0lBcENELCtCQUFPLEdBQVAsVUFBUSxDQUFRLElBQUcsQ0FBQztJQUFBLENBQUM7SUFDckIsNEJBQUksR0FBSixjQUFRLENBQUM7SUFBQSxDQUFDO0lBQ1YsNEJBQUksR0FBSixjQUFRLENBQUM7SUFBQSxDQUFDO0lBQ1YsMEJBQUUsR0FBRixVQUFHLFNBQTZCLEVBQUUsUUFBb0IsSUFBVyxPQUFPLElBQUksQ0FBQyxDQUFDLENBQUM7SUFBQSxDQUFDO0lBa0NwRixvQkFBQztBQUFELENBQUMsQUF4Q0QsQ0FBbUMsZUFBTSxHQXdDeEM7QUF4Q1ksc0NBQWE7QUE2QzFCLFNBQWdCLE9BQU8sQ0FBRSxPQUFPO0lBQzVCLE9BQU8sSUFBSSxhQUFhLENBQUUsT0FBTyxDQUFFLENBQUM7QUFDeEMsQ0FBQztBQUZELDBCQUVDIn0=","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar layout_1 = require(\"./layout\");\nvar gridrouter_1 = require(\"./gridrouter\");\nfunction gridify(pgLayout, nudgeGap, margin, groupMargin) {\n    pgLayout.cola.start(0, 0, 0, 10, false);\n    var gridrouter = route(pgLayout.cola.nodes(), pgLayout.cola.groups(), margin, groupMargin);\n    return gridrouter.routeEdges(pgLayout.powerGraph.powerEdges, nudgeGap, function (e) { return e.source.routerNode.id; }, function (e) { return e.target.routerNode.id; });\n}\nexports.gridify = gridify;\nfunction route(nodes, groups, margin, groupMargin) {\n    nodes.forEach(function (d) {\n        d.routerNode = {\n            name: d.name,\n            bounds: d.bounds.inflate(-margin)\n        };\n    });\n    groups.forEach(function (d) {\n        d.routerNode = {\n            bounds: d.bounds.inflate(-groupMargin),\n            children: (typeof d.groups !== 'undefined' ? d.groups.map(function (c) { return nodes.length + c.id; }) : [])\n                .concat(typeof d.leaves !== 'undefined' ? d.leaves.map(function (c) { return c.index; }) : [])\n        };\n    });\n    var gridRouterNodes = nodes.concat(groups).map(function (d, i) {\n        d.routerNode.id = i;\n        return d.routerNode;\n    });\n    return new gridrouter_1.GridRouter(gridRouterNodes, {\n        getChildren: function (v) { return v.children; },\n        getBounds: function (v) { return v.bounds; }\n    }, margin - groupMargin);\n}\nfunction powerGraphGridLayout(graph, size, grouppadding) {\n    var powerGraph;\n    graph.nodes.forEach(function (v, i) { return v.index = i; });\n    new layout_1.Layout()\n        .avoidOverlaps(false)\n        .nodes(graph.nodes)\n        .links(graph.links)\n        .powerGraphGroups(function (d) {\n        powerGraph = d;\n        powerGraph.groups.forEach(function (v) { return v.padding = grouppadding; });\n    });\n    var n = graph.nodes.length;\n    var edges = [];\n    var vs = graph.nodes.slice(0);\n    vs.forEach(function (v, i) { return v.index = i; });\n    powerGraph.groups.forEach(function (g) {\n        var sourceInd = g.index = g.id + n;\n        vs.push(g);\n        if (typeof g.leaves !== 'undefined')\n            g.leaves.forEach(function (v) { return edges.push({ source: sourceInd, target: v.index }); });\n        if (typeof g.groups !== 'undefined')\n            g.groups.forEach(function (gg) { return edges.push({ source: sourceInd, target: gg.id + n }); });\n    });\n    powerGraph.powerEdges.forEach(function (e) {\n        edges.push({ source: e.source.index, target: e.target.index });\n    });\n    new layout_1.Layout()\n        .size(size)\n        .nodes(vs)\n        .links(edges)\n        .avoidOverlaps(false)\n        .linkDistance(30)\n        .symmetricDiffLinkLengths(5)\n        .convergenceThreshold(1e-4)\n        .start(100, 0, 0, 0, false);\n    return {\n        cola: new layout_1.Layout()\n            .convergenceThreshold(1e-3)\n            .size(size)\n            .avoidOverlaps(true)\n            .nodes(graph.nodes)\n            .links(graph.links)\n            .groupCompactness(1e-4)\n            .linkDistance(30)\n            .symmetricDiffLinkLengths(5)\n            .powerGraphGroups(function (d) {\n            powerGraph = d;\n            powerGraph.groups.forEach(function (v) {\n                v.padding = grouppadding;\n            });\n        }).start(50, 0, 100, 0, false),\n        powerGraph: powerGraph\n    };\n}\nexports.powerGraphGridLayout = powerGraphGridLayout;\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmF0Y2guanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9XZWJDb2xhL3NyYy9iYXRjaC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLG1DQUEyQztBQUMzQywyQ0FBdUM7QUFRdkMsU0FBZ0IsT0FBTyxDQUFDLFFBQVEsRUFBRSxRQUFnQixFQUFFLE1BQWMsRUFBRSxXQUFtQjtJQUNuRixRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDeEMsSUFBSSxVQUFVLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLEVBQUUsUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxNQUFNLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDM0YsT0FBTyxVQUFVLENBQUMsVUFBVSxDQUFNLFFBQVEsQ0FBQyxVQUFVLENBQUMsVUFBVSxFQUFFLFFBQVEsRUFBRSxVQUFBLENBQUMsSUFBRyxPQUFBLENBQUMsQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLEVBQUUsRUFBdEIsQ0FBc0IsRUFBRSxVQUFBLENBQUMsSUFBRyxPQUFBLENBQUMsQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLEVBQUUsRUFBdEIsQ0FBc0IsQ0FBQyxDQUFDO0FBQ3hJLENBQUM7QUFKRCwwQkFJQztBQUVELFNBQVMsS0FBSyxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBYyxFQUFFLFdBQW1CO0lBQzdELEtBQUssQ0FBQyxPQUFPLENBQUMsVUFBQSxDQUFDO1FBQ1gsQ0FBQyxDQUFDLFVBQVUsR0FBUTtZQUNoQixJQUFJLEVBQUUsQ0FBQyxDQUFDLElBQUk7WUFDWixNQUFNLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFNLENBQUM7U0FDcEMsQ0FBQztJQUNOLENBQUMsQ0FBQyxDQUFDO0lBQ0gs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","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar d3v3 = require(\"./d3v3adaptor\");\nvar d3v4 = require(\"./d3v4adaptor\");\n;\nfunction d3adaptor(d3Context) {\n    if (!d3Context || isD3V3(d3Context)) {\n        return new d3v3.D3StyleLayoutAdaptor();\n    }\n    return new d3v4.D3StyleLayoutAdaptor(d3Context);\n}\nexports.d3adaptor = d3adaptor;\nfunction isD3V3(d3Context) {\n    var v3exp = /^3\\./;\n    return d3Context.version && d3Context.version.match(v3exp) !== null;\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZDNhZGFwdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vV2ViQ29sYS9zcmMvZDNhZGFwdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsb0NBQXFDO0FBQ3JDLG9DQUFxQztBQUdVLENBQUM7QUE0QmhELFNBQWdCLFNBQVMsQ0FBQyxTQUF3QztJQUM5RCxJQUFJLENBQUMsU0FBUyxJQUFJLE1BQU0sQ0FBQyxTQUFTLENBQUMsRUFBRTtRQUNqQyxPQUFPLElBQUksSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUM7S0FDMUM7SUFDRCxPQUFPLElBQUksSUFBSSxDQUFDLG9CQUFvQixDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBQ3BELENBQUM7QUFMRCw4QkFLQztBQUVELFNBQVMsTUFBTSxDQUFDLFNBQXVDO0lBQ25ELElBQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQztJQUNyQixPQUFhLFNBQVUsQ0FBQyxPQUFPLElBQVUsU0FBVSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLEtBQUssSUFBSSxDQUFDO0FBQ3RGLENBQUMifQ==","\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n    var extendStatics = function (d, b) {\n        extendStatics = Object.setPrototypeOf ||\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n            function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n        return extendStatics(d, b);\n    };\n    return function (d, b) {\n        extendStatics(d, b);\n        function __() { this.constructor = d; }\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n    };\n})();\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar layout_1 = require(\"./layout\");\nvar D3StyleLayoutAdaptor = (function (_super) {\n    __extends(D3StyleLayoutAdaptor, _super);\n    function D3StyleLayoutAdaptor() {\n        var _this = _super.call(this) || this;\n        _this.event = d3.dispatch(layout_1.EventType[layout_1.EventType.start], layout_1.EventType[layout_1.EventType.tick], layout_1.EventType[layout_1.EventType.end]);\n        var d3layout = _this;\n        var drag;\n        _this.drag = function () {\n            if (!drag) {\n                var drag = d3.behavior.drag()\n                    .origin(layout_1.Layout.dragOrigin)\n                    .on(\"dragstart.d3adaptor\", layout_1.Layout.dragStart)\n                    .on(\"drag.d3adaptor\", function (d) {\n                    layout_1.Layout.drag(d, d3.event);\n                    d3layout.resume();\n                })\n                    .on(\"dragend.d3adaptor\", layout_1.Layout.dragEnd);\n            }\n            if (!arguments.length)\n                return drag;\n            this\n                .call(drag);\n        };\n        return _this;\n    }\n    D3StyleLayoutAdaptor.prototype.trigger = function (e) {\n        var d3event = { type: layout_1.EventType[e.type], alpha: e.alpha, stress: e.stress };\n        this.event[d3event.type](d3event);\n    };\n    D3StyleLayoutAdaptor.prototype.kick = function () {\n        var _this = this;\n        d3.timer(function () { return _super.prototype.tick.call(_this); });\n    };\n    D3StyleLayoutAdaptor.prototype.on = function (eventType, listener) {\n        if (typeof eventType === 'string') {\n            this.event.on(eventType, listener);\n        }\n        else {\n            this.event.on(layout_1.EventType[eventType], listener);\n        }\n        return this;\n    };\n    return D3StyleLayoutAdaptor;\n}(layout_1.Layout));\nexports.D3StyleLayoutAdaptor = D3StyleLayoutAdaptor;\nfunction d3adaptor() {\n    return new D3StyleLayoutAdaptor();\n}\nexports.d3adaptor = d3adaptor;\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZDN2M2FkYXB0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9XZWJDb2xhL3NyYy9kM3YzYWRhcHRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7QUFNQSxtQ0FBa0Q7QUFHOUM7SUFBMEMsd0NBQU07SUFnQjVDO1FBQUEsWUFDSSxpQkFBTyxTQXVCVjtRQXZDRCxXQUFLLEdBQUcsRUFBRSxDQUFDLFFBQVEsQ0FBQyxrQkFBUyxDQUFDLGtCQUFTLENBQUMsS0FBSyxDQUFDLEVBQUUsa0JBQVMsQ0FBQyxrQkFBUyxDQUFDLElBQUksQ0FBQyxFQUFFLGtCQUFTLENBQUMsa0JBQVMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBa0JqRyxJQUFJLFFBQVEsR0FBRyxLQUFJLENBQUM7UUFDcEIsSUFBSSxJQUFJLENBQUM7UUFDVCxLQUFJLENBQUMsSUFBSSxHQUFHO1lBQ1IsSUFBSSxDQUFDLElBQUksRUFBRTtnQkFDUCxJQUFJLElBQUksR0FBRyxFQUFFLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRTtxQkFDeEIsTUFBTSxDQUFDLGVBQU0sQ0FBQyxVQUFVLENBQUM7cUJBQ3pCLEVBQUUsQ0FBQyxxQkFBcUIsRUFBRSxlQUFNLENBQUMsU0FBUyxDQUFDO3FCQUMzQyxFQUFFLENBQUMsZ0JBQWdCLEVBQUUsVUFBQSxDQUFDO29CQUNuQixlQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsRUFBTyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUM7b0JBQzlCLFFBQVEsQ0FBQyxNQUFNLEVBQUUsQ0FBQztnQkFDdEIsQ0FBQyxDQUFDO3FCQUNELEVBQUUsQ0FBQyxtQkFBbUIsRUFBRSxlQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7YUFDaEQ7WUFFRCxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU07Z0JBQUUsT0FBTyxJQUFJLENBQUM7WUFHbkMsSUFBSTtpQkFFQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDcEIsQ0FBQyxDQUFBOztJQUNMLENBQUM7SUFyQ0Qsc0NBQU8sR0FBUCxVQUFRLENBQVE7UUFDWixJQUFJLE9BQU8sR0FBRyxFQUFFLElBQUksRUFBRSxrQkFBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQzVFLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFHRCxtQ0FBSSxHQUFKO1FBQUEsaUJBRUM7UUFERyxFQUFFLENBQUMsS0FBSyxDQUFDLGNBQU0sT0FBQSxpQkFBTSxJQUFJLFlBQUUsRUFBWixDQUFZLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBZ0NELGlDQUFFLEdBQUYsVUFBRyxTQUE2QixFQUFFLFFBQW9CO1FBQ2xELElBQUksT0FBTyxTQUFTLEtBQUssUUFBUSxFQUFFO1lBQy9CLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLFNBQVMsRUFBRSxRQUFRLENBQUMsQ0FBQztTQUN0QzthQUFNO1lBQ0gsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsa0JBQVMsQ0FBQyxTQUFTLENBQUMsRUFBRSxRQUFRLENBQUMsQ0FBQztTQUNqRDtRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7SUFDTCwyQkFBQztBQUFELENBQUMsQUFuREQsQ0FBMEMsZUFBTSxHQW1EL0M7QUFuRFksb0RBQW9CO0FBaUVqQyxTQUFnQixTQUFTO0lBQ3JCLE9BQU8sSUFBSSxvQkFBb0IsRUFBRSxDQUFDO0FBQ3RDLENBQUM7QUFGRCw4QkFFQyJ9","\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n    var extendStatics = function (d, b) {\n        extendStatics = Object.setPrototypeOf ||\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n            function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n        return extendStatics(d, b);\n    };\n    return function (d, b) {\n        extendStatics(d, b);\n        function __() { this.constructor = d; }\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n    };\n})();\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar layout_1 = require(\"./layout\");\nvar D3StyleLayoutAdaptor = (function (_super) {\n    __extends(D3StyleLayoutAdaptor, _super);\n    function D3StyleLayoutAdaptor(d3Context) {\n        var _this = _super.call(this) || this;\n        _this.d3Context = d3Context;\n        _this.event = d3Context.dispatch(layout_1.EventType[layout_1.EventType.start], layout_1.EventType[layout_1.EventType.tick], layout_1.EventType[layout_1.EventType.end]);\n        var d3layout = _this;\n        var drag;\n        _this.drag = function () {\n            if (!drag) {\n                var drag = d3Context.drag()\n                    .subject(layout_1.Layout.dragOrigin)\n                    .on(\"start.d3adaptor\", layout_1.Layout.dragStart)\n                    .on(\"drag.d3adaptor\", function (d) {\n                    layout_1.Layout.drag(d, d3Context.event);\n                    d3layout.resume();\n                })\n                    .on(\"end.d3adaptor\", layout_1.Layout.dragEnd);\n            }\n            if (!arguments.length)\n                return drag;\n            arguments[0].call(drag);\n        };\n        return _this;\n    }\n    D3StyleLayoutAdaptor.prototype.trigger = function (e) {\n        var d3event = { type: layout_1.EventType[e.type], alpha: e.alpha, stress: e.stress };\n        this.event.call(d3event.type, d3event);\n    };\n    D3StyleLayoutAdaptor.prototype.kick = function () {\n        var _this = this;\n        var t = this.d3Context.timer(function () { return _super.prototype.tick.call(_this) && t.stop(); });\n    };\n    D3StyleLayoutAdaptor.prototype.on = function (eventType, listener) {\n        if (typeof eventType === 'string') {\n            this.event.on(eventType, listener);\n        }\n        else {\n            this.event.on(layout_1.EventType[eventType], listener);\n        }\n        return this;\n    };\n    return D3StyleLayoutAdaptor;\n}(layout_1.Layout));\nexports.D3StyleLayoutAdaptor = D3StyleLayoutAdaptor;\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZDN2NGFkYXB0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9XZWJDb2xhL3NyYy9kM3Y0YWRhcHRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7QUFHQSxtQ0FBaUQ7QUFVakQ7SUFBMEMsd0NBQU07SUFpQjVDLDhCQUFvQixTQUFvQjtRQUF4QyxZQUNJLGlCQUFPLFNBeUJWO1FBMUJtQixlQUFTLEdBQVQsU0FBUyxDQUFXO1FBRXBDLEtBQUksQ0FBQyxLQUFLLEdBQUcsU0FBUyxDQUFDLFFBQVEsQ0FBQyxrQkFBUyxDQUFDLGtCQUFTLENBQUMsS0FBSyxDQUFDLEVBQUUsa0JBQVMsQ0FBQyxrQkFBUyxDQUFDLElBQUksQ0FBQyxFQUFFLGtCQUFTLENBQUMsa0JBQVMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBR2pILElBQUksUUFBUSxHQUFHLEtBQUksQ0FBQztRQUNwQixJQUFJLElBQUksQ0FBQztRQUNULEtBQUksQ0FBQyxJQUFJLEdBQUc7WUFDUixJQUFJLENBQUMsSUFBSSxFQUFFO2dCQUNQLElBQUksSUFBSSxHQUFHLFNBQVMsQ0FBQyxJQUFJLEVBQUU7cUJBQ3RCLE9BQU8sQ0FBQyxlQUFNLENBQUMsVUFBVSxDQUFDO3FCQUMxQixFQUFFLENBQUMsaUJBQWlCLEVBQUUsZUFBTSxDQUFDLFNBQVMsQ0FBQztxQkFDdkMsRUFBRSxDQUFDLGdCQUFnQixFQUFFLFVBQUEsQ0FBQztvQkFDbkIsZUFBTSxDQUFDLElBQUksQ0FBTSxDQUFDLEVBQUUsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDO29CQUNyQyxRQUFRLENBQUMsTUFBTSxFQUFFLENBQUM7Z0JBQ3RCLENBQUMsQ0FBQztxQkFDRCxFQUFFLENBQUMsZUFBZSxFQUFFLGVBQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQzthQUM1QztZQUVELElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTTtnQkFBRSxPQUFPLElBQUksQ0FBQztZQUtuQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzVCLENBQUMsQ0FBQTs7SUFDTCxDQUFDO0lBekNELHNDQUFPLEdBQVAsVUFBUSxDQUFRO1FBQ1osSUFBSSxPQUFPLEdBQUcsRUFBRSxJQUFJLEVBQUUsa0JBQVMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUc1RSxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFPLE9BQU8sQ0FBQyxDQUFDO0lBQ2hELENBQUM7SUFHRCxtQ0FBSSxHQUFKO1FBQUEsaUJBRUM7UUFERyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxjQUFNLE9BQUEsaUJBQU0sSUFBSSxZQUFFLElBQUksQ0FBQyxDQUFDLElBQUksRUFBRSxFQUF4QixDQUF3QixDQUFDLENBQUM7SUFDakUsQ0FBQztJQWtDRCxpQ0FBRSxHQUFGLFVBQUcsU0FBNkIsRUFBRSxRQUFvQjtRQUNsRCxJQUFJLE9BQU8sU0FBUyxLQUFLLFFBQVEsRUFBRTtZQUMvQixJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxTQUFTLEVBQUUsUUFBUSxDQUFDLENBQUM7U0FDdEM7YUFBTTtZQUNILElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLGtCQUFTLENBQUMsU0FBUyxDQUFDLEVBQUUsUUFBUSxDQUFDLENBQUM7U0FDakQ7UUFDRCxPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0lBQ0wsMkJBQUM7QUFBRCxDQUFDLEFBdERELENBQTBDLGVBQU0sR0FzRC9DO0FBdERZLG9EQUFvQiJ9","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar Locks = (function () {\n    function Locks() {\n        this.locks = {};\n    }\n    Locks.prototype.add = function (id, x) {\n        this.locks[id] = x;\n    };\n    Locks.prototype.clear = function () {\n        this.locks = {};\n    };\n    Locks.prototype.isEmpty = function () {\n        for (var l in this.locks)\n            return false;\n        return true;\n    };\n    Locks.prototype.apply = function (f) {\n        for (var l in this.locks) {\n            f(Number(l), this.locks[l]);\n        }\n    };\n    return Locks;\n}());\nexports.Locks = Locks;\nvar Descent = (function () {\n    function Descent(x, D, G) {\n        if (G === void 0) { G = null; }\n        this.D = D;\n        this.G = G;\n        this.threshold = 0.0001;\n        this.numGridSnapNodes = 0;\n        this.snapGridSize = 100;\n        this.snapStrength = 1000;\n        this.scaleSnapByMaxH = false;\n        this.random = new PseudoRandom();\n        this.project = null;\n        this.x = x;\n        this.k = x.length;\n        var n = this.n = x[0].length;\n        this.H = new Array(this.k);\n        this.g = new Array(this.k);\n        this.Hd = new Array(this.k);\n        this.a = new Array(this.k);\n        this.b = new Array(this.k);\n        this.c = new Array(this.k);\n        this.d = new Array(this.k);\n        this.e = new Array(this.k);\n        this.ia = new Array(this.k);\n        this.ib = new Array(this.k);\n        this.xtmp = new Array(this.k);\n        this.locks = new Locks();\n        this.minD = Number.MAX_VALUE;\n        var i = n, j;\n        while (i--) {\n            j = n;\n            while (--j > i) {\n                var d = D[i][j];\n                if (d > 0 && d < this.minD) {\n                    this.minD = d;\n                }\n            }\n        }\n        if (this.minD === Number.MAX_VALUE)\n            this.minD = 1;\n        i = this.k;\n        while (i--) {\n            this.g[i] = new Array(n);\n            this.H[i] = new Array(n);\n            j = n;\n            while (j--) {\n                this.H[i][j] = new Array(n);\n            }\n            this.Hd[i] = new Array(n);\n            this.a[i] = new Array(n);\n            this.b[i] = new Array(n);\n            this.c[i] = new Array(n);\n            this.d[i] = new Array(n);\n            this.e[i] = new Array(n);\n            this.ia[i] = new Array(n);\n            this.ib[i] = new Array(n);\n            this.xtmp[i] = new Array(n);\n        }\n    }\n    Descent.createSquareMatrix = function (n, f) {\n        var M = new Array(n);\n        for (var i = 0; i < n; ++i) {\n            M[i] = new Array(n);\n            for (var j = 0; j < n; ++j) {\n                M[i][j] = f(i, j);\n            }\n        }\n        return M;\n    };\n    Descent.prototype.offsetDir = function () {\n        var _this = this;\n        var u = new Array(this.k);\n        var l = 0;\n        for (var i = 0; i < this.k; ++i) {\n            var x = u[i] = this.random.getNextBetween(0.01, 1) - 0.5;\n            l += x * x;\n        }\n        l = Math.sqrt(l);\n        return u.map(function (x) { return x *= _this.minD / l; });\n    };\n    Descent.prototype.computeDerivatives = function (x) {\n        var _this = this;\n        var n = this.n;\n        if (n < 1)\n            return;\n        var i;\n        var d = new Array(this.k);\n        var d2 = new Array(this.k);\n        var Huu = new Array(this.k);\n        var maxH = 0;\n        for (var u_1 = 0; u_1 < n; ++u_1) {\n            for (i = 0; i < this.k; ++i)\n                Huu[i] = this.g[i][u_1] = 0;\n            for (var v = 0; v < n; ++v) {\n                if (u_1 === v)\n                    continue;\n                var maxDisplaces = n;\n                var distanceSquared = 0;\n                while (maxDisplaces--) {\n                    distanceSquared = 0;\n                    for (i = 0; i < this.k; ++i) {\n                        var dx_1 = d[i] = x[i][u_1] - x[i][v];\n                        distanceSquared += d2[i] = dx_1 * dx_1;\n                    }\n                    if (distanceSquared > 1e-9)\n                        break;\n                    var rd = this.offsetDir();\n                    for (i = 0; i < this.k; ++i)\n                        x[i][v] += rd[i];\n                }\n                var distance = Math.sqrt(distanceSquared);\n                var idealDistance = this.D[u_1][v];\n                var weight = this.G != null ? this.G[u_1][v] : 1;\n                if (weight > 1 && distance > idealDistance || !isFinite(idealDistance)) {\n                    for (i = 0; i < this.k; ++i)\n                        this.H[i][u_1][v] = 0;\n                    continue;\n                }\n                if (weight > 1) {\n                    weight = 1;\n                }\n                var idealDistSquared = idealDistance * idealDistance, gs = 2 * weight * (distance - idealDistance) / (idealDistSquared * distance), distanceCubed = distanceSquared * distance, hs = 2 * -weight / (idealDistSquared * distanceCubed);\n                if (!isFinite(gs))\n                    console.log(gs);\n                for (i = 0; i < this.k; ++i) {\n                    this.g[i][u_1] += d[i] * gs;\n                    Huu[i] -= this.H[i][u_1][v] = hs * (2 * distanceCubed + idealDistance * (d2[i] - distanceSquared));\n                }\n            }\n            for (i = 0; i < this.k; ++i)\n                maxH = Math.max(maxH, this.H[i][u_1][u_1] = Huu[i]);\n        }\n        var r = this.snapGridSize / 2;\n        var g = this.snapGridSize;\n        var w = this.snapStrength;\n        var k = w / (r * r);\n        var numNodes = this.numGridSnapNodes;\n        for (var u = 0; u < numNodes; ++u) {\n            for (i = 0; i < this.k; ++i) {\n                var xiu = this.x[i][u];\n                var m = xiu / g;\n                var f = m % 1;\n                var q = m - f;\n                var a = Math.abs(f);\n                var dx = (a <= 0.5) ? xiu - q * g :\n                    (xiu > 0) ? xiu - (q + 1) * g : xiu - (q - 1) * g;\n                if (-r < dx && dx <= r) {\n                    if (this.scaleSnapByMaxH) {\n                        this.g[i][u] += maxH * k * dx;\n                        this.H[i][u][u] += maxH * k;\n                    }\n                    else {\n                        this.g[i][u] += k * dx;\n                        this.H[i][u][u] += k;\n                    }\n                }\n            }\n        }\n        if (!this.locks.isEmpty()) {\n            this.locks.apply(function (u, p) {\n                for (i = 0; i < _this.k; ++i) {\n                    _this.H[i][u][u] += maxH;\n                    _this.g[i][u] -= maxH * (p[i] - x[i][u]);\n                }\n            });\n        }\n    };\n    Descent.dotProd = function (a, b) {\n        var x = 0, i = a.length;\n        while (i--)\n            x += a[i] * b[i];\n        return x;\n    };\n    Descent.rightMultiply = function (m, v, r) {\n        var i = m.length;\n        while (i--)\n            r[i] = Descent.dotProd(m[i], v);\n    };\n    Descent.prototype.computeStepSize = function (d) {\n        var numerator = 0, denominator = 0;\n        for (var i = 0; i < this.k; ++i) {\n            numerator += Descent.dotProd(this.g[i], d[i]);\n            Descent.rightMultiply(this.H[i], d[i], this.Hd[i]);\n            denominator += Descent.dotProd(d[i], this.Hd[i]);\n        }\n        if (denominator === 0 || !isFinite(denominator))\n            return 0;\n        return 1 * numerator / denominator;\n    };\n    Descent.prototype.reduceStress = function () {\n        this.computeDerivatives(this.x);\n        var alpha = this.computeStepSize(this.g);\n        for (var i = 0; i < this.k; ++i) {\n            this.takeDescentStep(this.x[i], this.g[i], alpha);\n        }\n        return this.computeStress();\n    };\n    Descent.copy = function (a, b) {\n        var m = a.length, n = b[0].length;\n        for (var i = 0; i < m; ++i) {\n            for (var j = 0; j < n; ++j) {\n                b[i][j] = a[i][j];\n            }\n        }\n    };\n    Descent.prototype.stepAndProject = function (x0, r, d, stepSize) {\n        Descent.copy(x0, r);\n        this.takeDescentStep(r[0], d[0], stepSize);\n        if (this.project)\n            this.project[0](x0[0], x0[1], r[0]);\n        this.takeDescentStep(r[1], d[1], stepSize);\n        if (this.project)\n            this.project[1](r[0], x0[1], r[1]);\n        for (var i = 2; i < this.k; i++)\n            this.takeDescentStep(r[i], d[i], stepSize);\n    };\n    Descent.mApply = function (m, n, f) {\n        var i = m;\n        while (i-- > 0) {\n            var j = n;\n            while (j-- > 0)\n                f(i, j);\n        }\n    };\n    Descent.prototype.matrixApply = function (f) {\n        Descent.mApply(this.k, this.n, f);\n    };\n    Descent.prototype.computeNextPosition = function (x0, r) {\n        var _this = this;\n        this.computeDerivatives(x0);\n        var alpha = this.computeStepSize(this.g);\n        this.stepAndProject(x0, r, this.g, alpha);\n        if (this.project) {\n            this.matrixApply(function (i, j) { return _this.e[i][j] = x0[i][j] - r[i][j]; });\n            var beta = this.computeStepSize(this.e);\n            beta = Math.max(0.2, Math.min(beta, 1));\n            this.stepAndProject(x0, r, this.e, beta);\n        }\n    };\n    Descent.prototype.run = function (iterations) {\n        var stress = Number.MAX_VALUE, converged = false;\n        while (!converged && iterations-- > 0) {\n            var s = this.rungeKutta();\n            converged = Math.abs(stress / s - 1) < this.threshold;\n            stress = s;\n        }\n        return stress;\n    };\n    Descent.prototype.rungeKutta = function () {\n        var _this = this;\n        this.computeNextPosition(this.x, this.a);\n        Descent.mid(this.x, this.a, this.ia);\n        this.computeNextPosition(this.ia, this.b);\n        Descent.mid(this.x, this.b, this.ib);\n        this.computeNextPosition(this.ib, this.c);\n        this.computeNextPosition(this.c, this.d);\n        var disp = 0;\n        this.matrixApply(function (i, j) {\n            var x = (_this.a[i][j] + 2.0 * _this.b[i][j] + 2.0 * _this.c[i][j] + _this.d[i][j]) / 6.0, d = _this.x[i][j] - x;\n            disp += d * d;\n            _this.x[i][j] = x;\n        });\n        return disp;\n    };\n    Descent.mid = function (a, b, m) {\n        Descent.mApply(a.length, a[0].length, function (i, j) {\n            return m[i][j] = a[i][j] + (b[i][j] - a[i][j]) / 2.0;\n        });\n    };\n    Descent.prototype.takeDescentStep = function (x, d, stepSize) {\n        for (var i = 0; i < this.n; ++i) {\n            x[i] = x[i] - stepSize * d[i];\n        }\n    };\n    Descent.prototype.computeStress = function () {\n        var stress = 0;\n        for (var u = 0, nMinus1 = this.n - 1; u < nMinus1; ++u) {\n            for (var v = u + 1, n = this.n; v < n; ++v) {\n                var l = 0;\n                for (var i = 0; i < this.k; ++i) {\n                    var dx = this.x[i][u] - this.x[i][v];\n                    l += dx * dx;\n                }\n                l = Math.sqrt(l);\n                var d = this.D[u][v];\n                if (!isFinite(d))\n                    continue;\n                var rl = d - l;\n                var d2 = d * d;\n                stress += rl * rl / d2;\n            }\n        }\n        return stress;\n    };\n    Descent.zeroDistance = 1e-10;\n    return Descent;\n}());\nexports.Descent = Descent;\nvar PseudoRandom = (function () {\n    function PseudoRandom(seed) {\n        if (seed === void 0) { seed = 1; }\n        this.seed = seed;\n        this.a = 214013;\n        this.c = 2531011;\n        this.m = 2147483648;\n        this.range = 32767;\n    }\n    PseudoRandom.prototype.getNext = function () {\n        this.seed = (this.seed * this.a + this.c) % this.m;\n        return (this.seed >> 16) / this.range;\n    };\n    PseudoRandom.prototype.getNextBetween = function (min, max) {\n        return min + this.getNext() * (max - min);\n    };\n    return PseudoRandom;\n}());\nexports.PseudoRandom = PseudoRandom;\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"descent.js","sourceRoot":"","sources":["../../WebCola/src/descent.ts"],"names":[],"mappings":"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"}","\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n    var extendStatics = function (d, b) {\n        extendStatics = Object.setPrototypeOf ||\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n            function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n        return extendStatics(d, b);\n    };\n    return function (d, b) {\n        extendStatics(d, b);\n        function __() { this.constructor = d; }\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n    };\n})();\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar rectangle_1 = require(\"./rectangle\");\nvar Point = (function () {\n    function Point() {\n    }\n    return Point;\n}());\nexports.Point = Point;\nvar LineSegment = (function () {\n    function LineSegment(x1, y1, x2, y2) {\n        this.x1 = x1;\n        this.y1 = y1;\n        this.x2 = x2;\n        this.y2 = y2;\n    }\n    return LineSegment;\n}());\nexports.LineSegment = LineSegment;\nvar PolyPoint = (function (_super) {\n    __extends(PolyPoint, _super);\n    function PolyPoint() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    return PolyPoint;\n}(Point));\nexports.PolyPoint = PolyPoint;\nfunction isLeft(P0, P1, P2) {\n    return (P1.x - P0.x) * (P2.y - P0.y) - (P2.x - P0.x) * (P1.y - P0.y);\n}\nexports.isLeft = isLeft;\nfunction above(p, vi, vj) {\n    return isLeft(p, vi, vj) > 0;\n}\nfunction below(p, vi, vj) {\n    return isLeft(p, vi, vj) < 0;\n}\nfunction ConvexHull(S) {\n    var P = S.slice(0).sort(function (a, b) { return a.x !== b.x ? b.x - a.x : b.y - a.y; });\n    var n = S.length, i;\n    var minmin = 0;\n    var xmin = P[0].x;\n    for (i = 1; i < n; ++i) {\n        if (P[i].x !== xmin)\n            break;\n    }\n    var minmax = i - 1;\n    var H = [];\n    H.push(P[minmin]);\n    if (minmax === n - 1) {\n        if (P[minmax].y !== P[minmin].y)\n            H.push(P[minmax]);\n    }\n    else {\n        var maxmin, maxmax = n - 1;\n        var xmax = P[n - 1].x;\n        for (i = n - 2; i >= 0; i--)\n            if (P[i].x !== xmax)\n                break;\n        maxmin = i + 1;\n        i = minmax;\n        while (++i <= maxmin) {\n            if (isLeft(P[minmin], P[maxmin], P[i]) >= 0 && i < maxmin)\n                continue;\n            while (H.length > 1) {\n                if (isLeft(H[H.length - 2], H[H.length - 1], P[i]) > 0)\n                    break;\n                else\n                    H.length -= 1;\n            }\n            if (i != minmin)\n                H.push(P[i]);\n        }\n        if (maxmax != maxmin)\n            H.push(P[maxmax]);\n        var bot = H.length;\n        i = maxmin;\n        while (--i >= minmax) {\n            if (isLeft(P[maxmax], P[minmax], P[i]) >= 0 && i > minmax)\n                continue;\n            while (H.length > bot) {\n                if (isLeft(H[H.length - 2], H[H.length - 1], P[i]) > 0)\n                    break;\n                else\n                    H.length -= 1;\n            }\n            if (i != minmin)\n                H.push(P[i]);\n        }\n    }\n    return H;\n}\nexports.ConvexHull = ConvexHull;\nfunction clockwiseRadialSweep(p, P, f) {\n    P.slice(0).sort(function (a, b) { return Math.atan2(a.y - p.y, a.x - p.x) - Math.atan2(b.y - p.y, b.x - p.x); }).forEach(f);\n}\nexports.clockwiseRadialSweep = clockwiseRadialSweep;\nfunction nextPolyPoint(p, ps) {\n    if (p.polyIndex === ps.length - 1)\n        return ps[0];\n    return ps[p.polyIndex + 1];\n}\nfunction prevPolyPoint(p, ps) {\n    if (p.polyIndex === 0)\n        return ps[ps.length - 1];\n    return ps[p.polyIndex - 1];\n}\nfunction tangent_PointPolyC(P, V) {\n    var Vclosed = V.slice(0);\n    Vclosed.push(V[0]);\n    return { rtan: Rtangent_PointPolyC(P, Vclosed), ltan: Ltangent_PointPolyC(P, Vclosed) };\n}\nfunction Rtangent_PointPolyC(P, V) {\n    var n = V.length - 1;\n    var a, b, c;\n    var upA, dnC;\n    if (below(P, V[1], V[0]) && !above(P, V[n - 1], V[0]))\n        return 0;\n    for (a = 0, b = n;;) {\n        if (b - a === 1)\n            if (above(P, V[a], V[b]))\n                return a;\n            else\n                return b;\n        c = Math.floor((a + b) / 2);\n        dnC = below(P, V[c + 1], V[c]);\n        if (dnC && !above(P, V[c - 1], V[c]))\n            return c;\n        upA = above(P, V[a + 1], V[a]);\n        if (upA) {\n            if (dnC)\n                b = c;\n            else {\n                if (above(P, V[a], V[c]))\n                    b = c;\n                else\n                    a = c;\n            }\n        }\n        else {\n            if (!dnC)\n                a = c;\n            else {\n                if (below(P, V[a], V[c]))\n                    b = c;\n                else\n                    a = c;\n            }\n        }\n    }\n}\nfunction Ltangent_PointPolyC(P, V) {\n    var n = V.length - 1;\n    var a, b, c;\n    var dnA, dnC;\n    if (above(P, V[n - 1], V[0]) && !below(P, V[1], V[0]))\n        return 0;\n    for (a = 0, b = n;;) {\n        if (b - a === 1)\n            if (below(P, V[a], V[b]))\n                return a;\n            else\n                return b;\n        c = Math.floor((a + b) / 2);\n        dnC = below(P, V[c + 1], V[c]);\n        if (above(P, V[c - 1], V[c]) && !dnC)\n            return c;\n        dnA = below(P, V[a + 1], V[a]);\n        if (dnA) {\n            if (!dnC)\n                b = c;\n            else {\n                if (below(P, V[a], V[c]))\n                    b = c;\n                else\n                    a = c;\n            }\n        }\n        else {\n            if (dnC)\n                a = c;\n            else {\n                if (above(P, V[a], V[c]))\n                    b = c;\n                else\n                    a = c;\n            }\n        }\n    }\n}\nfunction tangent_PolyPolyC(V, W, t1, t2, cmp1, cmp2) {\n    var ix1, ix2;\n    ix1 = t1(W[0], V);\n    ix2 = t2(V[ix1], W);\n    var done = false;\n    while (!done) {\n        done = true;\n        while (true) {\n            if (ix1 === V.length - 1)\n                ix1 = 0;\n            if (cmp1(W[ix2], V[ix1], V[ix1 + 1]))\n                break;\n            ++ix1;\n        }\n        while (true) {\n            if (ix2 === 0)\n                ix2 = W.length - 1;\n            if (cmp2(V[ix1], W[ix2], W[ix2 - 1]))\n                break;\n            --ix2;\n            done = false;\n        }\n    }\n    return { t1: ix1, t2: ix2 };\n}\nexports.tangent_PolyPolyC = tangent_PolyPolyC;\nfunction LRtangent_PolyPolyC(V, W) {\n    var rl = RLtangent_PolyPolyC(W, V);\n    return { t1: rl.t2, t2: rl.t1 };\n}\nexports.LRtangent_PolyPolyC = LRtangent_PolyPolyC;\nfunction RLtangent_PolyPolyC(V, W) {\n    return tangent_PolyPolyC(V, W, Rtangent_PointPolyC, Ltangent_PointPolyC, above, below);\n}\nexports.RLtangent_PolyPolyC = RLtangent_PolyPolyC;\nfunction LLtangent_PolyPolyC(V, W) {\n    return tangent_PolyPolyC(V, W, Ltangent_PointPolyC, Ltangent_PointPolyC, below, below);\n}\nexports.LLtangent_PolyPolyC = LLtangent_PolyPolyC;\nfunction RRtangent_PolyPolyC(V, W) {\n    return tangent_PolyPolyC(V, W, Rtangent_PointPolyC, Rtangent_PointPolyC, above, above);\n}\nexports.RRtangent_PolyPolyC = RRtangent_PolyPolyC;\nvar BiTangent = (function () {\n    function BiTangent(t1, t2) {\n        this.t1 = t1;\n        this.t2 = t2;\n    }\n    return BiTangent;\n}());\nexports.BiTangent = BiTangent;\nvar BiTangents = (function () {\n    function BiTangents() {\n    }\n    return BiTangents;\n}());\nexports.BiTangents = BiTangents;\nvar TVGPoint = (function (_super) {\n    __extends(TVGPoint, _super);\n    function TVGPoint() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    return TVGPoint;\n}(Point));\nexports.TVGPoint = TVGPoint;\nvar VisibilityVertex = (function () {\n    function VisibilityVertex(id, polyid, polyvertid, p) {\n        this.id = id;\n        this.polyid = polyid;\n        this.polyvertid = polyvertid;\n        this.p = p;\n        p.vv = this;\n    }\n    return VisibilityVertex;\n}());\nexports.VisibilityVertex = VisibilityVertex;\nvar VisibilityEdge = (function () {\n    function VisibilityEdge(source, target) {\n        this.source = source;\n        this.target = target;\n    }\n    VisibilityEdge.prototype.length = function () {\n        var dx = this.source.p.x - this.target.p.x;\n        var dy = this.source.p.y - this.target.p.y;\n        return Math.sqrt(dx * dx + dy * dy);\n    };\n    return VisibilityEdge;\n}());\nexports.VisibilityEdge = VisibilityEdge;\nvar TangentVisibilityGraph = (function () {\n    function TangentVisibilityGraph(P, g0) {\n        this.P = P;\n        this.V = [];\n        this.E = [];\n        if (!g0) {\n            var n = P.length;\n            for (var i = 0; i < n; i++) {\n                var p = P[i];\n                for (var j = 0; j < p.length; ++j) {\n                    var pj = p[j], vv = new VisibilityVertex(this.V.length, i, j, pj);\n                    this.V.push(vv);\n                    if (j > 0)\n                        this.E.push(new VisibilityEdge(p[j - 1].vv, vv));\n                }\n                if (p.length > 1)\n                    this.E.push(new VisibilityEdge(p[0].vv, p[p.length - 1].vv));\n            }\n            for (var i = 0; i < n - 1; i++) {\n                var Pi = P[i];\n                for (var j = i + 1; j < n; j++) {\n                    var Pj = P[j], t = tangents(Pi, Pj);\n                    for (var q in t) {\n                        var c = t[q], source = Pi[c.t1], target = Pj[c.t2];\n                        this.addEdgeIfVisible(source, target, i, j);\n                    }\n                }\n            }\n        }\n        else {\n            this.V = g0.V.slice(0);\n            this.E = g0.E.slice(0);\n        }\n    }\n    TangentVisibilityGraph.prototype.addEdgeIfVisible = function (u, v, i1, i2) {\n        if (!this.intersectsPolys(new LineSegment(u.x, u.y, v.x, v.y), i1, i2)) {\n            this.E.push(new VisibilityEdge(u.vv, v.vv));\n        }\n    };\n    TangentVisibilityGraph.prototype.addPoint = function (p, i1) {\n        var n = this.P.length;\n        this.V.push(new VisibilityVertex(this.V.length, n, 0, p));\n        for (var i = 0; i < n; ++i) {\n            if (i === i1)\n                continue;\n            var poly = this.P[i], t = tangent_PointPolyC(p, poly);\n            this.addEdgeIfVisible(p, poly[t.ltan], i1, i);\n            this.addEdgeIfVisible(p, poly[t.rtan], i1, i);\n        }\n        return p.vv;\n    };\n    TangentVisibilityGraph.prototype.intersectsPolys = function (l, i1, i2) {\n        for (var i = 0, n = this.P.length; i < n; ++i) {\n            if (i != i1 && i != i2 && intersects(l, this.P[i]).length > 0) {\n                return true;\n            }\n        }\n        return false;\n    };\n    return TangentVisibilityGraph;\n}());\nexports.TangentVisibilityGraph = TangentVisibilityGraph;\nfunction intersects(l, P) {\n    var ints = [];\n    for (var i = 1, n = P.length; i < n; ++i) {\n        var int = rectangle_1.Rectangle.lineIntersection(l.x1, l.y1, l.x2, l.y2, P[i - 1].x, P[i - 1].y, P[i].x, P[i].y);\n        if (int)\n            ints.push(int);\n    }\n    return ints;\n}\nfunction tangents(V, W) {\n    var m = V.length - 1, n = W.length - 1;\n    var bt = new BiTangents();\n    for (var i = 0; i <= m; ++i) {\n        for (var j = 0; j <= n; ++j) {\n            var v1 = V[i == 0 ? m : i - 1];\n            var v2 = V[i];\n            var v3 = V[i == m ? 0 : i + 1];\n            var w1 = W[j == 0 ? n : j - 1];\n            var w2 = W[j];\n            var w3 = W[j == n ? 0 : j + 1];\n            var v1v2w2 = isLeft(v1, v2, w2);\n            var v2w1w2 = isLeft(v2, w1, w2);\n            var v2w2w3 = isLeft(v2, w2, w3);\n            var w1w2v2 = isLeft(w1, w2, v2);\n            var w2v1v2 = isLeft(w2, v1, v2);\n            var w2v2v3 = isLeft(w2, v2, v3);\n            if (v1v2w2 >= 0 && v2w1w2 >= 0 && v2w2w3 < 0\n                && w1w2v2 >= 0 && w2v1v2 >= 0 && w2v2v3 < 0) {\n                bt.ll = new BiTangent(i, j);\n            }\n            else if (v1v2w2 <= 0 && v2w1w2 <= 0 && v2w2w3 > 0\n                && w1w2v2 <= 0 && w2v1v2 <= 0 && w2v2v3 > 0) {\n                bt.rr = new BiTangent(i, j);\n            }\n            else if (v1v2w2 <= 0 && v2w1w2 > 0 && v2w2w3 <= 0\n                && w1w2v2 >= 0 && w2v1v2 < 0 && w2v2v3 >= 0) {\n                bt.rl = new BiTangent(i, j);\n            }\n            else if (v1v2w2 >= 0 && v2w1w2 < 0 && v2w2w3 >= 0\n                && w1w2v2 <= 0 && w2v1v2 > 0 && w2v2v3 <= 0) {\n                bt.lr = new BiTangent(i, j);\n            }\n        }\n    }\n    return bt;\n}\nexports.tangents = tangents;\nfunction isPointInsidePoly(p, poly) {\n    for (var i = 1, n = poly.length; i < n; ++i)\n        if (below(poly[i - 1], poly[i], p))\n            return false;\n    return true;\n}\nfunction isAnyPInQ(p, q) {\n    return !p.every(function (v) { return !isPointInsidePoly(v, q); });\n}\nfunction polysOverlap(p, q) {\n    if (isAnyPInQ(p, q))\n        return true;\n    if (isAnyPInQ(q, p))\n        return true;\n    for (var i = 1, n = p.length; i < n; ++i) {\n        var v = p[i], u = p[i - 1];\n        if (intersects(new LineSegment(u.x, u.y, v.x, v.y), q).length > 0)\n            return true;\n    }\n    return false;\n}\nexports.polysOverlap = polysOverlap;\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"geom.js","sourceRoot":"","sources":["../../WebCola/src/geom.ts"],"names":[],"mappings":"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"}","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar rectangle_1 = require(\"./rectangle\");\nvar vpsc_1 = require(\"./vpsc\");\nvar shortestpaths_1 = require(\"./shortestpaths\");\nvar NodeWrapper = (function () {\n    function NodeWrapper(id, rect, children) {\n        this.id = id;\n        this.rect = rect;\n        this.children = children;\n        this.leaf = typeof children === 'undefined' || children.length === 0;\n    }\n    return NodeWrapper;\n}());\nexports.NodeWrapper = NodeWrapper;\nvar Vert = (function () {\n    function Vert(id, x, y, node, line) {\n        if (node === void 0) { node = null; }\n        if (line === void 0) { line = null; }\n        this.id = id;\n        this.x = x;\n        this.y = y;\n        this.node = node;\n        this.line = line;\n    }\n    return Vert;\n}());\nexports.Vert = Vert;\nvar LongestCommonSubsequence = (function () {\n    function LongestCommonSubsequence(s, t) {\n        this.s = s;\n        this.t = t;\n        var mf = LongestCommonSubsequence.findMatch(s, t);\n        var tr = t.slice(0).reverse();\n        var mr = LongestCommonSubsequence.findMatch(s, tr);\n        if (mf.length >= mr.length) {\n            this.length = mf.length;\n            this.si = mf.si;\n            this.ti = mf.ti;\n            this.reversed = false;\n        }\n        else {\n            this.length = mr.length;\n            this.si = mr.si;\n            this.ti = t.length - mr.ti - mr.length;\n            this.reversed = true;\n        }\n    }\n    LongestCommonSubsequence.findMatch = function (s, t) {\n        var m = s.length;\n        var n = t.length;\n        var match = { length: 0, si: -1, ti: -1 };\n        var l = new Array(m);\n        for (var i = 0; i < m; i++) {\n            l[i] = new Array(n);\n            for (var j = 0; j < n; j++)\n                if (s[i] === t[j]) {\n                    var v = l[i][j] = (i === 0 || j === 0) ? 1 : l[i - 1][j - 1] + 1;\n                    if (v > match.length) {\n                        match.length = v;\n                        match.si = i - v + 1;\n                        match.ti = j - v + 1;\n                    }\n                    ;\n                }\n                else\n                    l[i][j] = 0;\n        }\n        return match;\n    };\n    LongestCommonSubsequence.prototype.getSequence = function () {\n        return this.length >= 0 ? this.s.slice(this.si, this.si + this.length) : [];\n    };\n    return LongestCommonSubsequence;\n}());\nexports.LongestCommonSubsequence = LongestCommonSubsequence;\nvar GridRouter = (function () {\n    function GridRouter(originalnodes, accessor, groupPadding) {\n        var _this = this;\n        if (groupPadding === void 0) { groupPadding = 12; }\n        this.originalnodes = originalnodes;\n        this.groupPadding = groupPadding;\n        this.leaves = null;\n        this.nodes = originalnodes.map(function (v, i) { return new NodeWrapper(i, accessor.getBounds(v), accessor.getChildren(v)); });\n        this.leaves = this.nodes.filter(function (v) { return v.leaf; });\n        this.groups = this.nodes.filter(function (g) { return !g.leaf; });\n        this.cols = this.getGridLines('x');\n        this.rows = this.getGridLines('y');\n        this.groups.forEach(function (v) {\n            return v.children.forEach(function (c) { return _this.nodes[c].parent = v; });\n        });\n        this.root = { children: [] };\n        this.nodes.forEach(function (v) {\n            if (typeof v.parent === 'undefined') {\n                v.parent = _this.root;\n                _this.root.children.push(v.id);\n            }\n            v.ports = [];\n        });\n        this.backToFront = this.nodes.slice(0);\n        this.backToFront.sort(function (x, y) { return _this.getDepth(x) - _this.getDepth(y); });\n        var frontToBackGroups = this.backToFront.slice(0).reverse().filter(function (g) { return !g.leaf; });\n        frontToBackGroups.forEach(function (v) {\n            var r = rectangle_1.Rectangle.empty();\n            v.children.forEach(function (c) { return r = r.union(_this.nodes[c].rect); });\n            v.rect = r.inflate(_this.groupPadding);\n        });\n        var colMids = this.midPoints(this.cols.map(function (r) { return r.pos; }));\n        var rowMids = this.midPoints(this.rows.map(function (r) { return r.pos; }));\n        var rowx = colMids[0], rowX = colMids[colMids.length - 1];\n        var coly = rowMids[0], colY = rowMids[rowMids.length - 1];\n        var hlines = this.rows.map(function (r) { return ({ x1: rowx, x2: rowX, y1: r.pos, y2: r.pos }); })\n            .concat(rowMids.map(function (m) { return ({ x1: rowx, x2: rowX, y1: m, y2: m }); }));\n        var vlines = this.cols.map(function (c) { return ({ x1: c.pos, x2: c.pos, y1: coly, y2: colY }); })\n            .concat(colMids.map(function (m) { return ({ x1: m, x2: m, y1: coly, y2: colY }); }));\n        var lines = hlines.concat(vlines);\n        lines.forEach(function (l) { return l.verts = []; });\n        this.verts = [];\n        this.edges = [];\n        hlines.forEach(function (h) {\n            return vlines.forEach(function (v) {\n                var p = new Vert(_this.verts.length, v.x1, h.y1);\n                h.verts.push(p);\n                v.verts.push(p);\n                _this.verts.push(p);\n                var i = _this.backToFront.length;\n                while (i-- > 0) {\n                    var node = _this.backToFront[i], r = node.rect;\n                    var dx = Math.abs(p.x - r.cx()), dy = Math.abs(p.y - r.cy());\n                    if (dx < r.width() / 2 && dy < r.height() / 2) {\n                        p.node = node;\n                        break;\n                    }\n                }\n            });\n        });\n        lines.forEach(function (l, li) {\n            _this.nodes.forEach(function (v, i) {\n                v.rect.lineIntersections(l.x1, l.y1, l.x2, l.y2).forEach(function (intersect, j) {\n                    var p = new Vert(_this.verts.length, intersect.x, intersect.y, v, l);\n                    _this.verts.push(p);\n                    l.verts.push(p);\n                    v.ports.push(p);\n                });\n            });\n            var isHoriz = Math.abs(l.y1 - l.y2) < 0.1;\n            var delta = function (a, b) { return isHoriz ? b.x - a.x : b.y - a.y; };\n            l.verts.sort(delta);\n            for (var i = 1; i < l.verts.length; i++) {\n                var u = l.verts[i - 1], v = l.verts[i];\n                if (u.node && u.node === v.node && u.node.leaf)\n                    continue;\n                _this.edges.push({ source: u.id, target: v.id, length: Math.abs(delta(u, v)) });\n            }\n        });\n    }\n    GridRouter.prototype.avg = function (a) { return a.reduce(function (x, y) { return x + y; }) / a.length; };\n    GridRouter.prototype.getGridLines = function (axis) {\n        var columns = [];\n        var ls = this.leaves.slice(0, this.leaves.length);\n        while (ls.length > 0) {\n            var overlapping = ls.filter(function (v) { return v.rect['overlap' + axis.toUpperCase()](ls[0].rect); });\n            var col = {\n                nodes: overlapping,\n                pos: this.avg(overlapping.map(function (v) { return v.rect['c' + axis](); }))\n            };\n            columns.push(col);\n            col.nodes.forEach(function (v) { return ls.splice(ls.indexOf(v), 1); });\n        }\n        columns.sort(function (a, b) { return a.pos - b.pos; });\n        return columns;\n    };\n    GridRouter.prototype.getDepth = function (v) {\n        var depth = 0;\n        while (v.parent !== this.root) {\n            depth++;\n            v = v.parent;\n        }\n        return depth;\n    };\n    GridRouter.prototype.midPoints = function (a) {\n        var gap = a[1] - a[0];\n        var mids = [a[0] - gap / 2];\n        for (var i = 1; i < a.length; i++) {\n            mids.push((a[i] + a[i - 1]) / 2);\n        }\n        mids.push(a[a.length - 1] + gap / 2);\n        return mids;\n    };\n    GridRouter.prototype.findLineage = function (v) {\n        var lineage = [v];\n        do {\n            v = v.parent;\n            lineage.push(v);\n        } while (v !== this.root);\n        return lineage.reverse();\n    };\n    GridRouter.prototype.findAncestorPathBetween = function (a, b) {\n        var aa = this.findLineage(a), ba = this.findLineage(b), i = 0;\n        while (aa[i] === ba[i])\n            i++;\n        return { commonAncestor: aa[i - 1], lineages: aa.slice(i).concat(ba.slice(i)) };\n    };\n    GridRouter.prototype.siblingObstacles = function (a, b) {\n        var _this = this;\n        var path = this.findAncestorPathBetween(a, b);\n        var lineageLookup = {};\n        path.lineages.forEach(function (v) { return lineageLookup[v.id] = {}; });\n        var obstacles = path.commonAncestor.children.filter(function (v) { return !(v in lineageLookup); });\n        path.lineages\n            .filter(function (v) { return v.parent !== path.commonAncestor; })\n            .forEach(function (v) { return obstacles = obstacles.concat(v.parent.children.filter(function (c) { return c !== v.id; })); });\n        return obstacles.map(function (v) { return _this.nodes[v]; });\n    };\n    GridRouter.getSegmentSets = function (routes, x, y) {\n        var vsegments = [];\n        for (var ei = 0; ei < routes.length; ei++) {\n            var route = routes[ei];\n            for (var si = 0; si < route.length; si++) {\n                var s = route[si];\n                s.edgeid = ei;\n                s.i = si;\n                var sdx = s[1][x] - s[0][x];\n                if (Math.abs(sdx) < 0.1) {\n                    vsegments.push(s);\n                }\n            }\n        }\n        vsegments.sort(function (a, b) { return a[0][x] - b[0][x]; });\n        var vsegmentsets = [];\n        var segmentset = null;\n        for (var i = 0; i < vsegments.length; i++) {\n            var s = vsegments[i];\n            if (!segmentset || Math.abs(s[0][x] - segmentset.pos) > 0.1) {\n                segmentset = { pos: s[0][x], segments: [] };\n                vsegmentsets.push(segmentset);\n            }\n            segmentset.segments.push(s);\n        }\n        return vsegmentsets;\n    };\n    GridRouter.nudgeSegs = function (x, y, routes, segments, leftOf, gap) {\n        var n = segments.length;\n        if (n <= 1)\n            return;\n        var vs = segments.map(function (s) { return new vpsc_1.Variable(s[0][x]); });\n        var cs = [];\n        for (var i = 0; i < n; i++) {\n            for (var j = 0; j < n; j++) {\n                if (i === j)\n                    continue;\n                var s1 = segments[i], s2 = segments[j], e1 = s1.edgeid, e2 = s2.edgeid, lind = -1, rind = -1;\n                if (x == 'x') {\n                    if (leftOf(e1, e2)) {\n                        if (s1[0][y] < s1[1][y]) {\n                            lind = j, rind = i;\n                        }\n                        else {\n                            lind = i, rind = j;\n                        }\n                    }\n                }\n                else {\n                    if (leftOf(e1, e2)) {\n                        if (s1[0][y] < s1[1][y]) {\n                            lind = i, rind = j;\n                        }\n                        else {\n                            lind = j, rind = i;\n                        }\n                    }\n                }\n                if (lind >= 0) {\n                    cs.push(new vpsc_1.Constraint(vs[lind], vs[rind], gap));\n                }\n            }\n        }\n        var solver = new vpsc_1.Solver(vs, cs);\n        solver.solve();\n        vs.forEach(function (v, i) {\n            var s = segments[i];\n            var pos = v.position();\n            s[0][x] = s[1][x] = pos;\n            var route = routes[s.edgeid];\n            if (s.i > 0)\n                route[s.i - 1][1][x] = pos;\n            if (s.i < route.length - 1)\n                route[s.i + 1][0][x] = pos;\n        });\n    };\n    GridRouter.nudgeSegments = function (routes, x, y, leftOf, gap) {\n        var vsegmentsets = GridRouter.getSegmentSets(routes, x, y);\n        for (var i = 0; i < vsegmentsets.length; i++) {\n            var ss = vsegmentsets[i];\n            var events = [];\n            for (var j = 0; j < ss.segments.length; j++) {\n                var s = ss.segments[j];\n                events.push({ type: 0, s: s, pos: Math.min(s[0][y], s[1][y]) });\n                events.push({ type: 1, s: s, pos: Math.max(s[0][y], s[1][y]) });\n            }\n            events.sort(function (a, b) { return a.pos - b.pos + a.type - b.type; });\n            var open = [];\n            var openCount = 0;\n            events.forEach(function (e) {\n                if (e.type === 0) {\n                    open.push(e.s);\n                    openCount++;\n                }\n                else {\n                    openCount--;\n                }\n                if (openCount == 0) {\n                    GridRouter.nudgeSegs(x, y, routes, open, leftOf, gap);\n                    open = [];\n                }\n            });\n        }\n    };\n    GridRouter.prototype.routeEdges = function (edges, nudgeGap, source, target) {\n        var _this = this;\n        var routePaths = edges.map(function (e) { return _this.route(source(e), target(e)); });\n        var order = GridRouter.orderEdges(routePaths);\n        var routes = routePaths.map(function (e) { return GridRouter.makeSegments(e); });\n        GridRouter.nudgeSegments(routes, 'x', 'y', order, nudgeGap);\n        GridRouter.nudgeSegments(routes, 'y', 'x', order, nudgeGap);\n        GridRouter.unreverseEdges(routes, routePaths);\n        return routes;\n    };\n    GridRouter.unreverseEdges = function (routes, routePaths) {\n        routes.forEach(function (segments, i) {\n            var path = routePaths[i];\n            if (path.reversed) {\n                segments.reverse();\n                segments.forEach(function (segment) {\n                    segment.reverse();\n                });\n            }\n        });\n    };\n    GridRouter.angleBetween2Lines = function (line1, line2) {\n        var angle1 = Math.atan2(line1[0].y - line1[1].y, line1[0].x - line1[1].x);\n        var angle2 = Math.atan2(line2[0].y - line2[1].y, line2[0].x - line2[1].x);\n        var diff = angle1 - angle2;\n        if (diff > Math.PI || diff < -Math.PI) {\n            diff = angle2 - angle1;\n        }\n        return diff;\n    };\n    GridRouter.isLeft = function (a, b, c) {\n        return ((b.x - a.x) * (c.y - a.y) - (b.y - a.y) * (c.x - a.x)) <= 0;\n    };\n    GridRouter.getOrder = function (pairs) {\n        var outgoing = {};\n        for (var i = 0; i < pairs.length; i++) {\n            var p = pairs[i];\n            if (typeof outgoing[p.l] === 'undefined')\n                outgoing[p.l] = {};\n            outgoing[p.l][p.r] = true;\n        }\n        return function (l, r) { return typeof outgoing[l] !== 'undefined' && outgoing[l][r]; };\n    };\n    GridRouter.orderEdges = function (edges) {\n        var edgeOrder = [];\n        for (var i = 0; i < edges.length - 1; i++) {\n            for (var j = i + 1; j < edges.length; j++) {\n                var e = edges[i], f = edges[j], lcs = new LongestCommonSubsequence(e, f);\n                var u, vi, vj;\n                if (lcs.length === 0)\n                    continue;\n                if (lcs.reversed) {\n                    f.reverse();\n                    f.reversed = true;\n                    lcs = new LongestCommonSubsequence(e, f);\n                }\n                if ((lcs.si <= 0 || lcs.ti <= 0) &&\n                    (lcs.si + lcs.length >= e.length || lcs.ti + lcs.length >= f.length)) {\n                    edgeOrder.push({ l: i, r: j });\n                    continue;\n                }\n                if (lcs.si + lcs.length >= e.length || lcs.ti + lcs.length >= f.length) {\n                    u = e[lcs.si + 1];\n                    vj = e[lcs.si - 1];\n                    vi = f[lcs.ti - 1];\n                }\n                else {\n                    u = e[lcs.si + lcs.length - 2];\n                    vi = e[lcs.si + lcs.length];\n                    vj = f[lcs.ti + lcs.length];\n                }\n                if (GridRouter.isLeft(u, vi, vj)) {\n                    edgeOrder.push({ l: j, r: i });\n                }\n                else {\n                    edgeOrder.push({ l: i, r: j });\n                }\n            }\n        }\n        return GridRouter.getOrder(edgeOrder);\n    };\n    GridRouter.makeSegments = function (path) {\n        function copyPoint(p) {\n            return { x: p.x, y: p.y };\n        }\n        var isStraight = function (a, b, c) { return Math.abs((b.x - a.x) * (c.y - a.y) - (b.y - a.y) * (c.x - a.x)) < 0.001; };\n        var segments = [];\n        var a = copyPoint(path[0]);\n        for (var i = 1; i < path.length; i++) {\n            var b = copyPoint(path[i]), c = i < path.length - 1 ? path[i + 1] : null;\n            if (!c || !isStraight(a, b, c)) {\n                segments.push([a, b]);\n                a = b;\n            }\n        }\n        return segments;\n    };\n    GridRouter.prototype.route = function (s, t) {\n        var _this = this;\n        var source = this.nodes[s], target = this.nodes[t];\n        this.obstacles = this.siblingObstacles(source, target);\n        var obstacleLookup = {};\n        this.obstacles.forEach(function (o) { return obstacleLookup[o.id] = o; });\n        this.passableEdges = this.edges.filter(function (e) {\n            var u = _this.verts[e.source], v = _this.verts[e.target];\n            return !(u.node && u.node.id in obstacleLookup\n                || v.node && v.node.id in obstacleLookup);\n        });\n        for (var i = 1; i < source.ports.length; i++) {\n            var u = source.ports[0].id;\n            var v = source.ports[i].id;\n            this.passableEdges.push({\n                source: u,\n                target: v,\n                length: 0\n            });\n        }\n        for (var i = 1; i < target.ports.length; i++) {\n            var u = target.ports[0].id;\n            var v = target.ports[i].id;\n            this.passableEdges.push({\n                source: u,\n                target: v,\n                length: 0\n            });\n        }\n        var getSource = function (e) { return e.source; }, getTarget = function (e) { return e.target; }, getLength = function (e) { return e.length; };\n        var shortestPathCalculator = new shortestpaths_1.Calculator(this.verts.length, this.passableEdges, getSource, getTarget, getLength);\n        var bendPenalty = function (u, v, w) {\n            var a = _this.verts[u], b = _this.verts[v], c = _this.verts[w];\n            var dx = Math.abs(c.x - a.x), dy = Math.abs(c.y - a.y);\n            if (a.node === source && a.node === b.node || b.node === target && b.node === c.node)\n                return 0;\n            return dx > 1 && dy > 1 ? 1000 : 0;\n        };\n        var shortestPath = shortestPathCalculator.PathFromNodeToNodeWithPrevCost(source.ports[0].id, target.ports[0].id, bendPenalty);\n        var pathPoints = shortestPath.reverse().map(function (vi) { return _this.verts[vi]; });\n        pathPoints.push(this.nodes[target.id].ports[0]);\n        return pathPoints.filter(function (v, i) {\n            return !(i < pathPoints.length - 1 && pathPoints[i + 1].node === source && v.node === source\n                || i > 0 && v.node === target && pathPoints[i - 1].node === target);\n        });\n    };\n    GridRouter.getRoutePath = function (route, cornerradius, arrowwidth, arrowheight) {\n        var result = {\n            routepath: 'M ' + route[0][0].x + ' ' + route[0][0].y + ' ',\n            arrowpath: ''\n        };\n        if (route.length > 1) {\n            for (var i = 0; i < route.length; i++) {\n                var li = route[i];\n                var x = li[1].x, y = li[1].y;\n                var dx = x - li[0].x;\n                var dy = y - li[0].y;\n                if (i < route.length - 1) {\n                    if (Math.abs(dx) > 0) {\n                        x -= dx / Math.abs(dx) * cornerradius;\n                    }\n                    else {\n                        y -= dy / Math.abs(dy) * cornerradius;\n                    }\n                    result.routepath += 'L ' + x + ' ' + y + ' ';\n                    var l = route[i + 1];\n                    var x0 = l[0].x, y0 = l[0].y;\n                    var x1 = l[1].x;\n                    var y1 = l[1].y;\n                    dx = x1 - x0;\n                    dy = y1 - y0;\n                    var angle = GridRouter.angleBetween2Lines(li, l) < 0 ? 1 : 0;\n                    var x2, y2;\n                    if (Math.abs(dx) > 0) {\n                        x2 = x0 + dx / Math.abs(dx) * cornerradius;\n                        y2 = y0;\n                    }\n                    else {\n                        x2 = x0;\n                        y2 = y0 + dy / Math.abs(dy) * cornerradius;\n                    }\n                    var cx = Math.abs(x2 - x);\n                    var cy = Math.abs(y2 - y);\n                    result.routepath += 'A ' + cx + ' ' + cy + ' 0 0 ' + angle + ' ' + x2 + ' ' + y2 + ' ';\n                }\n                else {\n                    var arrowtip = [x, y];\n                    var arrowcorner1, arrowcorner2;\n                    if (Math.abs(dx) > 0) {\n                        x -= dx / Math.abs(dx) * arrowheight;\n                        arrowcorner1 = [x, y + arrowwidth];\n                        arrowcorner2 = [x, y - arrowwidth];\n                    }\n                    else {\n                        y -= dy / Math.abs(dy) * arrowheight;\n                        arrowcorner1 = [x + arrowwidth, y];\n                        arrowcorner2 = [x - arrowwidth, y];\n                    }\n                    result.routepath += 'L ' + x + ' ' + y + ' ';\n                    if (arrowheight > 0) {\n                        result.arrowpath = 'M ' + arrowtip[0] + ' ' + arrowtip[1] + ' L ' + arrowcorner1[0] + ' ' + arrowcorner1[1]\n                            + ' L ' + arrowcorner2[0] + ' ' + arrowcorner2[1];\n                    }\n                }\n            }\n        }\n        else {\n            var li = route[0];\n            var x = li[1].x, y = li[1].y;\n            var dx = x - li[0].x;\n            var dy = y - li[0].y;\n            var arrowtip = [x, y];\n            var arrowcorner1, arrowcorner2;\n            if (Math.abs(dx) > 0) {\n                x -= dx / Math.abs(dx) * arrowheight;\n                arrowcorner1 = [x, y + arrowwidth];\n                arrowcorner2 = [x, y - arrowwidth];\n            }\n            else {\n                y -= dy / Math.abs(dy) * arrowheight;\n                arrowcorner1 = [x + arrowwidth, y];\n                arrowcorner2 = [x - arrowwidth, y];\n            }\n            result.routepath += 'L ' + x + ' ' + y + ' ';\n            if (arrowheight > 0) {\n                result.arrowpath = 'M ' + arrowtip[0] + ' ' + arrowtip[1] + ' L ' + arrowcorner1[0] + ' ' + arrowcorner1[1]\n                    + ' L ' + arrowcorner2[0] + ' ' + arrowcorner2[1];\n            }\n        }\n        return result;\n    };\n    return GridRouter;\n}());\nexports.GridRouter = GridRouter;\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gridrouter.js","sourceRoot":"","sources":["../../WebCola/src/gridrouter.ts"],"names":[],"mappings":"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"}","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar packingOptions = {\n    PADDING: 10,\n    GOLDEN_SECTION: (1 + Math.sqrt(5)) / 2,\n    FLOAT_EPSILON: 0.0001,\n    MAX_INERATIONS: 100\n};\nfunction applyPacking(graphs, w, h, node_size, desired_ratio, centerGraph) {\n    if (desired_ratio === void 0) { desired_ratio = 1; }\n    if (centerGraph === void 0) { centerGraph = true; }\n    var init_x = 0, init_y = 0, svg_width = w, svg_height = h, desired_ratio = typeof desired_ratio !== 'undefined' ? desired_ratio : 1, node_size = typeof node_size !== 'undefined' ? node_size : 0, real_width = 0, real_height = 0, min_width = 0, global_bottom = 0, line = [];\n    if (graphs.length == 0)\n        return;\n    calculate_bb(graphs);\n    apply(graphs, desired_ratio);\n    if (centerGraph) {\n        put_nodes_to_right_positions(graphs);\n    }\n    function calculate_bb(graphs) {\n        graphs.forEach(function (g) {\n            calculate_single_bb(g);\n        });\n        function calculate_single_bb(graph) {\n            var min_x = Number.MAX_VALUE, min_y = Number.MAX_VALUE, max_x = 0, max_y = 0;\n            graph.array.forEach(function (v) {\n                var w = typeof v.width !== 'undefined' ? v.width : node_size;\n                var h = typeof v.height !== 'undefined' ? v.height : node_size;\n                w /= 2;\n                h /= 2;\n                max_x = Math.max(v.x + w, max_x);\n                min_x = Math.min(v.x - w, min_x);\n                max_y = Math.max(v.y + h, max_y);\n                min_y = Math.min(v.y - h, min_y);\n            });\n            graph.width = max_x - min_x;\n            graph.height = max_y - min_y;\n        }\n    }\n    function put_nodes_to_right_positions(graphs) {\n        graphs.forEach(function (g) {\n            var center = { x: 0, y: 0 };\n            g.array.forEach(function (node) {\n                center.x += node.x;\n                center.y += node.y;\n            });\n            center.x /= g.array.length;\n            center.y /= g.array.length;\n            var corner = { x: center.x - g.width / 2, y: center.y - g.height / 2 };\n            var offset = { x: g.x - corner.x + svg_width / 2 - real_width / 2, y: g.y - corner.y + svg_height / 2 - real_height / 2 };\n            g.array.forEach(function (node) {\n                node.x += offset.x;\n                node.y += offset.y;\n            });\n        });\n    }\n    function apply(data, desired_ratio) {\n        var curr_best_f = Number.POSITIVE_INFINITY;\n        var curr_best = 0;\n        data.sort(function (a, b) { return b.height - a.height; });\n        min_width = data.reduce(function (a, b) {\n            return a.width < b.width ? a.width : b.width;\n        });\n        var left = x1 = min_width;\n        var right = x2 = get_entire_width(data);\n        var iterationCounter = 0;\n        var f_x1 = Number.MAX_VALUE;\n        var f_x2 = Number.MAX_VALUE;\n        var flag = -1;\n        var dx = Number.MAX_VALUE;\n        var df = Number.MAX_VALUE;\n        while ((dx > min_width) || df > packingOptions.FLOAT_EPSILON) {\n            if (flag != 1) {\n                var x1 = right - (right - left) / packingOptions.GOLDEN_SECTION;\n                var f_x1 = step(data, x1);\n            }\n            if (flag != 0) {\n                var x2 = left + (right - left) / packingOptions.GOLDEN_SECTION;\n                var f_x2 = step(data, x2);\n            }\n            dx = Math.abs(x1 - x2);\n            df = Math.abs(f_x1 - f_x2);\n            if (f_x1 < curr_best_f) {\n                curr_best_f = f_x1;\n                curr_best = x1;\n            }\n            if (f_x2 < curr_best_f) {\n                curr_best_f = f_x2;\n                curr_best = x2;\n            }\n            if (f_x1 > f_x2) {\n                left = x1;\n                x1 = x2;\n                f_x1 = f_x2;\n                flag = 1;\n            }\n            else {\n                right = x2;\n                x2 = x1;\n                f_x2 = f_x1;\n                flag = 0;\n            }\n            if (iterationCounter++ > 100) {\n                break;\n            }\n        }\n        step(data, curr_best);\n    }\n    function step(data, max_width) {\n        line = [];\n        real_width = 0;\n        real_height = 0;\n        global_bottom = init_y;\n        for (var i = 0; i < data.length; i++) {\n            var o = data[i];\n            put_rect(o, max_width);\n        }\n        return Math.abs(get_real_ratio() - desired_ratio);\n    }\n    function put_rect(rect, max_width) {\n        var parent = undefined;\n        for (var i = 0; i < line.length; i++) {\n            if ((line[i].space_left >= rect.height) && (line[i].x + line[i].width + rect.width + packingOptions.PADDING - max_width) <= packingOptions.FLOAT_EPSILON) {\n                parent = line[i];\n                break;\n            }\n        }\n        line.push(rect);\n        if (parent !== undefined) {\n            rect.x = parent.x + parent.width + packingOptions.PADDING;\n            rect.y = parent.bottom;\n            rect.space_left = rect.height;\n            rect.bottom = rect.y;\n            parent.space_left -= rect.height + packingOptions.PADDING;\n            parent.bottom += rect.height + packingOptions.PADDING;\n        }\n        else {\n            rect.y = global_bottom;\n            global_bottom += rect.height + packingOptions.PADDING;\n            rect.x = init_x;\n            rect.bottom = rect.y;\n            rect.space_left = rect.height;\n        }\n        if (rect.y + rect.height - real_height > -packingOptions.FLOAT_EPSILON)\n            real_height = rect.y + rect.height - init_y;\n        if (rect.x + rect.width - real_width > -packingOptions.FLOAT_EPSILON)\n            real_width = rect.x + rect.width - init_x;\n    }\n    ;\n    function get_entire_width(data) {\n        var width = 0;\n        data.forEach(function (d) { return width += d.width + packingOptions.PADDING; });\n        return width;\n    }\n    function get_real_ratio() {\n        return (real_width / real_height);\n    }\n}\nexports.applyPacking = applyPacking;\nfunction separateGraphs(nodes, links) {\n    var marks = {};\n    var ways = {};\n    var graphs = [];\n    var clusters = 0;\n    for (var i = 0; i < links.length; i++) {\n        var link = links[i];\n        var n1 = link.source;\n        var n2 = link.target;\n        if (ways[n1.index])\n            ways[n1.index].push(n2);\n        else\n            ways[n1.index] = [n2];\n        if (ways[n2.index])\n            ways[n2.index].push(n1);\n        else\n            ways[n2.index] = [n1];\n    }\n    for (var i = 0; i < nodes.length; i++) {\n        var node = nodes[i];\n        if (marks[node.index])\n            continue;\n        explore_node(node, true);\n    }\n    function explore_node(n, is_new) {\n        if (marks[n.index] !== undefined)\n            return;\n        if (is_new) {\n            clusters++;\n            graphs.push({ array: [] });\n        }\n        marks[n.index] = clusters;\n        graphs[clusters - 1].array.push(n);\n        var adjacent = ways[n.index];\n        if (!adjacent)\n            return;\n        for (var j = 0; j < adjacent.length; j++) {\n            explore_node(adjacent[j], false);\n        }\n    }\n    return graphs;\n}\nexports.separateGraphs = separateGraphs;\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"handledisconnected.js","sourceRoot":"","sources":["../../WebCola/src/handledisconnected.ts"],"names":[],"mappings":"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"}","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar powergraph = require(\"./powergraph\");\nvar linklengths_1 = require(\"./linklengths\");\nvar descent_1 = require(\"./descent\");\nvar rectangle_1 = require(\"./rectangle\");\nvar shortestpaths_1 = require(\"./shortestpaths\");\nvar geom_1 = require(\"./geom\");\nvar handledisconnected_1 = require(\"./handledisconnected\");\nvar EventType;\n(function (EventType) {\n    EventType[EventType[\"start\"] = 0] = \"start\";\n    EventType[EventType[\"tick\"] = 1] = \"tick\";\n    EventType[EventType[\"end\"] = 2] = \"end\";\n})(EventType = exports.EventType || (exports.EventType = {}));\n;\nfunction isGroup(g) {\n    return typeof g.leaves !== 'undefined' || typeof g.groups !== 'undefined';\n}\nvar Layout = (function () {\n    function Layout() {\n        var _this = this;\n        this._canvasSize = [1, 1];\n        this._linkDistance = 20;\n        this._defaultNodeSize = 10;\n        this._linkLengthCalculator = null;\n        this._linkType = null;\n        this._avoidOverlaps = false;\n        this._handleDisconnected = true;\n        this._running = false;\n        this._nodes = [];\n        this._groups = [];\n        this._rootGroup = null;\n        this._links = [];\n        this._constraints = [];\n        this._distanceMatrix = null;\n        this._descent = null;\n        this._directedLinkConstraints = null;\n        this._threshold = 0.01;\n        this._visibilityGraph = null;\n        this._groupCompactness = 1e-6;\n        this.event = null;\n        this.linkAccessor = {\n            getSourceIndex: Layout.getSourceIndex,\n            getTargetIndex: Layout.getTargetIndex,\n            setLength: Layout.setLinkLength,\n            getType: function (l) { return typeof _this._linkType === \"function\" ? _this._linkType(l) : 0; }\n        };\n    }\n    Layout.prototype.on = function (e, listener) {\n        if (!this.event)\n            this.event = {};\n        if (typeof e === 'string') {\n            this.event[EventType[e]] = listener;\n        }\n        else {\n            this.event[e] = listener;\n        }\n        return this;\n    };\n    Layout.prototype.trigger = function (e) {\n        if (this.event && typeof this.event[e.type] !== 'undefined') {\n            this.event[e.type](e);\n        }\n    };\n    Layout.prototype.kick = function () {\n        while (!this.tick())\n            ;\n    };\n    Layout.prototype.tick = function () {\n        if (this._alpha < this._threshold) {\n            this._running = false;\n            this.trigger({ type: EventType.end, alpha: this._alpha = 0, stress: this._lastStress });\n            return true;\n        }\n        var n = this._nodes.length, m = this._links.length;\n        var o, i;\n        this._descent.locks.clear();\n        for (i = 0; i < n; ++i) {\n            o = this._nodes[i];\n            if (o.fixed) {\n                if (typeof o.px === 'undefined' || typeof o.py === 'undefined') {\n                    o.px = o.x;\n                    o.py = o.y;\n                }\n                var p = [o.px, o.py];\n                this._descent.locks.add(i, p);\n            }\n        }\n        var s1 = this._descent.rungeKutta();\n        if (s1 === 0) {\n            this._alpha = 0;\n        }\n        else if (typeof this._lastStress !== 'undefined') {\n            this._alpha = s1;\n        }\n        this._lastStress = s1;\n        this.updateNodePositions();\n        this.trigger({ type: EventType.tick, alpha: this._alpha, stress: this._lastStress });\n        return false;\n    };\n    Layout.prototype.updateNodePositions = function () {\n        var x = this._descent.x[0], y = this._descent.x[1];\n        var o, i = this._nodes.length;\n        while (i--) {\n            o = this._nodes[i];\n            o.x = x[i];\n            o.y = y[i];\n        }\n    };\n    Layout.prototype.nodes = function (v) {\n        if (!v) {\n            if (this._nodes.length === 0 && this._links.length > 0) {\n                var n = 0;\n                this._links.forEach(function (l) {\n                    n = Math.max(n, l.source, l.target);\n                });\n                this._nodes = new Array(++n);\n                for (var i = 0; i < n; ++i) {\n                    this._nodes[i] = {};\n                }\n            }\n            return this._nodes;\n        }\n        this._nodes = v;\n        return this;\n    };\n    Layout.prototype.groups = function (x) {\n        var _this = this;\n        if (!x)\n            return this._groups;\n        this._groups = x;\n        this._rootGroup = {};\n        this._groups.forEach(function (g) {\n            if (typeof g.padding === \"undefined\")\n                g.padding = 1;\n            if (typeof g.leaves !== \"undefined\") {\n                g.leaves.forEach(function (v, i) {\n                    if (typeof v === 'number')\n                        (g.leaves[i] = _this._nodes[v]).parent = g;\n                });\n            }\n            if (typeof g.groups !== \"undefined\") {\n                g.groups.forEach(function (gi, i) {\n                    if (typeof gi === 'number')\n                        (g.groups[i] = _this._groups[gi]).parent = g;\n                });\n            }\n        });\n        this._rootGroup.leaves = this._nodes.filter(function (v) { return typeof v.parent === 'undefined'; });\n        this._rootGroup.groups = this._groups.filter(function (g) { return typeof g.parent === 'undefined'; });\n        return this;\n    };\n    Layout.prototype.powerGraphGroups = function (f) {\n        var g = powergraph.getGroups(this._nodes, this._links, this.linkAccessor, this._rootGroup);\n        this.groups(g.groups);\n        f(g);\n        return this;\n    };\n    Layout.prototype.avoidOverlaps = function (v) {\n        if (!arguments.length)\n            return this._avoidOverlaps;\n        this._avoidOverlaps = v;\n        return this;\n    };\n    Layout.prototype.handleDisconnected = function (v) {\n        if (!arguments.length)\n            return this._handleDisconnected;\n        this._handleDisconnected = v;\n        return this;\n    };\n    Layout.prototype.flowLayout = function (axis, minSeparation) {\n        if (!arguments.length)\n            axis = 'y';\n        this._directedLinkConstraints = {\n            axis: axis,\n            getMinSeparation: typeof minSeparation === 'number' ? function () { return minSeparation; } : minSeparation\n        };\n        return this;\n    };\n    Layout.prototype.links = function (x) {\n        if (!arguments.length)\n            return this._links;\n        this._links = x;\n        return this;\n    };\n    Layout.prototype.constraints = function (c) {\n        if (!arguments.length)\n            return this._constraints;\n        this._constraints = c;\n        return this;\n    };\n    Layout.prototype.distanceMatrix = function (d) {\n        if (!arguments.length)\n            return this._distanceMatrix;\n        this._distanceMatrix = d;\n        return this;\n    };\n    Layout.prototype.size = function (x) {\n        if (!x)\n            return this._canvasSize;\n        this._canvasSize = x;\n        return this;\n    };\n    Layout.prototype.defaultNodeSize = function (x) {\n        if (!x)\n            return this._defaultNodeSize;\n        this._defaultNodeSize = x;\n        return this;\n    };\n    Layout.prototype.groupCompactness = function (x) {\n        if (!x)\n            return this._groupCompactness;\n        this._groupCompactness = x;\n        return this;\n    };\n    Layout.prototype.linkDistance = function (x) {\n        if (!x) {\n            return this._linkDistance;\n        }\n        this._linkDistance = typeof x === \"function\" ? x : +x;\n        this._linkLengthCalculator = null;\n        return this;\n    };\n    Layout.prototype.linkType = function (f) {\n        this._linkType = f;\n        return this;\n    };\n    Layout.prototype.convergenceThreshold = function (x) {\n        if (!x)\n            return this._threshold;\n        this._threshold = typeof x === \"function\" ? x : +x;\n        return this;\n    };\n    Layout.prototype.alpha = function (x) {\n        if (!arguments.length)\n            return this._alpha;\n        else {\n            x = +x;\n            if (this._alpha) {\n                if (x > 0)\n                    this._alpha = x;\n                else\n                    this._alpha = 0;\n            }\n            else if (x > 0) {\n                if (!this._running) {\n                    this._running = true;\n                    this.trigger({ type: EventType.start, alpha: this._alpha = x });\n                    this.kick();\n                }\n            }\n            return this;\n        }\n    };\n    Layout.prototype.getLinkLength = function (link) {\n        return typeof this._linkDistance === \"function\" ? +(this._linkDistance(link)) : this._linkDistance;\n    };\n    Layout.setLinkLength = function (link, length) {\n        link.length = length;\n    };\n    Layout.prototype.getLinkType = function (link) {\n        return typeof this._linkType === \"function\" ? this._linkType(link) : 0;\n    };\n    Layout.prototype.symmetricDiffLinkLengths = function (idealLength, w) {\n        var _this = this;\n        if (w === void 0) { w = 1; }\n        this.linkDistance(function (l) { return idealLength * l.length; });\n        this._linkLengthCalculator = function () { return linklengths_1.symmetricDiffLinkLengths(_this._links, _this.linkAccessor, w); };\n        return this;\n    };\n    Layout.prototype.jaccardLinkLengths = function (idealLength, w) {\n        var _this = this;\n        if (w === void 0) { w = 1; }\n        this.linkDistance(function (l) { return idealLength * l.length; });\n        this._linkLengthCalculator = function () { return linklengths_1.jaccardLinkLengths(_this._links, _this.linkAccessor, w); };\n        return this;\n    };\n    Layout.prototype.start = function (initialUnconstrainedIterations, initialUserConstraintIterations, initialAllConstraintsIterations, gridSnapIterations, keepRunning, centerGraph) {\n        var _this = this;\n        if (initialUnconstrainedIterations === void 0) { initialUnconstrainedIterations = 0; }\n        if (initialUserConstraintIterations === void 0) { initialUserConstraintIterations = 0; }\n        if (initialAllConstraintsIterations === void 0) { initialAllConstraintsIterations = 0; }\n        if (gridSnapIterations === void 0) { gridSnapIterations = 0; }\n        if (keepRunning === void 0) { keepRunning = true; }\n        if (centerGraph === void 0) { centerGraph = true; }\n        var i, j, n = this.nodes().length, N = n + 2 * this._groups.length, m = this._links.length, w = this._canvasSize[0], h = this._canvasSize[1];\n        var x = new Array(N), y = new Array(N);\n        var G = null;\n        var ao = this._avoidOverlaps;\n        this._nodes.forEach(function (v, i) {\n            v.index = i;\n            if (typeof v.x === 'undefined') {\n                v.x = w / 2, v.y = h / 2;\n            }\n            x[i] = v.x, y[i] = v.y;\n        });\n        if (this._linkLengthCalculator)\n            this._linkLengthCalculator();\n        var distances;\n        if (this._distanceMatrix) {\n            distances = this._distanceMatrix;\n        }\n        else {\n            distances = (new shortestpaths_1.Calculator(N, this._links, Layout.getSourceIndex, Layout.getTargetIndex, function (l) { return _this.getLinkLength(l); })).DistanceMatrix();\n            G = descent_1.Descent.createSquareMatrix(N, function () { return 2; });\n            this._links.forEach(function (l) {\n                if (typeof l.source == \"number\")\n                    l.source = _this._nodes[l.source];\n                if (typeof l.target == \"number\")\n                    l.target = _this._nodes[l.target];\n            });\n            this._links.forEach(function (e) {\n                var u = Layout.getSourceIndex(e), v = Layout.getTargetIndex(e);\n                G[u][v] = G[v][u] = e.weight || 1;\n            });\n        }\n        var D = descent_1.Descent.createSquareMatrix(N, function (i, j) {\n            return distances[i][j];\n        });\n        if (this._rootGroup && typeof this._rootGroup.groups !== 'undefined') {\n            var i = n;\n            var addAttraction = function (i, j, strength, idealDistance) {\n                G[i][j] = G[j][i] = strength;\n                D[i][j] = D[j][i] = idealDistance;\n            };\n            this._groups.forEach(function (g) {\n                addAttraction(i, i + 1, _this._groupCompactness, 0.1);\n                x[i] = 0, y[i++] = 0;\n                x[i] = 0, y[i++] = 0;\n            });\n        }\n        else\n            this._rootGroup = { leaves: this._nodes, groups: [] };\n        var curConstraints = this._constraints || [];\n        if (this._directedLinkConstraints) {\n            this.linkAccessor.getMinSeparation = this._directedLinkConstraints.getMinSeparation;\n            curConstraints = curConstraints.concat(linklengths_1.generateDirectedEdgeConstraints(n, this._links, this._directedLinkConstraints.axis, (this.linkAccessor)));\n        }\n        this.avoidOverlaps(false);\n        this._descent = new descent_1.Descent([x, y], D);\n        this._descent.locks.clear();\n        for (var i = 0; i < n; ++i) {\n            var o = this._nodes[i];\n            if (o.fixed) {\n                o.px = o.x;\n                o.py = o.y;\n                var p = [o.x, o.y];\n                this._descent.locks.add(i, p);\n            }\n        }\n        this._descent.threshold = this._threshold;\n        this.initialLayout(initialUnconstrainedIterations, x, y);\n        if (curConstraints.length > 0)\n            this._descent.project = new rectangle_1.Projection(this._nodes, this._groups, this._rootGroup, curConstraints).projectFunctions();\n        this._descent.run(initialUserConstraintIterations);\n        this.separateOverlappingComponents(w, h, centerGraph);\n        this.avoidOverlaps(ao);\n        if (ao) {\n            this._nodes.forEach(function (v, i) { v.x = x[i], v.y = y[i]; });\n            this._descent.project = new rectangle_1.Projection(this._nodes, this._groups, this._rootGroup, curConstraints, true).projectFunctions();\n            this._nodes.forEach(function (v, i) { x[i] = v.x, y[i] = v.y; });\n        }\n        this._descent.G = G;\n        this._descent.run(initialAllConstraintsIterations);\n        if (gridSnapIterations) {\n            this._descent.snapStrength = 1000;\n            this._descent.snapGridSize = this._nodes[0].width;\n            this._descent.numGridSnapNodes = n;\n            this._descent.scaleSnapByMaxH = n != N;\n            var G0 = descent_1.Descent.createSquareMatrix(N, function (i, j) {\n                if (i >= n || j >= n)\n                    return G[i][j];\n                return 0;\n            });\n            this._descent.G = G0;\n            this._descent.run(gridSnapIterations);\n        }\n        this.updateNodePositions();\n        this.separateOverlappingComponents(w, h, centerGraph);\n        return keepRunning ? this.resume() : this;\n    };\n    Layout.prototype.initialLayout = function (iterations, x, y) {\n        if (this._groups.length > 0 && iterations > 0) {\n            var n = this._nodes.length;\n            var edges = this._links.map(function (e) { return ({ source: e.source.index, target: e.target.index }); });\n            var vs = this._nodes.map(function (v) { return ({ index: v.index }); });\n            this._groups.forEach(function (g, i) {\n                vs.push({ index: g.index = n + i });\n            });\n            this._groups.forEach(function (g, i) {\n                if (typeof g.leaves !== 'undefined')\n                    g.leaves.forEach(function (v) { return edges.push({ source: g.index, target: v.index }); });\n                if (typeof g.groups !== 'undefined')\n                    g.groups.forEach(function (gg) { return edges.push({ source: g.index, target: gg.index }); });\n            });\n            new Layout()\n                .size(this.size())\n                .nodes(vs)\n                .links(edges)\n                .avoidOverlaps(false)\n                .linkDistance(this.linkDistance())\n                .symmetricDiffLinkLengths(5)\n                .convergenceThreshold(1e-4)\n                .start(iterations, 0, 0, 0, false);\n            this._nodes.forEach(function (v) {\n                x[v.index] = vs[v.index].x;\n                y[v.index] = vs[v.index].y;\n            });\n        }\n        else {\n            this._descent.run(iterations);\n        }\n    };\n    Layout.prototype.separateOverlappingComponents = function (width, height, centerGraph) {\n        var _this = this;\n        if (centerGraph === void 0) { centerGraph = true; }\n        if (!this._distanceMatrix && this._handleDisconnected) {\n            var x_1 = this._descent.x[0], y_1 = this._descent.x[1];\n            this._nodes.forEach(function (v, i) { v.x = x_1[i], v.y = y_1[i]; });\n            var graphs = handledisconnected_1.separateGraphs(this._nodes, this._links);\n            handledisconnected_1.applyPacking(graphs, width, height, this._defaultNodeSize, (height / width), centerGraph);\n            this._nodes.forEach(function (v, i) {\n                _this._descent.x[0][i] = v.x, _this._descent.x[1][i] = v.y;\n                if (v.bounds) {\n                    v.bounds.setXCentre(v.x);\n                    v.bounds.setYCentre(v.y);\n                }\n            });\n        }\n    };\n    Layout.prototype.resume = function () {\n        return this.alpha(0.1);\n    };\n    Layout.prototype.stop = function () {\n        return this.alpha(0);\n    };\n    Layout.prototype.prepareEdgeRouting = function (nodeMargin) {\n        if (nodeMargin === void 0) { nodeMargin = 0; }\n        this._visibilityGraph = new geom_1.TangentVisibilityGraph(this._nodes.map(function (v) {\n            return v.bounds.inflate(-nodeMargin).vertices();\n        }));\n    };\n    Layout.prototype.routeEdge = function (edge, ah, draw) {\n        if (ah === void 0) { ah = 5; }\n        var lineData = [];\n        var vg2 = new geom_1.TangentVisibilityGraph(this._visibilityGraph.P, { V: this._visibilityGraph.V, E: this._visibilityGraph.E }), port1 = { x: edge.source.x, y: edge.source.y }, port2 = { x: edge.target.x, y: edge.target.y }, start = vg2.addPoint(port1, edge.source.index), end = vg2.addPoint(port2, edge.target.index);\n        vg2.addEdgeIfVisible(port1, port2, edge.source.index, edge.target.index);\n        if (typeof draw !== 'undefined') {\n            draw(vg2);\n        }\n        var sourceInd = function (e) { return e.source.id; }, targetInd = function (e) { return e.target.id; }, length = function (e) { return e.length(); }, spCalc = new shortestpaths_1.Calculator(vg2.V.length, vg2.E, sourceInd, targetInd, length), shortestPath = spCalc.PathFromNodeToNode(start.id, end.id);\n        if (shortestPath.length === 1 || shortestPath.length === vg2.V.length) {\n            var route = rectangle_1.makeEdgeBetween(edge.source.innerBounds, edge.target.innerBounds, ah);\n            lineData = [route.sourceIntersection, route.arrowStart];\n        }\n        else {\n            var n = shortestPath.length - 2, p = vg2.V[shortestPath[n]].p, q = vg2.V[shortestPath[0]].p, lineData = [edge.source.innerBounds.rayIntersection(p.x, p.y)];\n            for (var i = n; i >= 0; --i)\n                lineData.push(vg2.V[shortestPath[i]].p);\n            lineData.push(rectangle_1.makeEdgeTo(q, edge.target.innerBounds, ah));\n        }\n        return lineData;\n    };\n    Layout.getSourceIndex = function (e) {\n        return typeof e.source === 'number' ? e.source : e.source.index;\n    };\n    Layout.getTargetIndex = function (e) {\n        return typeof e.target === 'number' ? e.target : e.target.index;\n    };\n    Layout.linkId = function (e) {\n        return Layout.getSourceIndex(e) + \"-\" + Layout.getTargetIndex(e);\n    };\n    Layout.dragStart = function (d) {\n        if (isGroup(d)) {\n            Layout.storeOffset(d, Layout.dragOrigin(d));\n        }\n        else {\n            Layout.stopNode(d);\n            d.fixed |= 2;\n        }\n    };\n    Layout.stopNode = function (v) {\n        v.px = v.x;\n        v.py = v.y;\n    };\n    Layout.storeOffset = function (d, origin) {\n        if (typeof d.leaves !== 'undefined') {\n            d.leaves.forEach(function (v) {\n                v.fixed |= 2;\n                Layout.stopNode(v);\n                v._dragGroupOffsetX = v.x - origin.x;\n                v._dragGroupOffsetY = v.y - origin.y;\n            });\n        }\n        if (typeof d.groups !== 'undefined') {\n            d.groups.forEach(function (g) { return Layout.storeOffset(g, origin); });\n        }\n    };\n    Layout.dragOrigin = function (d) {\n        if (isGroup(d)) {\n            return {\n                x: d.bounds.cx(),\n                y: d.bounds.cy()\n            };\n        }\n        else {\n            return d;\n        }\n    };\n    Layout.drag = function (d, position) {\n        if (isGroup(d)) {\n            if (typeof d.leaves !== 'undefined') {\n                d.leaves.forEach(function (v) {\n                    d.bounds.setXCentre(position.x);\n                    d.bounds.setYCentre(position.y);\n                    v.px = v._dragGroupOffsetX + position.x;\n                    v.py = v._dragGroupOffsetY + position.y;\n                });\n            }\n            if (typeof d.groups !== 'undefined') {\n                d.groups.forEach(function (g) { return Layout.drag(g, position); });\n            }\n        }\n        else {\n            d.px = position.x;\n            d.py = position.y;\n        }\n    };\n    Layout.dragEnd = function (d) {\n        if (isGroup(d)) {\n            if (typeof d.leaves !== 'undefined') {\n                d.leaves.forEach(function (v) {\n                    Layout.dragEnd(v);\n                    delete v._dragGroupOffsetX;\n                    delete v._dragGroupOffsetY;\n                });\n            }\n            if (typeof d.groups !== 'undefined') {\n                d.groups.forEach(Layout.dragEnd);\n            }\n        }\n        else {\n            d.fixed &= ~6;\n        }\n    };\n    Layout.mouseOver = function (d) {\n        d.fixed |= 4;\n        d.px = d.x, d.py = d.y;\n    };\n    Layout.mouseOut = function (d) {\n        d.fixed &= ~4;\n    };\n    return Layout;\n}());\nexports.Layout = Layout;\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout.js","sourceRoot":"","sources":["../../WebCola/src/layout.ts"],"names":[],"mappings":"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"}","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar shortestpaths_1 = require(\"./shortestpaths\");\nvar descent_1 = require(\"./descent\");\nvar rectangle_1 = require(\"./rectangle\");\nvar linklengths_1 = require(\"./linklengths\");\nvar Link3D = (function () {\n    function Link3D(source, target) {\n        this.source = source;\n        this.target = target;\n    }\n    Link3D.prototype.actualLength = function (x) {\n        var _this = this;\n        return Math.sqrt(x.reduce(function (c, v) {\n            var dx = v[_this.target] - v[_this.source];\n            return c + dx * dx;\n        }, 0));\n    };\n    return Link3D;\n}());\nexports.Link3D = Link3D;\nvar Node3D = (function () {\n    function Node3D(x, y, z) {\n        if (x === void 0) { x = 0; }\n        if (y === void 0) { y = 0; }\n        if (z === void 0) { z = 0; }\n        this.x = x;\n        this.y = y;\n        this.z = z;\n    }\n    return Node3D;\n}());\nexports.Node3D = Node3D;\nvar Layout3D = (function () {\n    function Layout3D(nodes, links, idealLinkLength) {\n        var _this = this;\n        if (idealLinkLength === void 0) { idealLinkLength = 1; }\n        this.nodes = nodes;\n        this.links = links;\n        this.idealLinkLength = idealLinkLength;\n        this.constraints = null;\n        this.useJaccardLinkLengths = true;\n        this.result = new Array(Layout3D.k);\n        for (var i = 0; i < Layout3D.k; ++i) {\n            this.result[i] = new Array(nodes.length);\n        }\n        nodes.forEach(function (v, i) {\n            for (var _i = 0, _a = Layout3D.dims; _i < _a.length; _i++) {\n                var dim = _a[_i];\n                if (typeof v[dim] == 'undefined')\n                    v[dim] = Math.random();\n            }\n            _this.result[0][i] = v.x;\n            _this.result[1][i] = v.y;\n            _this.result[2][i] = v.z;\n        });\n    }\n    ;\n    Layout3D.prototype.linkLength = function (l) {\n        return l.actualLength(this.result);\n    };\n    Layout3D.prototype.start = function (iterations) {\n        var _this = this;\n        if (iterations === void 0) { iterations = 100; }\n        var n = this.nodes.length;\n        var linkAccessor = new LinkAccessor();\n        if (this.useJaccardLinkLengths)\n            linklengths_1.jaccardLinkLengths(this.links, linkAccessor, 1.5);\n        this.links.forEach(function (e) { return e.length *= _this.idealLinkLength; });\n        var distanceMatrix = (new shortestpaths_1.Calculator(n, this.links, function (e) { return e.source; }, function (e) { return e.target; }, function (e) { return e.length; })).DistanceMatrix();\n        var D = descent_1.Descent.createSquareMatrix(n, function (i, j) { return distanceMatrix[i][j]; });\n        var G = descent_1.Descent.createSquareMatrix(n, function () { return 2; });\n        this.links.forEach(function (_a) {\n            var source = _a.source, target = _a.target;\n            return G[source][target] = G[target][source] = 1;\n        });\n        this.descent = new descent_1.Descent(this.result, D);\n        this.descent.threshold = 1e-3;\n        this.descent.G = G;\n        if (this.constraints)\n            this.descent.project = new rectangle_1.Projection(this.nodes, null, null, this.constraints).projectFunctions();\n        for (var i = 0; i < this.nodes.length; i++) {\n            var v = this.nodes[i];\n            if (v.fixed) {\n                this.descent.locks.add(i, [v.x, v.y, v.z]);\n            }\n        }\n        this.descent.run(iterations);\n        return this;\n    };\n    Layout3D.prototype.tick = function () {\n        this.descent.locks.clear();\n        for (var i = 0; i < this.nodes.length; i++) {\n            var v = this.nodes[i];\n            if (v.fixed) {\n                this.descent.locks.add(i, [v.x, v.y, v.z]);\n            }\n        }\n        return this.descent.rungeKutta();\n    };\n    Layout3D.dims = ['x', 'y', 'z'];\n    Layout3D.k = Layout3D.dims.length;\n    return Layout3D;\n}());\nexports.Layout3D = Layout3D;\nvar LinkAccessor = (function () {\n    function LinkAccessor() {\n    }\n    LinkAccessor.prototype.getSourceIndex = function (e) { return e.source; };\n    LinkAccessor.prototype.getTargetIndex = function (e) { return e.target; };\n    LinkAccessor.prototype.getLength = function (e) { return e.length; };\n    LinkAccessor.prototype.setLength = function (e, l) { e.length = l; };\n    return LinkAccessor;\n}());\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF5b3V0M2QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9XZWJDb2xhL3NyYy9sYXlvdXQzZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLGlEQUEwQztBQUMxQyxxQ0FBaUM7QUFDakMseUNBQTREO0FBRTVELDZDQUFvRTtBQUVwRTtJQUVRLGdCQUFtQixNQUFjLEVBQVMsTUFBYztRQUFyQyxXQUFNLEdBQU4sTUFBTSxDQUFRO1FBQVMsV0FBTSxHQUFOLE1BQU0sQ0FBUTtJQUFJLENBQUM7SUFDN0QsNkJBQVksR0FBWixVQUFhLENBQWE7UUFBMUIsaUJBTUM7UUFMRyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQ1osQ0FBQyxDQUFDLE1BQU0sQ0FBQyxVQUFDLENBQVMsRUFBRSxDQUFXO1lBQzVCLElBQU0sRUFBRSxHQUFHLENBQUMsQ0FBQyxLQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUMzQyxPQUFPLENBQUMsR0FBRyxFQUFFLEdBQUcsRUFBRSxDQUFDO1FBQ3ZCLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ2YsQ0FBQztJQUNMLGFBQUM7QUFBRCxDQUFDLEFBVkwsSUFVSztBQVZRLHdCQUFNO0FBV2Y7SUFTSSxnQkFDVyxDQUFhLEVBQ2IsQ0FBYSxFQUNiLENBQWE7UUFGYixrQkFBQSxFQUFBLEtBQWE7UUFDYixrQkFBQSxFQUFBLEtBQWE7UUFDYixrQkFBQSxFQUFBLEtBQWE7UUFGYixNQUFDLEdBQUQsQ0FBQyxDQUFZO1FBQ2IsTUFBQyxHQUFELENBQUMsQ0FBWTtRQUNiLE1BQUMsR0FBRCxDQUFDLENBQVk7SUFBSSxDQUFDO0lBQ2pDLGFBQUM7QUFBRCxDQUFDLEFBYkQsSUFhQztBQWJZLHdCQUFNO0FBY25CO0lBTUksa0JBQW1CLEtBQWUsRUFBUyxLQUFlLEVBQVMsZUFBMkI7UUFBOUYsaUJBYUM7UUFia0UsZ0NBQUEsRUFBQSxtQkFB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","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nfunction unionCount(a, b) {\n    var u = {};\n    for (var i in a)\n        u[i] = {};\n    for (var i in b)\n        u[i] = {};\n    return Object.keys(u).length;\n}\nfunction intersectionCount(a, b) {\n    var n = 0;\n    for (var i in a)\n        if (typeof b[i] !== 'undefined')\n            ++n;\n    return n;\n}\nfunction getNeighbours(links, la) {\n    var neighbours = {};\n    var addNeighbours = function (u, v) {\n        if (typeof neighbours[u] === 'undefined')\n            neighbours[u] = {};\n        neighbours[u][v] = {};\n    };\n    links.forEach(function (e) {\n        var u = la.getSourceIndex(e), v = la.getTargetIndex(e);\n        addNeighbours(u, v);\n        addNeighbours(v, u);\n    });\n    return neighbours;\n}\nfunction computeLinkLengths(links, w, f, la) {\n    var neighbours = getNeighbours(links, la);\n    links.forEach(function (l) {\n        var a = neighbours[la.getSourceIndex(l)];\n        var b = neighbours[la.getTargetIndex(l)];\n        la.setLength(l, 1 + w * f(a, b));\n    });\n}\nfunction symmetricDiffLinkLengths(links, la, w) {\n    if (w === void 0) { w = 1; }\n    computeLinkLengths(links, w, function (a, b) { return Math.sqrt(unionCount(a, b) - intersectionCount(a, b)); }, la);\n}\nexports.symmetricDiffLinkLengths = symmetricDiffLinkLengths;\nfunction jaccardLinkLengths(links, la, w) {\n    if (w === void 0) { w = 1; }\n    computeLinkLengths(links, w, function (a, b) {\n        return Math.min(Object.keys(a).length, Object.keys(b).length) < 1.1 ? 0 : intersectionCount(a, b) / unionCount(a, b);\n    }, la);\n}\nexports.jaccardLinkLengths = jaccardLinkLengths;\nfunction generateDirectedEdgeConstraints(n, links, axis, la) {\n    var components = stronglyConnectedComponents(n, links, la);\n    var nodes = {};\n    components.forEach(function (c, i) {\n        return c.forEach(function (v) { return nodes[v] = i; });\n    });\n    var constraints = [];\n    links.forEach(function (l) {\n        var ui = la.getSourceIndex(l), vi = la.getTargetIndex(l), u = nodes[ui], v = nodes[vi];\n        if (u !== v) {\n            constraints.push({\n                axis: axis,\n                left: ui,\n                right: vi,\n                gap: la.getMinSeparation(l)\n            });\n        }\n    });\n    return constraints;\n}\nexports.generateDirectedEdgeConstraints = generateDirectedEdgeConstraints;\nfunction stronglyConnectedComponents(numVertices, edges, la) {\n    var nodes = [];\n    var index = 0;\n    var stack = [];\n    var components = [];\n    function strongConnect(v) {\n        v.index = v.lowlink = index++;\n        stack.push(v);\n        v.onStack = true;\n        for (var _i = 0, _a = v.out; _i < _a.length; _i++) {\n            var w = _a[_i];\n            if (typeof w.index === 'undefined') {\n                strongConnect(w);\n                v.lowlink = Math.min(v.lowlink, w.lowlink);\n            }\n            else if (w.onStack) {\n                v.lowlink = Math.min(v.lowlink, w.index);\n            }\n        }\n        if (v.lowlink === v.index) {\n            var component = [];\n            while (stack.length) {\n                w = stack.pop();\n                w.onStack = false;\n                component.push(w);\n                if (w === v)\n                    break;\n            }\n            components.push(component.map(function (v) { return v.id; }));\n        }\n    }\n    for (var i = 0; i < numVertices; i++) {\n        nodes.push({ id: i, out: [] });\n    }\n    for (var _i = 0, edges_1 = edges; _i < edges_1.length; _i++) {\n        var e = edges_1[_i];\n        var v_1 = nodes[la.getSourceIndex(e)], w = nodes[la.getTargetIndex(e)];\n        v_1.out.push(w);\n    }\n    for (var _a = 0, nodes_1 = nodes; _a < nodes_1.length; _a++) {\n        var v = nodes_1[_a];\n        if (typeof v.index === 'undefined')\n            strongConnect(v);\n    }\n    return components;\n}\nexports.stronglyConnectedComponents = stronglyConnectedComponents;\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlua2xlbmd0aHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9XZWJDb2xhL3NyYy9saW5rbGVuZ3Rocy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQVVJLFNBQVMsVUFBVSxDQUFDLENBQU0sRUFBRSxDQUFNO0lBQzlCLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztJQUNYLEtBQUssSUFBSSxDQUFDLElBQUksQ0FBQztRQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxFQUFFLENBQUM7SUFDM0IsS0FBSyxJQUFJLENBQUMsSUFBSSxDQUFDO1FBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLEVBQUUsQ0FBQztJQUMzQixPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDO0FBQ2pDLENBQUM7QUFHRCxTQUFTLGlCQUFpQixDQUFDLENBQVcsRUFBRSxDQUFXO0lBQy9DLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNWLEtBQUssSUFBSSxDQUFDLElBQUksQ0FBQztRQUFFLElBQUksT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssV0FBVztZQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3RELE9BQU8sQ0FBQyxDQUFDO0FBQ2IsQ0FBQztBQUVELFNBQVMsYUFBYSxDQUFPLEtBQWEsRUFBRSxFQUFzQjtJQUM5RCxJQUFJLFVBQVUsR0FBRyxFQUFFLENBQUM7SUFDcEIsSUFBSSxhQUFhLEdBQUcsVUFBQyxDQUFDLEVBQUUsQ0FBQztRQUNyQixJQUFJLE9BQU8sVUFBVSxDQUFDLENBQUMsQ0FBQyxLQUFLLFdBQVc7WUFDcEMsVUFBVSxDQUFDLENBQUMsQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUN2QixVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxDQUFDO0lBQzFCLENBQUMsQ0FBQztJQUNGLEtBQUssQ0FBQyxPQUFPLENBQUMsVUFBQSxDQUFDO1FBQ1gs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","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar PowerEdge = (function () {\n    function PowerEdge(source, target, type) {\n        this.source = source;\n        this.target = target;\n        this.type = type;\n    }\n    return PowerEdge;\n}());\nexports.PowerEdge = PowerEdge;\nvar Configuration = (function () {\n    function Configuration(n, edges, linkAccessor, rootGroup) {\n        var _this = this;\n        this.linkAccessor = linkAccessor;\n        this.modules = new Array(n);\n        this.roots = [];\n        if (rootGroup) {\n            this.initModulesFromGroup(rootGroup);\n        }\n        else {\n            this.roots.push(new ModuleSet());\n            for (var i = 0; i < n; ++i)\n                this.roots[0].add(this.modules[i] = new Module(i));\n        }\n        this.R = edges.length;\n        edges.forEach(function (e) {\n            var s = _this.modules[linkAccessor.getSourceIndex(e)], t = _this.modules[linkAccessor.getTargetIndex(e)], type = linkAccessor.getType(e);\n            s.outgoing.add(type, t);\n            t.incoming.add(type, s);\n        });\n    }\n    Configuration.prototype.initModulesFromGroup = function (group) {\n        var moduleSet = new ModuleSet();\n        this.roots.push(moduleSet);\n        for (var i = 0; i < group.leaves.length; ++i) {\n            var node = group.leaves[i];\n            var module = new Module(node.id);\n            this.modules[node.id] = module;\n            moduleSet.add(module);\n        }\n        if (group.groups) {\n            for (var j = 0; j < group.groups.length; ++j) {\n                var child = group.groups[j];\n                var definition = {};\n                for (var prop in child)\n                    if (prop !== \"leaves\" && prop !== \"groups\" && child.hasOwnProperty(prop))\n                        definition[prop] = child[prop];\n                moduleSet.add(new Module(-1 - j, new LinkSets(), new LinkSets(), this.initModulesFromGroup(child), definition));\n            }\n        }\n        return moduleSet;\n    };\n    Configuration.prototype.merge = function (a, b, k) {\n        if (k === void 0) { k = 0; }\n        var inInt = a.incoming.intersection(b.incoming), outInt = a.outgoing.intersection(b.outgoing);\n        var children = new ModuleSet();\n        children.add(a);\n        children.add(b);\n        var m = new Module(this.modules.length, outInt, inInt, children);\n        this.modules.push(m);\n        var update = function (s, i, o) {\n            s.forAll(function (ms, linktype) {\n                ms.forAll(function (n) {\n                    var nls = n[i];\n                    nls.add(linktype, m);\n                    nls.remove(linktype, a);\n                    nls.remove(linktype, b);\n                    a[o].remove(linktype, n);\n                    b[o].remove(linktype, n);\n                });\n            });\n        };\n        update(outInt, \"incoming\", \"outgoing\");\n        update(inInt, \"outgoing\", \"incoming\");\n        this.R -= inInt.count() + outInt.count();\n        this.roots[k].remove(a);\n        this.roots[k].remove(b);\n        this.roots[k].add(m);\n        return m;\n    };\n    Configuration.prototype.rootMerges = function (k) {\n        if (k === void 0) { k = 0; }\n        var rs = this.roots[k].modules();\n        var n = rs.length;\n        var merges = new Array(n * (n - 1));\n        var ctr = 0;\n        for (var i = 0, i_ = n - 1; i < i_; ++i) {\n            for (var j = i + 1; j < n; ++j) {\n                var a = rs[i], b = rs[j];\n                merges[ctr] = { id: ctr, nEdges: this.nEdges(a, b), a: a, b: b };\n                ctr++;\n            }\n        }\n        return merges;\n    };\n    Configuration.prototype.greedyMerge = function () {\n        for (var i = 0; i < this.roots.length; ++i) {\n            if (this.roots[i].modules().length < 2)\n                continue;\n            var ms = this.rootMerges(i).sort(function (a, b) { return a.nEdges == b.nEdges ? a.id - b.id : a.nEdges - b.nEdges; });\n            var m = ms[0];\n            if (m.nEdges >= this.R)\n                continue;\n            this.merge(m.a, m.b, i);\n            return true;\n        }\n    };\n    Configuration.prototype.nEdges = function (a, b) {\n        var inInt = a.incoming.intersection(b.incoming), outInt = a.outgoing.intersection(b.outgoing);\n        return this.R - inInt.count() - outInt.count();\n    };\n    Configuration.prototype.getGroupHierarchy = function (retargetedEdges) {\n        var _this = this;\n        var groups = [];\n        var root = {};\n        toGroups(this.roots[0], root, groups);\n        var es = this.allEdges();\n        es.forEach(function (e) {\n            var a = _this.modules[e.source];\n            var b = _this.modules[e.target];\n            retargetedEdges.push(new PowerEdge(typeof a.gid === \"undefined\" ? e.source : groups[a.gid], typeof b.gid === \"undefined\" ? e.target : groups[b.gid], e.type));\n        });\n        return groups;\n    };\n    Configuration.prototype.allEdges = function () {\n        var es = [];\n        Configuration.getEdges(this.roots[0], es);\n        return es;\n    };\n    Configuration.getEdges = function (modules, es) {\n        modules.forAll(function (m) {\n            m.getEdges(es);\n            Configuration.getEdges(m.children, es);\n        });\n    };\n    return Configuration;\n}());\nexports.Configuration = Configuration;\nfunction toGroups(modules, group, groups) {\n    modules.forAll(function (m) {\n        if (m.isLeaf()) {\n            if (!group.leaves)\n                group.leaves = [];\n            group.leaves.push(m.id);\n        }\n        else {\n            var g = group;\n            m.gid = groups.length;\n            if (!m.isIsland() || m.isPredefined()) {\n                g = { id: m.gid };\n                if (m.isPredefined())\n                    for (var prop in m.definition)\n                        g[prop] = m.definition[prop];\n                if (!group.groups)\n                    group.groups = [];\n                group.groups.push(m.gid);\n                groups.push(g);\n            }\n            toGroups(m.children, g, groups);\n        }\n    });\n}\nvar Module = (function () {\n    function Module(id, outgoing, incoming, children, definition) {\n        if (outgoing === void 0) { outgoing = new LinkSets(); }\n        if (incoming === void 0) { incoming = new LinkSets(); }\n        if (children === void 0) { children = new ModuleSet(); }\n        this.id = id;\n        this.outgoing = outgoing;\n        this.incoming = incoming;\n        this.children = children;\n        this.definition = definition;\n    }\n    Module.prototype.getEdges = function (es) {\n        var _this = this;\n        this.outgoing.forAll(function (ms, edgetype) {\n            ms.forAll(function (target) {\n                es.push(new PowerEdge(_this.id, target.id, edgetype));\n            });\n        });\n    };\n    Module.prototype.isLeaf = function () {\n        return this.children.count() === 0;\n    };\n    Module.prototype.isIsland = function () {\n        return this.outgoing.count() === 0 && this.incoming.count() === 0;\n    };\n    Module.prototype.isPredefined = function () {\n        return typeof this.definition !== \"undefined\";\n    };\n    return Module;\n}());\nexports.Module = Module;\nfunction intersection(m, n) {\n    var i = {};\n    for (var v in m)\n        if (v in n)\n            i[v] = m[v];\n    return i;\n}\nvar ModuleSet = (function () {\n    function ModuleSet() {\n        this.table = {};\n    }\n    ModuleSet.prototype.count = function () {\n        return Object.keys(this.table).length;\n    };\n    ModuleSet.prototype.intersection = function (other) {\n        var result = new ModuleSet();\n        result.table = intersection(this.table, other.table);\n        return result;\n    };\n    ModuleSet.prototype.intersectionCount = function (other) {\n        return this.intersection(other).count();\n    };\n    ModuleSet.prototype.contains = function (id) {\n        return id in this.table;\n    };\n    ModuleSet.prototype.add = function (m) {\n        this.table[m.id] = m;\n    };\n    ModuleSet.prototype.remove = function (m) {\n        delete this.table[m.id];\n    };\n    ModuleSet.prototype.forAll = function (f) {\n        for (var mid in this.table) {\n            f(this.table[mid]);\n        }\n    };\n    ModuleSet.prototype.modules = function () {\n        var vs = [];\n        this.forAll(function (m) {\n            if (!m.isPredefined())\n                vs.push(m);\n        });\n        return vs;\n    };\n    return ModuleSet;\n}());\nexports.ModuleSet = ModuleSet;\nvar LinkSets = (function () {\n    function LinkSets() {\n        this.sets = {};\n        this.n = 0;\n    }\n    LinkSets.prototype.count = function () {\n        return this.n;\n    };\n    LinkSets.prototype.contains = function (id) {\n        var result = false;\n        this.forAllModules(function (m) {\n            if (!result && m.id == id) {\n                result = true;\n            }\n        });\n        return result;\n    };\n    LinkSets.prototype.add = function (linktype, m) {\n        var s = linktype in this.sets ? this.sets[linktype] : this.sets[linktype] = new ModuleSet();\n        s.add(m);\n        ++this.n;\n    };\n    LinkSets.prototype.remove = function (linktype, m) {\n        var ms = this.sets[linktype];\n        ms.remove(m);\n        if (ms.count() === 0) {\n            delete this.sets[linktype];\n        }\n        --this.n;\n    };\n    LinkSets.prototype.forAll = function (f) {\n        for (var linktype in this.sets) {\n            f(this.sets[linktype], Number(linktype));\n        }\n    };\n    LinkSets.prototype.forAllModules = function (f) {\n        this.forAll(function (ms, lt) { return ms.forAll(f); });\n    };\n    LinkSets.prototype.intersection = function (other) {\n        var result = new LinkSets();\n        this.forAll(function (ms, lt) {\n            if (lt in other.sets) {\n                var i = ms.intersection(other.sets[lt]), n = i.count();\n                if (n > 0) {\n                    result.sets[lt] = i;\n                    result.n += n;\n                }\n            }\n        });\n        return result;\n    };\n    return LinkSets;\n}());\nexports.LinkSets = LinkSets;\nfunction intersectionCount(m, n) {\n    return Object.keys(intersection(m, n)).length;\n}\nfunction getGroups(nodes, links, la, rootGroup) {\n    var n = nodes.length, c = new Configuration(n, links, la, rootGroup);\n    while (c.greedyMerge())\n        ;\n    var powerEdges = [];\n    var g = c.getGroupHierarchy(powerEdges);\n    powerEdges.forEach(function (e) {\n        var f = function (end) {\n            var g = e[end];\n            if (typeof g == \"number\")\n                e[end] = nodes[g];\n        };\n        f(\"source\");\n        f(\"target\");\n    });\n    return { groups: g, powerEdges: powerEdges };\n}\nexports.getGroups = getGroups;\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"powergraph.js","sourceRoot":"","sources":["../../WebCola/src/powergraph.ts"],"names":[],"mappings":";;AAOI;IACI,mBACW,MAAW,EACX,MAAW,EACX,IAAY;QAFZ,WAAM,GAAN,MAAM,CAAK;QACX,WAAM,GAAN,MAAM,CAAK;QACX,SAAI,GAAJ,IAAI,CAAQ;IAAI,CAAC;IAChC,gBAAC;AAAD,CAAC,AALD,IAKC;AALY,8BAAS;AAOtB;IASI,uBAAY,CAAS,EAAE,KAAa,EAAU,YAAoC,EAAE,SAAiB;QAArG,iBAkBC;QAlB6C,iBAAY,GAAZ,YAAY,CAAwB;QAC9E,IAAI,CAAC,OAAO,GAAG,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC;QAC5B,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAChB,IAAI,SAAS,EAAE;YACX,IAAI,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC;SACxC;aAAM;YACH,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,SAAS,EAAE,CAAC,CAAC;YACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;gBACtB,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;SAC1D;QACD,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC;QACtB,KAAK,CAAC,OAAO,CAAC,UAAA,CAAC;YACX,IAAI,CAAC,GAAG,KAAI,CAAC,OAAO,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,EAChD,CAAC,GAAG,KAAI,CAAC,OAAO,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,EAChD,IAAI,GAAG,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YACnC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YACxB,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;QAC5B,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,4CAAoB,GAA5B,UAA6B,KAAK;QAC9B,IAAI,SAAS,GAAG,IAAI,SAAS,EAAE,CAAC;QAChC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC3B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;YAC1C,IAAI,IAAI,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YAC3B,IAAI,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACjC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC;YAC/B,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;SACzB;QACD,IAAI,KAAK,CAAC,MAAM,EAAE;YACd,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;gBAC1C,IAAI,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;gBAE5B,IAAI,UAAU,GAAG,EAAE,CAAC;gBACpB,KAAK,IAAI,IAAI,IAAI,KAAK;oBAClB,IAAI,IAAI,KAAK,QAAQ,IAAI,IAAI,KAAK,QAAQ,IAAI,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC;wBACpE,UAAU,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;gBAEvC,SAAS,CAAC,GAAG,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,GAAC,CAAC,EAAE,IAAI,QAAQ,EAAE,EAAE,IAAI,QAAQ,EAAE,EAAE,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC;aACjH;SACJ;QACD,OAAO,SAAS,CAAC;IACpB,CAAC;IAGF,6BAAK,GAAL,UAAM,CAAS,EAAE,CAAS,EAAE,CAAa;QAAb,kBAAA,EAAA,KAAa;QACrC,IAAI,KAAK,GAAG,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,EAC3C,MAAM,GAAG,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;QACjD,IAAI,QAAQ,GAAG,IAAI,SAAS,EAAE,CAAC;QAC/B,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAChB,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAChB,IAAI,CAAC,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;QACjE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACrB,IAAI,MAAM,GAAG,UAAC,CAAW,EAAE,CAAS,EAAE,CAAS;YAC3C,CAAC,CAAC,MAAM,CAAC,UAAC,EAAE,EAAE,QAAQ;gBAClB,EAAE,CAAC,MAAM,CAAC,UAAA,CAAC;oBACP,IAAI,GAAG,GAAa,CAAC,CAAC,CAAC,CAAC,CAAC;oBACzB,GAAG,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;oBACrB,GAAG,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;oBACxB,GAAG,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;oBACb,CAAC,CAAC,CAAC,CAAE,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;oBAC1B,CAAC,CAAC,CAAC,CAAE,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;gBACzC,CAAC,CAAC,CAAC;YACP,CAAC,CAAC,CAAC;QACP,CAAC,CAAC;QACF,MAAM,CAAC,MAAM,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;QACvC,MAAM,CAAC,KAAK,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;QACtC,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,KAAK,EAAE,GAAG,MAAM,CAAC,KAAK,EAAE,CAAC;QACzC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACxB,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACxB,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACrB,OAAO,CAAC,CAAC;IACb,CAAC;IAEO,kCAAU,GAAlB,UAAmB,CAAa;QAAb,kBAAA,EAAA,KAAa;QAM5B,IAAI,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;QACjC,IAAI,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC;QAClB,IAAI,MAAM,GAAG,IAAI,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACpC,IAAI,GAAG,GAAG,CAAC,CAAC;QACZ,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,EAAE,CAAC,EAAE;YACrC,KAAK,IAAI,CAAC,GAAG,CAAC,GAAC,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE;gBAC1B,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;gBACzB,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;gBACjE,GAAG,EAAE,CAAC;aACT;SACJ;QACD,OAAO,MAAM,CAAC;IAClB,CAAC;IAED,mCAAW,GAAX;QACI,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;YAExC,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,MAAM,GAAG,CAAC;gBAAE,SAAS;YAGjD,IAAI,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,MAAM,EAAxD,CAAwD,CAAC,CAAC;YACrG,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;YACd,IAAI,CAAC,CAAC,MAAM,IAAI,IAAI,CAAC,CAAC;gBAAE,SAAS;YACjC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YACxB,OAAO,IAAI,CAAC;SACf;IACL,CAAC;IAEO,8BAAM,GAAd,UAAe,CAAS,EAAE,CAAS;QAC/B,IAAI,KAAK,GAAG,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,EAC3C,MAAM,GAAG,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;QACjD,OAAO,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,KAAK,EAAE,GAAG,MAAM,CAAC,KAAK,EAAE,CAAC;IACnD,CAAC;IAED,yCAAiB,GAAjB,UAAkB,eAA4B;QAA9C,iBAeC;QAdG,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,IAAI,IAAI,GAAG,EAAE,CAAC;QACd,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;QACtC,IAAI,EAAE,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QACzB,EAAE,CAAC,OAAO,CAAC,UAAA,CAAC;YACR,IAAI,CAAC,GAAG,KAAI,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;YAC/B,IAAI,CAAC,GAAG,KAAI,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;YAC/B,eAAe,CAAC,IAAI,CAAC,IAAI,SAAS,CAC9B,OAAO,CAAC,CAAC,GAAG,KAAK,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,EACvD,OAAO,CAAC,CAAC,GAAG,KAAK,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,EACvD,CAAC,CAAC,IAAI,CACT,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAClB,CAAC;IAED,gCAAQ,GAAR;QACI,IAAI,EAAE,GAAG,EAAE,CAAC;QACZ,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC1C,OAAO,EAAE,CAAC;IACd,CAAC;IAEM,sBAAQ,GAAf,UAAgB,OAAkB,EAAE,EAAe;QAC/C,OAAO,CAAC,MAAM,CAAC,UAAA,CAAC;YACZ,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YACf,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;IACP,CAAC;IACL,oBAAC;AAAD,CAAC,AAxJD,IAwJC;AAxJY,sCAAa;AA0J1B,SAAS,QAAQ,CAAC,OAAkB,EAAE,KAAK,EAAE,MAAM;IAC/C,OAAO,CAAC,MAAM,CAAC,UAAA,CAAC;QACZ,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;YACZ,IAAI,CAAC,KAAK,CAAC,MAAM;gBAAE,KAAK,CAAC,MAAM,GAAG,EAAE,CAAC;YACrC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;SAC3B;aAAM;YACH,IAAI,CAAC,GAAG,KAAK,CAAC;YACd,CAAC,CAAC,GAAG,GAAG,MAAM,CAAC,MAAM,CAAC;YACtB,IAAI,CAAC,CAAC,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,YAAY,EAAE,EAAE;gBACnC,CAAC,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC;gBAClB,IAAI,CAAC,CAAC,YAAY,EAAE;oBAEhB,KAAK,IAAI,IAAI,IAAI,CAAC,CAAC,UAAU;wBACzB,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;gBACrC,IAAI,CAAC,KAAK,CAAC,MAAM;oBAAE,KAAK,CAAC,MAAM,GAAG,EAAE,CAAC;gBACrC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;gBACzB,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aAClB;YACD,QAAQ,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC;SACnC;IACL,CAAC,CAAC,CAAC;AACP,CAAC;AAED;IAGI,gBACW,EAAU,EACV,QAAmC,EACnC,QAAmC,EACnC,QAAqC,EACrC,UAAgB;QAHhB,yBAAA,EAAA,eAAyB,QAAQ,EAAE;QACnC,yBAAA,EAAA,eAAyB,QAAQ,EAAE;QACnC,yBAAA,EAAA,eAA0B,SAAS,EAAE;QAHrC,OAAE,GAAF,EAAE,CAAQ;QACV,aAAQ,GAAR,QAAQ,CAA2B;QACnC,aAAQ,GAAR,QAAQ,CAA2B;QACnC,aAAQ,GAAR,QAAQ,CAA6B;QACrC,eAAU,GAAV,UAAU,CAAM;IAAI,CAAC;IAEhC,yBAAQ,GAAR,UAAS,EAAe;QAAxB,iBAMC;QALG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAC,EAAE,EAAE,QAAQ;YAC9B,EAAE,CAAC,MAAM,CAAC,UAAA,MAAM;gBACZ,EAAE,CAAC,IAAI,CAAC,IAAI,SAAS,CAAC,KAAI,CAAC,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC,CAAC;YACzD,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IAED,uBAAM,GAAN;QACI,OAAO,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IACvC,CAAC;IAED,yBAAQ,GAAR;QACI,OAAO,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IACtE,CAAC;IAED,6BAAY,GAAZ;QACI,OAAO,OAAO,IAAI,CAAC,UAAU,KAAK,WAAW,CAAC;IAClD,CAAC;IACL,aAAC;AAAD,CAAC,AA7BD,IA6BC;AA7BY,wBAAM;AA+BnB,SAAS,YAAY,CAAC,CAAM,EAAE,CAAM;IAChC,IAAI,CAAC,GAAG,EAAE,CAAC;IACX,KAAK,IAAI,CAAC,IAAI,CAAC;QAAE,IAAI,CAAC,IAAI,CAAC;YAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACzC,OAAO,CAAC,CAAC;AACb,CAAC;AAED;IAAA;QACI,UAAK,GAAQ,EAAE,CAAC;IAkCpB,CAAC;IAjCG,yBAAK,GAAL;QACI,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC;IAC1C,CAAC;IACD,gCAAY,GAAZ,UAAa,KAAgB;QACzB,IAAI,MAAM,GAAG,IAAI,SAAS,EAAE,CAAC;QAC7B,MAAM,CAAC,KAAK,GAAG,YAAY,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;QACrD,OAAO,MAAM,CAAC;IAClB,CAAC;IACD,qCAAiB,GAAjB,UAAkB,KAAgB;QAC9B,OAAO,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,CAAC;IAC5C,CAAC;IACD,4BAAQ,GAAR,UAAS,EAAU;QACf,OAAO,EAAE,IAAI,IAAI,CAAC,KAAK,CAAC;IAC5B,CAAC;IACD,uBAAG,GAAH,UAAI,CAAS;QACT,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;IACzB,CAAC;IACD,0BAAM,GAAN,UAAO,CAAS;QACZ,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IAC5B,CAAC;IACD,0BAAM,GAAN,UAAO,CAAsB;QACzB,KAAK,IAAI,GAAG,IAAI,IAAI,CAAC,KAAK,EAAE;YACxB,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;SACtB;IACL,CAAC;IACD,2BAAO,GAAP;QACI,IAAI,EAAE,GAAG,EAAE,CAAC;QACZ,IAAI,CAAC,MAAM,CAAC,UAAA,CAAC;YACT,IAAI,CAAC,CAAC,CAAC,YAAY,EAAE;gBACjB,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACnB,CAAC,CAAC,CAAC;QACH,OAAO,EAAE,CAAC;IACd,CAAC;IACL,gBAAC;AAAD,CAAC,AAnCD,IAmCC;AAnCY,8BAAS;AAqCtB;IAAA;QACI,SAAI,GAAQ,EAAE,CAAC;QACf,MAAC,GAAW,CAAC,CAAC;IAgDlB,CAAC;IA/CG,wBAAK,GAAL;QACI,OAAO,IAAI,CAAC,CAAC,CAAC;IAClB,CAAC;IACD,2BAAQ,GAAR,UAAS,EAAU;QACf,IAAI,MAAM,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,aAAa,CAAC,UAAA,CAAC;YAChB,IAAI,CAAC,MAAM,IAAI,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE;gBACvB,MAAM,GAAG,IAAI,CAAC;aACjB;QACL,CAAC,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAClB,CAAC;IACD,sBAAG,GAAH,UAAI,QAAgB,EAAE,CAAS;QAC3B,IAAI,CAAC,GAAc,QAAQ,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,IAAI,SAAS,EAAE,CAAC;QACvG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACT,EAAE,IAAI,CAAC,CAAC,CAAC;IACb,CAAC;IACD,yBAAM,GAAN,UAAO,QAAgB,EAAE,CAAS;QAC9B,IAAI,EAAE,GAAc,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACxC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACb,IAAI,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,EAAE;YAClB,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SAC9B;QACD,EAAE,IAAI,CAAC,CAAC,CAAC;IACb,CAAC;IACD,yBAAM,GAAN,UAAO,CAA4C;QAC/C,KAAK,IAAI,QAAQ,IAAI,IAAI,CAAC,IAAI,EAAE;YAC5B,CAAC,CAAY,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC;SACvD;IACL,CAAC;IACD,gCAAa,GAAb,UAAc,CAAsB;QAChC,IAAI,CAAC,MAAM,CAAC,UAAC,EAAE,EAAE,EAAE,IAAK,OAAA,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAZ,CAAY,CAAC,CAAC;IAC1C,CAAC;IACD,+BAAY,GAAZ,UAAa,KAAe;QACxB,IAAI,MAAM,GAAa,IAAI,QAAQ,EAAE,CAAC;QACtC,IAAI,CAAC,MAAM,CAAC,UAAC,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,IAAI,KAAK,CAAC,IAAI,EAAE;gBAClB,IAAI,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EACnC,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC;gBAClB,IAAI,CAAC,GAAG,CAAC,EAAE;oBACP,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;oBACpB,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC;iBACjB;aACJ;QACL,CAAC,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAClB,CAAC;IACL,eAAC;AAAD,CAAC,AAlDD,IAkDC;AAlDY,4BAAQ;AAoDrB,SAAS,iBAAiB,CAAC,CAAM,EAAE,CAAM;IACrC,OAAO,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAA;AACjD,CAAC;AAED,SAAgB,SAAS,CAAO,KAAY,EAAE,KAAa,EAAE,EAA0B,EAAE,SAAiB;IACtG,IAAI,CAAC,GAAG,KAAK,CAAC,MAAM,EAChB,CAAC,GAAG,IAAI,aAAa,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,SAAS,CAAC,CAAC;IACnD,OAAO,CAAC,CAAC,WAAW,EAAE;QAAC,CAAC;IACxB,IAAI,UAAU,GAAgB,EAAE,CAAC;IACjC,IAAI,CAAC,GAAG,CAAC,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;IACxC,UAAU,CAAC,OAAO,CAAC,UAAU,CAAC;QAC1B,IAAI,CAAC,GAAG,UAAC,GAAG;YACR,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;YACf,IAAI,OAAO,CAAC,IAAI,QAAQ;gBAAE,CAAC,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QAChD,CAAC,CAAC;QACF,CAAC,CAAC,QAAQ,CAAC,CAAC;QACZ,CAAC,CAAC,QAAQ,CAAC,CAAC;IAChB,CAAC,CAAC,CAAC;IACH,OAAO,EAAE,MAAM,EAAE,CAAC,EAAE,UAAU,EAAE,UAAU,EAAE,CAAC;AACjD,CAAC;AAfD,8BAeC"}","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar PairingHeap = (function () {\n    function PairingHeap(elem) {\n        this.elem = elem;\n        this.subheaps = [];\n    }\n    PairingHeap.prototype.toString = function (selector) {\n        var str = \"\", needComma = false;\n        for (var i = 0; i < this.subheaps.length; ++i) {\n            var subheap = this.subheaps[i];\n            if (!subheap.elem) {\n                needComma = false;\n                continue;\n            }\n            if (needComma) {\n                str = str + \",\";\n            }\n            str = str + subheap.toString(selector);\n            needComma = true;\n        }\n        if (str !== \"\") {\n            str = \"(\" + str + \")\";\n        }\n        return (this.elem ? selector(this.elem) : \"\") + str;\n    };\n    PairingHeap.prototype.forEach = function (f) {\n        if (!this.empty()) {\n            f(this.elem, this);\n            this.subheaps.forEach(function (s) { return s.forEach(f); });\n        }\n    };\n    PairingHeap.prototype.count = function () {\n        return this.empty() ? 0 : 1 + this.subheaps.reduce(function (n, h) {\n            return n + h.count();\n        }, 0);\n    };\n    PairingHeap.prototype.min = function () {\n        return this.elem;\n    };\n    PairingHeap.prototype.empty = function () {\n        return this.elem == null;\n    };\n    PairingHeap.prototype.contains = function (h) {\n        if (this === h)\n            return true;\n        for (var i = 0; i < this.subheaps.length; i++) {\n            if (this.subheaps[i].contains(h))\n                return true;\n        }\n        return false;\n    };\n    PairingHeap.prototype.isHeap = function (lessThan) {\n        var _this = this;\n        return this.subheaps.every(function (h) { return lessThan(_this.elem, h.elem) && h.isHeap(lessThan); });\n    };\n    PairingHeap.prototype.insert = function (obj, lessThan) {\n        return this.merge(new PairingHeap(obj), lessThan);\n    };\n    PairingHeap.prototype.merge = function (heap2, lessThan) {\n        if (this.empty())\n            return heap2;\n        else if (heap2.empty())\n            return this;\n        else if (lessThan(this.elem, heap2.elem)) {\n            this.subheaps.push(heap2);\n            return this;\n        }\n        else {\n            heap2.subheaps.push(this);\n            return heap2;\n        }\n    };\n    PairingHeap.prototype.removeMin = function (lessThan) {\n        if (this.empty())\n            return null;\n        else\n            return this.mergePairs(lessThan);\n    };\n    PairingHeap.prototype.mergePairs = function (lessThan) {\n        if (this.subheaps.length == 0)\n            return new PairingHeap(null);\n        else if (this.subheaps.length == 1) {\n            return this.subheaps[0];\n        }\n        else {\n            var firstPair = this.subheaps.pop().merge(this.subheaps.pop(), lessThan);\n            var remaining = this.mergePairs(lessThan);\n            return firstPair.merge(remaining, lessThan);\n        }\n    };\n    PairingHeap.prototype.decreaseKey = function (subheap, newValue, setHeapNode, lessThan) {\n        var newHeap = subheap.removeMin(lessThan);\n        subheap.elem = newHeap.elem;\n        subheap.subheaps = newHeap.subheaps;\n        if (setHeapNode !== null && newHeap.elem !== null) {\n            setHeapNode(subheap.elem, subheap);\n        }\n        var pairingNode = new PairingHeap(newValue);\n        if (setHeapNode !== null) {\n            setHeapNode(newValue, pairingNode);\n        }\n        return this.merge(pairingNode, lessThan);\n    };\n    return PairingHeap;\n}());\nexports.PairingHeap = PairingHeap;\nvar PriorityQueue = (function () {\n    function PriorityQueue(lessThan) {\n        this.lessThan = lessThan;\n    }\n    PriorityQueue.prototype.top = function () {\n        if (this.empty()) {\n            return null;\n        }\n        return this.root.elem;\n    };\n    PriorityQueue.prototype.push = function () {\n        var args = [];\n        for (var _i = 0; _i < arguments.length; _i++) {\n            args[_i] = arguments[_i];\n        }\n        var pairingNode;\n        for (var i = 0, arg; arg = args[i]; ++i) {\n            pairingNode = new PairingHeap(arg);\n            this.root = this.empty() ?\n                pairingNode : this.root.merge(pairingNode, this.lessThan);\n        }\n        return pairingNode;\n    };\n    PriorityQueue.prototype.empty = function () {\n        return !this.root || !this.root.elem;\n    };\n    PriorityQueue.prototype.isHeap = function () {\n        return this.root.isHeap(this.lessThan);\n    };\n    PriorityQueue.prototype.forEach = function (f) {\n        this.root.forEach(f);\n    };\n    PriorityQueue.prototype.pop = function () {\n        if (this.empty()) {\n            return null;\n        }\n        var obj = this.root.min();\n        this.root = this.root.removeMin(this.lessThan);\n        return obj;\n    };\n    PriorityQueue.prototype.reduceKey = function (heapNode, newKey, setHeapNode) {\n        if (setHeapNode === void 0) { setHeapNode = null; }\n        this.root = this.root.decreaseKey(heapNode, newKey, setHeapNode, this.lessThan);\n    };\n    PriorityQueue.prototype.toString = function (selector) {\n        return this.root.toString(selector);\n    };\n    PriorityQueue.prototype.count = function () {\n        return this.root.count();\n    };\n    return PriorityQueue;\n}());\nexports.PriorityQueue = PriorityQueue;\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHF1ZXVlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vV2ViQ29sYS9zcmMvcHF1ZXVlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQ0E7SUFJSSxxQkFBbUIsSUFBTztRQUFQLFNBQUksR0FBSixJQUFJLENBQUc7UUFDdEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDdkIsQ0FBQztJQUVNLDhCQUFRLEdBQWYsVUFBZ0IsUUFBUTtRQUNwQixJQUFJLEdBQUcsR0FBRyxFQUFFLEVBQUUsU0FBUyxHQUFHLEtBQUssQ0FBQztRQUNoQyxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLEVBQUU7WUFDM0MsSUFBSSxPQUFPLEdBQW1CLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDL0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUU7Z0JBQ2YsU0FBUyxHQUFHLEtBQUssQ0FBQztnQkFDbEIsU0FBUzthQUNaO1lBQ0QsSUFBSSxTQUFTLEVBQUU7Z0JBQ1gsR0FBRyxHQUFHLEdBQUcsR0FBRyxHQUFHLENBQUM7YUFDbkI7WUFDRCxHQUFHLEdBQUcsR0FBRyxHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDdkMsU0FBUyxHQUFHLElBQUksQ0FBQztTQUNwQjtRQUNELElBQUksR0FBRyxLQUFLLEVBQUUsRUFBRTtZQUNaLEdBQUcsR0FBRyxHQUFHLEdBQUcsR0FBRyxHQUFHLEdBQUcsQ0FBQztTQUN6QjtRQUNELE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsR0FBRyxHQUFHLENBQUM7SUFDeEQsQ0FBQztJQUVNLDZCQUFPLEdBQWQsVUFBZSxDQUFD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","\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n    var extendStatics = function (d, b) {\n        extendStatics = Object.setPrototypeOf ||\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n            function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n        return extendStatics(d, b);\n    };\n    return function (d, b) {\n        extendStatics(d, b);\n        function __() { this.constructor = d; }\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n    };\n})();\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar TreeBase = (function () {\n    function TreeBase() {\n        this.findIter = function (data) {\n            var res = this._root;\n            var iter = this.iterator();\n            while (res !== null) {\n                var c = this._comparator(data, res.data);\n                if (c === 0) {\n                    iter._cursor = res;\n                    return iter;\n                }\n                else {\n                    iter._ancestors.push(res);\n                    res = res.get_child(c > 0);\n                }\n            }\n            return null;\n        };\n    }\n    TreeBase.prototype.clear = function () {\n        this._root = null;\n        this.size = 0;\n    };\n    ;\n    TreeBase.prototype.find = function (data) {\n        var res = this._root;\n        while (res !== null) {\n            var c = this._comparator(data, res.data);\n            if (c === 0) {\n                return res.data;\n            }\n            else {\n                res = res.get_child(c > 0);\n            }\n        }\n        return null;\n    };\n    ;\n    TreeBase.prototype.lowerBound = function (data) {\n        return this._bound(data, this._comparator);\n    };\n    ;\n    TreeBase.prototype.upperBound = function (data) {\n        var cmp = this._comparator;\n        function reverse_cmp(a, b) {\n            return cmp(b, a);\n        }\n        return this._bound(data, reverse_cmp);\n    };\n    ;\n    TreeBase.prototype.min = function () {\n        var res = this._root;\n        if (res === null) {\n            return null;\n        }\n        while (res.left !== null) {\n            res = res.left;\n        }\n        return res.data;\n    };\n    ;\n    TreeBase.prototype.max = function () {\n        var res = this._root;\n        if (res === null) {\n            return null;\n        }\n        while (res.right !== null) {\n            res = res.right;\n        }\n        return res.data;\n    };\n    ;\n    TreeBase.prototype.iterator = function () {\n        return new Iterator(this);\n    };\n    ;\n    TreeBase.prototype.each = function (cb) {\n        var it = this.iterator(), data;\n        while ((data = it.next()) !== null) {\n            cb(data);\n        }\n    };\n    ;\n    TreeBase.prototype.reach = function (cb) {\n        var it = this.iterator(), data;\n        while ((data = it.prev()) !== null) {\n            cb(data);\n        }\n    };\n    ;\n    TreeBase.prototype._bound = function (data, cmp) {\n        var cur = this._root;\n        var iter = this.iterator();\n        while (cur !== null) {\n            var c = this._comparator(data, cur.data);\n            if (c === 0) {\n                iter._cursor = cur;\n                return iter;\n            }\n            iter._ancestors.push(cur);\n            cur = cur.get_child(c > 0);\n        }\n        for (var i = iter._ancestors.length - 1; i >= 0; --i) {\n            cur = iter._ancestors[i];\n            if (cmp(data, cur.data) > 0) {\n                iter._cursor = cur;\n                iter._ancestors.length = i;\n                return iter;\n            }\n        }\n        iter._ancestors.length = 0;\n        return iter;\n    };\n    ;\n    return TreeBase;\n}());\nexports.TreeBase = TreeBase;\nvar Iterator = (function () {\n    function Iterator(tree) {\n        this._tree = tree;\n        this._ancestors = [];\n        this._cursor = null;\n    }\n    Iterator.prototype.data = function () {\n        return this._cursor !== null ? this._cursor.data : null;\n    };\n    ;\n    Iterator.prototype.next = function () {\n        if (this._cursor === null) {\n            var root = this._tree._root;\n            if (root !== null) {\n                this._minNode(root);\n            }\n        }\n        else {\n            if (this._cursor.right === null) {\n                var save;\n                do {\n                    save = this._cursor;\n                    if (this._ancestors.length) {\n                        this._cursor = this._ancestors.pop();\n                    }\n                    else {\n                        this._cursor = null;\n                        break;\n                    }\n                } while (this._cursor.right === save);\n            }\n            else {\n                this._ancestors.push(this._cursor);\n                this._minNode(this._cursor.right);\n            }\n        }\n        return this._cursor !== null ? this._cursor.data : null;\n    };\n    ;\n    Iterator.prototype.prev = function () {\n        if (this._cursor === null) {\n            var root = this._tree._root;\n            if (root !== null) {\n                this._maxNode(root);\n            }\n        }\n        else {\n            if (this._cursor.left === null) {\n                var save;\n                do {\n                    save = this._cursor;\n                    if (this._ancestors.length) {\n                        this._cursor = this._ancestors.pop();\n                    }\n                    else {\n                        this._cursor = null;\n                        break;\n                    }\n                } while (this._cursor.left === save);\n            }\n            else {\n                this._ancestors.push(this._cursor);\n                this._maxNode(this._cursor.left);\n            }\n        }\n        return this._cursor !== null ? this._cursor.data : null;\n    };\n    ;\n    Iterator.prototype._minNode = function (start) {\n        while (start.left !== null) {\n            this._ancestors.push(start);\n            start = start.left;\n        }\n        this._cursor = start;\n    };\n    ;\n    Iterator.prototype._maxNode = function (start) {\n        while (start.right !== null) {\n            this._ancestors.push(start);\n            start = start.right;\n        }\n        this._cursor = start;\n    };\n    ;\n    return Iterator;\n}());\nexports.Iterator = Iterator;\nvar Node = (function () {\n    function Node(data) {\n        this.data = data;\n        this.left = null;\n        this.right = null;\n        this.red = true;\n    }\n    Node.prototype.get_child = function (dir) {\n        return dir ? this.right : this.left;\n    };\n    ;\n    Node.prototype.set_child = function (dir, val) {\n        if (dir) {\n            this.right = val;\n        }\n        else {\n            this.left = val;\n        }\n    };\n    ;\n    return Node;\n}());\nvar RBTree = (function (_super) {\n    __extends(RBTree, _super);\n    function RBTree(comparator) {\n        var _this = _super.call(this) || this;\n        _this._root = null;\n        _this._comparator = comparator;\n        _this.size = 0;\n        return _this;\n    }\n    RBTree.prototype.insert = function (data) {\n        var ret = false;\n        if (this._root === null) {\n            this._root = new Node(data);\n            ret = true;\n            this.size++;\n        }\n        else {\n            var head = new Node(undefined);\n            var dir = false;\n            var last = false;\n            var gp = null;\n            var ggp = head;\n            var p = null;\n            var node = this._root;\n            ggp.right = this._root;\n            while (true) {\n                if (node === null) {\n                    node = new Node(data);\n                    p.set_child(dir, node);\n                    ret = true;\n                    this.size++;\n                }\n                else if (RBTree.is_red(node.left) && RBTree.is_red(node.right)) {\n                    node.red = true;\n                    node.left.red = false;\n                    node.right.red = false;\n                }\n                if (RBTree.is_red(node) && RBTree.is_red(p)) {\n                    var dir2 = ggp.right === gp;\n                    if (node === p.get_child(last)) {\n                        ggp.set_child(dir2, RBTree.single_rotate(gp, !last));\n                    }\n                    else {\n                        ggp.set_child(dir2, RBTree.double_rotate(gp, !last));\n                    }\n                }\n                var cmp = this._comparator(node.data, data);\n                if (cmp === 0) {\n                    break;\n                }\n                last = dir;\n                dir = cmp < 0;\n                if (gp !== null) {\n                    ggp = gp;\n                }\n                gp = p;\n                p = node;\n                node = node.get_child(dir);\n            }\n            this._root = head.right;\n        }\n        this._root.red = false;\n        return ret;\n    };\n    ;\n    RBTree.prototype.remove = function (data) {\n        if (this._root === null) {\n            return false;\n        }\n        var head = new Node(undefined);\n        var node = head;\n        node.right = this._root;\n        var p = null;\n        var gp = null;\n        var found = null;\n        var dir = true;\n        while (node.get_child(dir) !== null) {\n            var last = dir;\n            gp = p;\n            p = node;\n            node = node.get_child(dir);\n            var cmp = this._comparator(data, node.data);\n            dir = cmp > 0;\n            if (cmp === 0) {\n                found = node;\n            }\n            if (!RBTree.is_red(node) && !RBTree.is_red(node.get_child(dir))) {\n                if (RBTree.is_red(node.get_child(!dir))) {\n                    var sr = RBTree.single_rotate(node, dir);\n                    p.set_child(last, sr);\n                    p = sr;\n                }\n                else if (!RBTree.is_red(node.get_child(!dir))) {\n                    var sibling = p.get_child(!last);\n                    if (sibling !== null) {\n                        if (!RBTree.is_red(sibling.get_child(!last)) && !RBTree.is_red(sibling.get_child(last))) {\n                            p.red = false;\n                            sibling.red = true;\n                            node.red = true;\n                        }\n                        else {\n                            var dir2 = gp.right === p;\n                            if (RBTree.is_red(sibling.get_child(last))) {\n                                gp.set_child(dir2, RBTree.double_rotate(p, last));\n                            }\n                            else if (RBTree.is_red(sibling.get_child(!last))) {\n                                gp.set_child(dir2, RBTree.single_rotate(p, last));\n                            }\n                            var gpc = gp.get_child(dir2);\n                            gpc.red = true;\n                            node.red = true;\n                            gpc.left.red = false;\n                            gpc.right.red = false;\n                        }\n                    }\n                }\n            }\n        }\n        if (found !== null) {\n            found.data = node.data;\n            p.set_child(p.right === node, node.get_child(node.left === null));\n            this.size--;\n        }\n        this._root = head.right;\n        if (this._root !== null) {\n            this._root.red = false;\n        }\n        return found !== null;\n    };\n    ;\n    RBTree.is_red = function (node) {\n        return node !== null && node.red;\n    };\n    RBTree.single_rotate = function (root, dir) {\n        var save = root.get_child(!dir);\n        root.set_child(!dir, save.get_child(dir));\n        save.set_child(dir, root);\n        root.red = true;\n        save.red = false;\n        return save;\n    };\n    RBTree.double_rotate = function (root, dir) {\n        root.set_child(!dir, RBTree.single_rotate(root.get_child(!dir), !dir));\n        return RBTree.single_rotate(root, dir);\n    };\n    return RBTree;\n}(TreeBase));\nexports.RBTree = RBTree;\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rbtree.js","sourceRoot":"","sources":["../../WebCola/src/rbtree.ts"],"names":[],"mappings":"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"}","\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n    var extendStatics = function (d, b) {\n        extendStatics = Object.setPrototypeOf ||\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n            function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n        return extendStatics(d, b);\n    };\n    return function (d, b) {\n        extendStatics(d, b);\n        function __() { this.constructor = d; }\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n    };\n})();\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar vpsc_1 = require(\"./vpsc\");\nvar rbtree_1 = require(\"./rbtree\");\nfunction computeGroupBounds(g) {\n    g.bounds = typeof g.leaves !== \"undefined\" ?\n        g.leaves.reduce(function (r, c) { return c.bounds.union(r); }, Rectangle.empty()) :\n        Rectangle.empty();\n    if (typeof g.groups !== \"undefined\")\n        g.bounds = g.groups.reduce(function (r, c) { return computeGroupBounds(c).union(r); }, g.bounds);\n    g.bounds = g.bounds.inflate(g.padding);\n    return g.bounds;\n}\nexports.computeGroupBounds = computeGroupBounds;\nvar Rectangle = (function () {\n    function Rectangle(x, X, y, Y) {\n        this.x = x;\n        this.X = X;\n        this.y = y;\n        this.Y = Y;\n    }\n    Rectangle.empty = function () { return new Rectangle(Number.POSITIVE_INFINITY, Number.NEGATIVE_INFINITY, Number.POSITIVE_INFINITY, Number.NEGATIVE_INFINITY); };\n    Rectangle.prototype.cx = function () { return (this.x + this.X) / 2; };\n    Rectangle.prototype.cy = function () { return (this.y + this.Y) / 2; };\n    Rectangle.prototype.overlapX = function (r) {\n        var ux = this.cx(), vx = r.cx();\n        if (ux <= vx && r.x < this.X)\n            return this.X - r.x;\n        if (vx <= ux && this.x < r.X)\n            return r.X - this.x;\n        return 0;\n    };\n    Rectangle.prototype.overlapY = function (r) {\n        var uy = this.cy(), vy = r.cy();\n        if (uy <= vy && r.y < this.Y)\n            return this.Y - r.y;\n        if (vy <= uy && this.y < r.Y)\n            return r.Y - this.y;\n        return 0;\n    };\n    Rectangle.prototype.setXCentre = function (cx) {\n        var dx = cx - this.cx();\n        this.x += dx;\n        this.X += dx;\n    };\n    Rectangle.prototype.setYCentre = function (cy) {\n        var dy = cy - this.cy();\n        this.y += dy;\n        this.Y += dy;\n    };\n    Rectangle.prototype.width = function () {\n        return this.X - this.x;\n    };\n    Rectangle.prototype.height = function () {\n        return this.Y - this.y;\n    };\n    Rectangle.prototype.union = function (r) {\n        return new Rectangle(Math.min(this.x, r.x), Math.max(this.X, r.X), Math.min(this.y, r.y), Math.max(this.Y, r.Y));\n    };\n    Rectangle.prototype.lineIntersections = function (x1, y1, x2, y2) {\n        var sides = [[this.x, this.y, this.X, this.y],\n            [this.X, this.y, this.X, this.Y],\n            [this.X, this.Y, this.x, this.Y],\n            [this.x, this.Y, this.x, this.y]];\n        var intersections = [];\n        for (var i = 0; i < 4; ++i) {\n            var r = Rectangle.lineIntersection(x1, y1, x2, y2, sides[i][0], sides[i][1], sides[i][2], sides[i][3]);\n            if (r !== null)\n                intersections.push({ x: r.x, y: r.y });\n        }\n        return intersections;\n    };\n    Rectangle.prototype.rayIntersection = function (x2, y2) {\n        var ints = this.lineIntersections(this.cx(), this.cy(), x2, y2);\n        return ints.length > 0 ? ints[0] : null;\n    };\n    Rectangle.prototype.vertices = function () {\n        return [\n            { x: this.x, y: this.y },\n            { x: this.X, y: this.y },\n            { x: this.X, y: this.Y },\n            { x: this.x, y: this.Y }\n        ];\n    };\n    Rectangle.lineIntersection = function (x1, y1, x2, y2, x3, y3, x4, y4) {\n        var dx12 = x2 - x1, dx34 = x4 - x3, dy12 = y2 - y1, dy34 = y4 - y3, denominator = dy34 * dx12 - dx34 * dy12;\n        if (denominator == 0)\n            return null;\n        var dx31 = x1 - x3, dy31 = y1 - y3, numa = dx34 * dy31 - dy34 * dx31, a = numa / denominator, numb = dx12 * dy31 - dy12 * dx31, b = numb / denominator;\n        if (a >= 0 && a <= 1 && b >= 0 && b <= 1) {\n            return {\n                x: x1 + a * dx12,\n                y: y1 + a * dy12\n            };\n        }\n        return null;\n    };\n    Rectangle.prototype.inflate = function (pad) {\n        return new Rectangle(this.x - pad, this.X + pad, this.y - pad, this.Y + pad);\n    };\n    return Rectangle;\n}());\nexports.Rectangle = Rectangle;\nfunction makeEdgeBetween(source, target, ah) {\n    var si = source.rayIntersection(target.cx(), target.cy()) || { x: source.cx(), y: source.cy() }, ti = target.rayIntersection(source.cx(), source.cy()) || { x: target.cx(), y: target.cy() }, dx = ti.x - si.x, dy = ti.y - si.y, l = Math.sqrt(dx * dx + dy * dy), al = l - ah;\n    return {\n        sourceIntersection: si,\n        targetIntersection: ti,\n        arrowStart: { x: si.x + al * dx / l, y: si.y + al * dy / l }\n    };\n}\nexports.makeEdgeBetween = makeEdgeBetween;\nfunction makeEdgeTo(s, target, ah) {\n    var ti = target.rayIntersection(s.x, s.y);\n    if (!ti)\n        ti = { x: target.cx(), y: target.cy() };\n    var dx = ti.x - s.x, dy = ti.y - s.y, l = Math.sqrt(dx * dx + dy * dy);\n    return { x: ti.x - ah * dx / l, y: ti.y - ah * dy / l };\n}\nexports.makeEdgeTo = makeEdgeTo;\nvar Node = (function () {\n    function Node(v, r, pos) {\n        this.v = v;\n        this.r = r;\n        this.pos = pos;\n        this.prev = makeRBTree();\n        this.next = makeRBTree();\n    }\n    return Node;\n}());\nvar Event = (function () {\n    function Event(isOpen, v, pos) {\n        this.isOpen = isOpen;\n        this.v = v;\n        this.pos = pos;\n    }\n    return Event;\n}());\nfunction compareEvents(a, b) {\n    if (a.pos > b.pos) {\n        return 1;\n    }\n    if (a.pos < b.pos) {\n        return -1;\n    }\n    if (a.isOpen) {\n        return -1;\n    }\n    if (b.isOpen) {\n        return 1;\n    }\n    return 0;\n}\nfunction makeRBTree() {\n    return new rbtree_1.RBTree(function (a, b) { return a.pos - b.pos; });\n}\nvar xRect = {\n    getCentre: function (r) { return r.cx(); },\n    getOpen: function (r) { return r.y; },\n    getClose: function (r) { return r.Y; },\n    getSize: function (r) { return r.width(); },\n    makeRect: function (open, close, center, size) { return new Rectangle(center - size / 2, center + size / 2, open, close); },\n    findNeighbours: findXNeighbours\n};\nvar yRect = {\n    getCentre: function (r) { return r.cy(); },\n    getOpen: function (r) { return r.x; },\n    getClose: function (r) { return r.X; },\n    getSize: function (r) { return r.height(); },\n    makeRect: function (open, close, center, size) { return new Rectangle(open, close, center - size / 2, center + size / 2); },\n    findNeighbours: findYNeighbours\n};\nfunction generateGroupConstraints(root, f, minSep, isContained) {\n    if (isContained === void 0) { isContained = false; }\n    var padding = root.padding, gn = typeof root.groups !== 'undefined' ? root.groups.length : 0, ln = typeof root.leaves !== 'undefined' ? root.leaves.length : 0, childConstraints = !gn ? []\n        : root.groups.reduce(function (ccs, g) { return ccs.concat(generateGroupConstraints(g, f, minSep, true)); }, []), n = (isContained ? 2 : 0) + ln + gn, vs = new Array(n), rs = new Array(n), i = 0, add = function (r, v) { rs[i] = r; vs[i++] = v; };\n    if (isContained) {\n        var b = root.bounds, c = f.getCentre(b), s = f.getSize(b) / 2, open = f.getOpen(b), close = f.getClose(b), min = c - s + padding / 2, max = c + s - padding / 2;\n        root.minVar.desiredPosition = min;\n        add(f.makeRect(open, close, min, padding), root.minVar);\n        root.maxVar.desiredPosition = max;\n        add(f.makeRect(open, close, max, padding), root.maxVar);\n    }\n    if (ln)\n        root.leaves.forEach(function (l) { return add(l.bounds, l.variable); });\n    if (gn)\n        root.groups.forEach(function (g) {\n            var b = g.bounds;\n            add(f.makeRect(f.getOpen(b), f.getClose(b), f.getCentre(b), f.getSize(b)), g.minVar);\n        });\n    var cs = generateConstraints(rs, vs, f, minSep);\n    if (gn) {\n        vs.forEach(function (v) { v.cOut = [], v.cIn = []; });\n        cs.forEach(function (c) { c.left.cOut.push(c), c.right.cIn.push(c); });\n        root.groups.forEach(function (g) {\n            var gapAdjustment = (g.padding - f.getSize(g.bounds)) / 2;\n            g.minVar.cIn.forEach(function (c) { return c.gap += gapAdjustment; });\n            g.minVar.cOut.forEach(function (c) { c.left = g.maxVar; c.gap += gapAdjustment; });\n        });\n    }\n    return childConstraints.concat(cs);\n}\nfunction generateConstraints(rs, vars, rect, minSep) {\n    var i, n = rs.length;\n    var N = 2 * n;\n    console.assert(vars.length >= n);\n    var events = new Array(N);\n    for (i = 0; i < n; ++i) {\n        var r = rs[i];\n        var v = new Node(vars[i], r, rect.getCentre(r));\n        events[i] = new Event(true, v, rect.getOpen(r));\n        events[i + n] = new Event(false, v, rect.getClose(r));\n    }\n    events.sort(compareEvents);\n    var cs = new Array();\n    var scanline = makeRBTree();\n    for (i = 0; i < N; ++i) {\n        var e = events[i];\n        var v = e.v;\n        if (e.isOpen) {\n            scanline.insert(v);\n            rect.findNeighbours(v, scanline);\n        }\n        else {\n            scanline.remove(v);\n            var makeConstraint = function (l, r) {\n                var sep = (rect.getSize(l.r) + rect.getSize(r.r)) / 2 + minSep;\n                cs.push(new vpsc_1.Constraint(l.v, r.v, sep));\n            };\n            var visitNeighbours = function (forward, reverse, mkcon) {\n                var u, it = v[forward].iterator();\n                while ((u = it[forward]()) !== null) {\n                    mkcon(u, v);\n                    u[reverse].remove(v);\n                }\n            };\n            visitNeighbours(\"prev\", \"next\", function (u, v) { return makeConstraint(u, v); });\n            visitNeighbours(\"next\", \"prev\", function (u, v) { return makeConstraint(v, u); });\n        }\n    }\n    console.assert(scanline.size === 0);\n    return cs;\n}\nfunction findXNeighbours(v, scanline) {\n    var f = function (forward, reverse) {\n        var it = scanline.findIter(v);\n        var u;\n        while ((u = it[forward]()) !== null) {\n            var uovervX = u.r.overlapX(v.r);\n            if (uovervX <= 0 || uovervX <= u.r.overlapY(v.r)) {\n                v[forward].insert(u);\n                u[reverse].insert(v);\n            }\n            if (uovervX <= 0) {\n                break;\n            }\n        }\n    };\n    f(\"next\", \"prev\");\n    f(\"prev\", \"next\");\n}\nfunction findYNeighbours(v, scanline) {\n    var f = function (forward, reverse) {\n        var u = scanline.findIter(v)[forward]();\n        if (u !== null && u.r.overlapX(v.r) > 0) {\n            v[forward].insert(u);\n            u[reverse].insert(v);\n        }\n    };\n    f(\"next\", \"prev\");\n    f(\"prev\", \"next\");\n}\nfunction generateXConstraints(rs, vars) {\n    return generateConstraints(rs, vars, xRect, 1e-6);\n}\nexports.generateXConstraints = generateXConstraints;\nfunction generateYConstraints(rs, vars) {\n    return generateConstraints(rs, vars, yRect, 1e-6);\n}\nexports.generateYConstraints = generateYConstraints;\nfunction generateXGroupConstraints(root) {\n    return generateGroupConstraints(root, xRect, 1e-6);\n}\nexports.generateXGroupConstraints = generateXGroupConstraints;\nfunction generateYGroupConstraints(root) {\n    return generateGroupConstraints(root, yRect, 1e-6);\n}\nexports.generateYGroupConstraints = generateYGroupConstraints;\nfunction removeOverlaps(rs) {\n    var vs = rs.map(function (r) { return new vpsc_1.Variable(r.cx()); });\n    var cs = generateXConstraints(rs, vs);\n    var solver = new vpsc_1.Solver(vs, cs);\n    solver.solve();\n    vs.forEach(function (v, i) { return rs[i].setXCentre(v.position()); });\n    vs = rs.map(function (r) { return new vpsc_1.Variable(r.cy()); });\n    cs = generateYConstraints(rs, vs);\n    solver = new vpsc_1.Solver(vs, cs);\n    solver.solve();\n    vs.forEach(function (v, i) { return rs[i].setYCentre(v.position()); });\n}\nexports.removeOverlaps = removeOverlaps;\nvar IndexedVariable = (function (_super) {\n    __extends(IndexedVariable, _super);\n    function IndexedVariable(index, w) {\n        var _this = _super.call(this, 0, w) || this;\n        _this.index = index;\n        return _this;\n    }\n    return IndexedVariable;\n}(vpsc_1.Variable));\nexports.IndexedVariable = IndexedVariable;\nvar Projection = (function () {\n    function Projection(nodes, groups, rootGroup, constraints, avoidOverlaps) {\n        var _this = this;\n        if (rootGroup === void 0) { rootGroup = null; }\n        if (constraints === void 0) { constraints = null; }\n        if (avoidOverlaps === void 0) { avoidOverlaps = false; }\n        this.nodes = nodes;\n        this.groups = groups;\n        this.rootGroup = rootGroup;\n        this.avoidOverlaps = avoidOverlaps;\n        this.variables = nodes.map(function (v, i) {\n            return v.variable = new IndexedVariable(i, 1);\n        });\n        if (constraints)\n            this.createConstraints(constraints);\n        if (avoidOverlaps && rootGroup && typeof rootGroup.groups !== 'undefined') {\n            nodes.forEach(function (v) {\n                if (!v.width || !v.height) {\n                    v.bounds = new Rectangle(v.x, v.x, v.y, v.y);\n                    return;\n                }\n                var w2 = v.width / 2, h2 = v.height / 2;\n                v.bounds = new Rectangle(v.x - w2, v.x + w2, v.y - h2, v.y + h2);\n            });\n            computeGroupBounds(rootGroup);\n            var i = nodes.length;\n            groups.forEach(function (g) {\n                _this.variables[i] = g.minVar = new IndexedVariable(i++, typeof g.stiffness !== \"undefined\" ? g.stiffness : 0.01);\n                _this.variables[i] = g.maxVar = new IndexedVariable(i++, typeof g.stiffness !== \"undefined\" ? g.stiffness : 0.01);\n            });\n        }\n    }\n    Projection.prototype.createSeparation = function (c) {\n        return new vpsc_1.Constraint(this.nodes[c.left].variable, this.nodes[c.right].variable, c.gap, typeof c.equality !== \"undefined\" ? c.equality : false);\n    };\n    Projection.prototype.makeFeasible = function (c) {\n        var _this = this;\n        if (!this.avoidOverlaps)\n            return;\n        var axis = 'x', dim = 'width';\n        if (c.axis === 'x')\n            axis = 'y', dim = 'height';\n        var vs = c.offsets.map(function (o) { return _this.nodes[o.node]; }).sort(function (a, b) { return a[axis] - b[axis]; });\n        var p = null;\n        vs.forEach(function (v) {\n            if (p) {\n                var nextPos = p[axis] + p[dim];\n                if (nextPos > v[axis]) {\n                    v[axis] = nextPos;\n                }\n            }\n            p = v;\n        });\n    };\n    Projection.prototype.createAlignment = function (c) {\n        var _this = this;\n        var u = this.nodes[c.offsets[0].node].variable;\n        this.makeFeasible(c);\n        var cs = c.axis === 'x' ? this.xConstraints : this.yConstraints;\n        c.offsets.slice(1).forEach(function (o) {\n            var v = _this.nodes[o.node].variable;\n            cs.push(new vpsc_1.Constraint(u, v, o.offset, true));\n        });\n    };\n    Projection.prototype.createConstraints = function (constraints) {\n        var _this = this;\n        var isSep = function (c) { return typeof c.type === 'undefined' || c.type === 'separation'; };\n        this.xConstraints = constraints\n            .filter(function (c) { return c.axis === \"x\" && isSep(c); })\n            .map(function (c) { return _this.createSeparation(c); });\n        this.yConstraints = constraints\n            .filter(function (c) { return c.axis === \"y\" && isSep(c); })\n            .map(function (c) { return _this.createSeparation(c); });\n        constraints\n            .filter(function (c) { return c.type === 'alignment'; })\n            .forEach(function (c) { return _this.createAlignment(c); });\n    };\n    Projection.prototype.setupVariablesAndBounds = function (x0, y0, desired, getDesired) {\n        this.nodes.forEach(function (v, i) {\n            if (v.fixed) {\n                v.variable.weight = v.fixedWeight ? v.fixedWeight : 1000;\n                desired[i] = getDesired(v);\n            }\n            else {\n                v.variable.weight = 1;\n            }\n            var w = (v.width || 0) / 2, h = (v.height || 0) / 2;\n            var ix = x0[i], iy = y0[i];\n            v.bounds = new Rectangle(ix - w, ix + w, iy - h, iy + h);\n        });\n    };\n    Projection.prototype.xProject = function (x0, y0, x) {\n        if (!this.rootGroup && !(this.avoidOverlaps || this.xConstraints))\n            return;\n        this.project(x0, y0, x0, x, function (v) { return v.px; }, this.xConstraints, generateXGroupConstraints, function (v) { return v.bounds.setXCentre(x[v.variable.index] = v.variable.position()); }, function (g) {\n            var xmin = x[g.minVar.index] = g.minVar.position();\n            var xmax = x[g.maxVar.index] = g.maxVar.position();\n            var p2 = g.padding / 2;\n            g.bounds.x = xmin - p2;\n            g.bounds.X = xmax + p2;\n        });\n    };\n    Projection.prototype.yProject = function (x0, y0, y) {\n        if (!this.rootGroup && !this.yConstraints)\n            return;\n        this.project(x0, y0, y0, y, function (v) { return v.py; }, this.yConstraints, generateYGroupConstraints, function (v) { return v.bounds.setYCentre(y[v.variable.index] = v.variable.position()); }, function (g) {\n            var ymin = y[g.minVar.index] = g.minVar.position();\n            var ymax = y[g.maxVar.index] = g.maxVar.position();\n            var p2 = g.padding / 2;\n            g.bounds.y = ymin - p2;\n            ;\n            g.bounds.Y = ymax + p2;\n        });\n    };\n    Projection.prototype.projectFunctions = function () {\n        var _this = this;\n        return [\n            function (x0, y0, x) { return _this.xProject(x0, y0, x); },\n            function (x0, y0, y) { return _this.yProject(x0, y0, y); }\n        ];\n    };\n    Projection.prototype.project = function (x0, y0, start, desired, getDesired, cs, generateConstraints, updateNodeBounds, updateGroupBounds) {\n        this.setupVariablesAndBounds(x0, y0, desired, getDesired);\n        if (this.rootGroup && this.avoidOverlaps) {\n            computeGroupBounds(this.rootGroup);\n            cs = cs.concat(generateConstraints(this.rootGroup));\n        }\n        this.solve(this.variables, cs, start, desired);\n        this.nodes.forEach(updateNodeBounds);\n        if (this.rootGroup && this.avoidOverlaps) {\n            this.groups.forEach(updateGroupBounds);\n            computeGroupBounds(this.rootGroup);\n        }\n    };\n    Projection.prototype.solve = function (vs, cs, starting, desired) {\n        var solver = new vpsc_1.Solver(vs, cs);\n        solver.setStartingPositions(starting);\n        solver.setDesiredPositions(desired);\n        solver.solve();\n    };\n    return Projection;\n}());\nexports.Projection = Projection;\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rectangle.js","sourceRoot":"","sources":["../../WebCola/src/rectangle.ts"],"names":[],"mappings":"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"}","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar pqueue_1 = require(\"./pqueue\");\nvar Neighbour = (function () {\n    function Neighbour(id, distance) {\n        this.id = id;\n        this.distance = distance;\n    }\n    return Neighbour;\n}());\nvar Node = (function () {\n    function Node(id) {\n        this.id = id;\n        this.neighbours = [];\n    }\n    return Node;\n}());\nvar QueueEntry = (function () {\n    function QueueEntry(node, prev, d) {\n        this.node = node;\n        this.prev = prev;\n        this.d = d;\n    }\n    return QueueEntry;\n}());\nvar Calculator = (function () {\n    function Calculator(n, es, getSourceIndex, getTargetIndex, getLength) {\n        this.n = n;\n        this.es = es;\n        this.neighbours = new Array(this.n);\n        var i = this.n;\n        while (i--)\n            this.neighbours[i] = new Node(i);\n        i = this.es.length;\n        while (i--) {\n            var e = this.es[i];\n            var u = getSourceIndex(e), v = getTargetIndex(e);\n            var d = getLength(e);\n            this.neighbours[u].neighbours.push(new Neighbour(v, d));\n            this.neighbours[v].neighbours.push(new Neighbour(u, d));\n        }\n    }\n    Calculator.prototype.DistanceMatrix = function () {\n        var D = new Array(this.n);\n        for (var i = 0; i < this.n; ++i) {\n            D[i] = this.dijkstraNeighbours(i);\n        }\n        return D;\n    };\n    Calculator.prototype.DistancesFromNode = function (start) {\n        return this.dijkstraNeighbours(start);\n    };\n    Calculator.prototype.PathFromNodeToNode = function (start, end) {\n        return this.dijkstraNeighbours(start, end);\n    };\n    Calculator.prototype.PathFromNodeToNodeWithPrevCost = function (start, end, prevCost) {\n        var q = new pqueue_1.PriorityQueue(function (a, b) { return a.d <= b.d; }), u = this.neighbours[start], qu = new QueueEntry(u, null, 0), visitedFrom = {};\n        q.push(qu);\n        while (!q.empty()) {\n            qu = q.pop();\n            u = qu.node;\n            if (u.id === end) {\n                break;\n            }\n            var i = u.neighbours.length;\n            while (i--) {\n                var neighbour = u.neighbours[i], v = this.neighbours[neighbour.id];\n                if (qu.prev && v.id === qu.prev.node.id)\n                    continue;\n                var viduid = v.id + ',' + u.id;\n                if (viduid in visitedFrom && visitedFrom[viduid] <= qu.d)\n                    continue;\n                var cc = qu.prev ? prevCost(qu.prev.node.id, u.id, v.id) : 0, t = qu.d + neighbour.distance + cc;\n                visitedFrom[viduid] = t;\n                q.push(new QueueEntry(v, qu, t));\n            }\n        }\n        var path = [];\n        while (qu.prev) {\n            qu = qu.prev;\n            path.push(qu.node.id);\n        }\n        return path;\n    };\n    Calculator.prototype.dijkstraNeighbours = function (start, dest) {\n        if (dest === void 0) { dest = -1; }\n        var q = new pqueue_1.PriorityQueue(function (a, b) { return a.d <= b.d; }), i = this.neighbours.length, d = new Array(i);\n        while (i--) {\n            var node = this.neighbours[i];\n            node.d = i === start ? 0 : Number.POSITIVE_INFINITY;\n            node.q = q.push(node);\n        }\n        while (!q.empty()) {\n            var u = q.pop();\n            d[u.id] = u.d;\n            if (u.id === dest) {\n                var path = [];\n                var v = u;\n                while (typeof v.prev !== 'undefined') {\n                    path.push(v.prev.id);\n                    v = v.prev;\n                }\n                return path;\n            }\n            i = u.neighbours.length;\n            while (i--) {\n                var neighbour = u.neighbours[i];\n                var v = this.neighbours[neighbour.id];\n                var t = u.d + neighbour.distance;\n                if (u.d !== Number.MAX_VALUE && v.d > t) {\n                    v.d = t;\n                    v.prev = u;\n                    q.reduceKey(v.q, v, function (e, q) { return e.q = q; });\n                }\n            }\n        }\n        return d;\n    };\n    return Calculator;\n}());\nexports.Calculator = Calculator;\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hvcnRlc3RwYXRocy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL1dlYkNvbGEvc3JjL3Nob3J0ZXN0cGF0aHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxtQ0FBbUQ7QUFFbkQ7SUFDSSxtQkFBbUIsRUFBVSxFQUFTLFFBQWdCO1FBQW5DLE9BQUUsR0FBRixFQUFFLENBQVE7UUFBUyxhQUFRLEdBQVIsUUFBUSxDQUFRO0lBQUksQ0FBQztJQUMvRCxnQkFBQztBQUFELENBQUMsQUFGRCxJQUVDO0FBRUQ7SUFDSSxjQUFtQixFQUFVO1FBQVYsT0FBRSxHQUFGLEVBQUUsQ0FBUTtRQUN6QixJQUFJLENBQUMsVUFBVSxHQUFHLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBS0wsV0FBQztBQUFELENBQUMsQUFSRCxJQVFDO0FBRUQ7SUFDSSxvQkFBbUIsSUFBVSxFQUFTLElBQWdCLEVBQVMsQ0FBUztRQUFyRCxTQUFJLEdBQUosSUFBSSxDQUFNO1FBQVMsU0FBSSxHQUFKLElBQUksQ0FBWTtRQUFTLE1BQUMsR0FBRCxDQUFDLENBQVE7SUFBRyxDQUFDO0lBQ2hGLGlCQUFDO0FBQUQsQ0FBQyxBQUZELElBRUM7QUFTRDtJQUdJLG9CQUFtQixDQUFTLEVBQVMsRUFBVSxFQUFFLGNBQW1DLEVBQUUsY0FBbUMsRUFBRSxTQUE4QjtRQUF0SSxNQUFDLEdBQUQsQ0FBQyxDQUFRO1FBQVMsT0FBRSxHQUFGLEVBQUUsQ0FBUTtRQUMzQyxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNwQyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDO1FBQUMsT0FBTyxDQUFDLEVBQUU7WUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRTdELENBQUMsR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFD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","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar PositionStats = (function () {\n    function PositionStats(scale) {\n        this.scale = scale;\n        this.AB = 0;\n        this.AD = 0;\n        this.A2 = 0;\n    }\n    PositionStats.prototype.addVariable = function (v) {\n        var ai = this.scale / v.scale;\n        var bi = v.offset / v.scale;\n        var wi = v.weight;\n        this.AB += wi * ai * bi;\n        this.AD += wi * ai * v.desiredPosition;\n        this.A2 += wi * ai * ai;\n    };\n    PositionStats.prototype.getPosn = function () {\n        return (this.AD - this.AB) / this.A2;\n    };\n    return PositionStats;\n}());\nexports.PositionStats = PositionStats;\nvar Constraint = (function () {\n    function Constraint(left, right, gap, equality) {\n        if (equality === void 0) { equality = false; }\n        this.left = left;\n        this.right = right;\n        this.gap = gap;\n        this.equality = equality;\n        this.active = false;\n        this.unsatisfiable = false;\n        this.left = left;\n        this.right = right;\n        this.gap = gap;\n        this.equality = equality;\n    }\n    Constraint.prototype.slack = function () {\n        return this.unsatisfiable ? Number.MAX_VALUE\n            : this.right.scale * this.right.position() - this.gap\n                - this.left.scale * this.left.position();\n    };\n    return Constraint;\n}());\nexports.Constraint = Constraint;\nvar Variable = (function () {\n    function Variable(desiredPosition, weight, scale) {\n        if (weight === void 0) { weight = 1; }\n        if (scale === void 0) { scale = 1; }\n        this.desiredPosition = desiredPosition;\n        this.weight = weight;\n        this.scale = scale;\n        this.offset = 0;\n    }\n    Variable.prototype.dfdv = function () {\n        return 2.0 * this.weight * (this.position() - this.desiredPosition);\n    };\n    Variable.prototype.position = function () {\n        return (this.block.ps.scale * this.block.posn + this.offset) / this.scale;\n    };\n    Variable.prototype.visitNeighbours = function (prev, f) {\n        var ff = function (c, next) { return c.active && prev !== next && f(c, next); };\n        this.cOut.forEach(function (c) { return ff(c, c.right); });\n        this.cIn.forEach(function (c) { return ff(c, c.left); });\n    };\n    return Variable;\n}());\nexports.Variable = Variable;\nvar Block = (function () {\n    function Block(v) {\n        this.vars = [];\n        v.offset = 0;\n        this.ps = new PositionStats(v.scale);\n        this.addVariable(v);\n    }\n    Block.prototype.addVariable = function (v) {\n        v.block = this;\n        this.vars.push(v);\n        this.ps.addVariable(v);\n        this.posn = this.ps.getPosn();\n    };\n    Block.prototype.updateWeightedPosition = function () {\n        this.ps.AB = this.ps.AD = this.ps.A2 = 0;\n        for (var i = 0, n = this.vars.length; i < n; ++i)\n            this.ps.addVariable(this.vars[i]);\n        this.posn = this.ps.getPosn();\n    };\n    Block.prototype.compute_lm = function (v, u, postAction) {\n        var _this = this;\n        var dfdv = v.dfdv();\n        v.visitNeighbours(u, function (c, next) {\n            var _dfdv = _this.compute_lm(next, v, postAction);\n            if (next === c.right) {\n                dfdv += _dfdv * c.left.scale;\n                c.lm = _dfdv;\n            }\n            else {\n                dfdv += _dfdv * c.right.scale;\n                c.lm = -_dfdv;\n            }\n            postAction(c);\n        });\n        return dfdv / v.scale;\n    };\n    Block.prototype.populateSplitBlock = function (v, prev) {\n        var _this = this;\n        v.visitNeighbours(prev, function (c, next) {\n            next.offset = v.offset + (next === c.right ? c.gap : -c.gap);\n            _this.addVariable(next);\n            _this.populateSplitBlock(next, v);\n        });\n    };\n    Block.prototype.traverse = function (visit, acc, v, prev) {\n        var _this = this;\n        if (v === void 0) { v = this.vars[0]; }\n        if (prev === void 0) { prev = null; }\n        v.visitNeighbours(prev, function (c, next) {\n            acc.push(visit(c));\n            _this.traverse(visit, acc, next, v);\n        });\n    };\n    Block.prototype.findMinLM = function () {\n        var m = null;\n        this.compute_lm(this.vars[0], null, function (c) {\n            if (!c.equality && (m === null || c.lm < m.lm))\n                m = c;\n        });\n        return m;\n    };\n    Block.prototype.findMinLMBetween = function (lv, rv) {\n        this.compute_lm(lv, null, function () { });\n        var m = null;\n        this.findPath(lv, null, rv, function (c, next) {\n            if (!c.equality && c.right === next && (m === null || c.lm < m.lm))\n                m = c;\n        });\n        return m;\n    };\n    Block.prototype.findPath = function (v, prev, to, visit) {\n        var _this = this;\n        var endFound = false;\n        v.visitNeighbours(prev, function (c, next) {\n            if (!endFound && (next === to || _this.findPath(next, v, to, visit))) {\n                endFound = true;\n                visit(c, next);\n            }\n        });\n        return endFound;\n    };\n    Block.prototype.isActiveDirectedPathBetween = function (u, v) {\n        if (u === v)\n            return true;\n        var i = u.cOut.length;\n        while (i--) {\n            var c = u.cOut[i];\n            if (c.active && this.isActiveDirectedPathBetween(c.right, v))\n                return true;\n        }\n        return false;\n    };\n    Block.split = function (c) {\n        c.active = false;\n        return [Block.createSplitBlock(c.left), Block.createSplitBlock(c.right)];\n    };\n    Block.createSplitBlock = function (startVar) {\n        var b = new Block(startVar);\n        b.populateSplitBlock(startVar, null);\n        return b;\n    };\n    Block.prototype.splitBetween = function (vl, vr) {\n        var c = this.findMinLMBetween(vl, vr);\n        if (c !== null) {\n            var bs = Block.split(c);\n            return { constraint: c, lb: bs[0], rb: bs[1] };\n        }\n        return null;\n    };\n    Block.prototype.mergeAcross = function (b, c, dist) {\n        c.active = true;\n        for (var i = 0, n = b.vars.length; i < n; ++i) {\n            var v = b.vars[i];\n            v.offset += dist;\n            this.addVariable(v);\n        }\n        this.posn = this.ps.getPosn();\n    };\n    Block.prototype.cost = function () {\n        var sum = 0, i = this.vars.length;\n        while (i--) {\n            var v = this.vars[i], d = v.position() - v.desiredPosition;\n            sum += d * d * v.weight;\n        }\n        return sum;\n    };\n    return Block;\n}());\nexports.Block = Block;\nvar Blocks = (function () {\n    function Blocks(vs) {\n        this.vs = vs;\n        var n = vs.length;\n        this.list = new Array(n);\n        while (n--) {\n            var b = new Block(vs[n]);\n            this.list[n] = b;\n            b.blockInd = n;\n        }\n    }\n    Blocks.prototype.cost = function () {\n        var sum = 0, i = this.list.length;\n        while (i--)\n            sum += this.list[i].cost();\n        return sum;\n    };\n    Blocks.prototype.insert = function (b) {\n        b.blockInd = this.list.length;\n        this.list.push(b);\n    };\n    Blocks.prototype.remove = function (b) {\n        var last = this.list.length - 1;\n        var swapBlock = this.list[last];\n        this.list.length = last;\n        if (b !== swapBlock) {\n            this.list[b.blockInd] = swapBlock;\n            swapBlock.blockInd = b.blockInd;\n        }\n    };\n    Blocks.prototype.merge = function (c) {\n        var l = c.left.block, r = c.right.block;\n        var dist = c.right.offset - c.left.offset - c.gap;\n        if (l.vars.length < r.vars.length) {\n            r.mergeAcross(l, c, dist);\n            this.remove(l);\n        }\n        else {\n            l.mergeAcross(r, c, -dist);\n            this.remove(r);\n        }\n    };\n    Blocks.prototype.forEach = function (f) {\n        this.list.forEach(f);\n    };\n    Blocks.prototype.updateBlockPositions = function () {\n        this.list.forEach(function (b) { return b.updateWeightedPosition(); });\n    };\n    Blocks.prototype.split = function (inactive) {\n        var _this = this;\n        this.updateBlockPositions();\n        this.list.forEach(function (b) {\n            var v = b.findMinLM();\n            if (v !== null && v.lm < Solver.LAGRANGIAN_TOLERANCE) {\n                b = v.left.block;\n                Block.split(v).forEach(function (nb) { return _this.insert(nb); });\n                _this.remove(b);\n                inactive.push(v);\n            }\n        });\n    };\n    return Blocks;\n}());\nexports.Blocks = Blocks;\nvar Solver = (function () {\n    function Solver(vs, cs) {\n        this.vs = vs;\n        this.cs = cs;\n        this.vs = vs;\n        vs.forEach(function (v) {\n            v.cIn = [], v.cOut = [];\n        });\n        this.cs = cs;\n        cs.forEach(function (c) {\n            c.left.cOut.push(c);\n            c.right.cIn.push(c);\n        });\n        this.inactive = cs.map(function (c) { c.active = false; return c; });\n        this.bs = null;\n    }\n    Solver.prototype.cost = function () {\n        return this.bs.cost();\n    };\n    Solver.prototype.setStartingPositions = function (ps) {\n        this.inactive = this.cs.map(function (c) { c.active = false; return c; });\n        this.bs = new Blocks(this.vs);\n        this.bs.forEach(function (b, i) { return b.posn = ps[i]; });\n    };\n    Solver.prototype.setDesiredPositions = function (ps) {\n        this.vs.forEach(function (v, i) { return v.desiredPosition = ps[i]; });\n    };\n    Solver.prototype.mostViolated = function () {\n        var minSlack = Number.MAX_VALUE, v = null, l = this.inactive, n = l.length, deletePoint = n;\n        for (var i = 0; i < n; ++i) {\n            var c = l[i];\n            if (c.unsatisfiable)\n                continue;\n            var slack = c.slack();\n            if (c.equality || slack < minSlack) {\n                minSlack = slack;\n                v = c;\n                deletePoint = i;\n                if (c.equality)\n                    break;\n            }\n        }\n        if (deletePoint !== n &&\n            (minSlack < Solver.ZERO_UPPERBOUND && !v.active || v.equality)) {\n            l[deletePoint] = l[n - 1];\n            l.length = n - 1;\n        }\n        return v;\n    };\n    Solver.prototype.satisfy = function () {\n        if (this.bs == null) {\n            this.bs = new Blocks(this.vs);\n        }\n        this.bs.split(this.inactive);\n        var v = null;\n        while ((v = this.mostViolated()) && (v.equality || v.slack() < Solver.ZERO_UPPERBOUND && !v.active)) {\n            var lb = v.left.block, rb = v.right.block;\n            if (lb !== rb) {\n                this.bs.merge(v);\n            }\n            else {\n                if (lb.isActiveDirectedPathBetween(v.right, v.left)) {\n                    v.unsatisfiable = true;\n                    continue;\n                }\n                var split = lb.splitBetween(v.left, v.right);\n                if (split !== null) {\n                    this.bs.insert(split.lb);\n                    this.bs.insert(split.rb);\n                    this.bs.remove(lb);\n                    this.inactive.push(split.constraint);\n                }\n                else {\n                    v.unsatisfiable = true;\n                    continue;\n                }\n                if (v.slack() >= 0) {\n                    this.inactive.push(v);\n                }\n                else {\n                    this.bs.merge(v);\n                }\n            }\n        }\n    };\n    Solver.prototype.solve = function () {\n        this.satisfy();\n        var lastcost = Number.MAX_VALUE, cost = this.bs.cost();\n        while (Math.abs(lastcost - cost) > 0.0001) {\n            this.satisfy();\n            lastcost = cost;\n            cost = this.bs.cost();\n        }\n        return cost;\n    };\n    Solver.LAGRANGIAN_TOLERANCE = -1e-4;\n    Solver.ZERO_UPPERBOUND = -1e-10;\n    return Solver;\n}());\nexports.Solver = Solver;\nfunction removeOverlapInOneDimension(spans, lowerBound, upperBound) {\n    var vs = spans.map(function (s) { return new Variable(s.desiredCenter); });\n    var cs = [];\n    var n = spans.length;\n    for (var i = 0; i < n - 1; i++) {\n        var left = spans[i], right = spans[i + 1];\n        cs.push(new Constraint(vs[i], vs[i + 1], (left.size + right.size) / 2));\n    }\n    var leftMost = vs[0], rightMost = vs[n - 1], leftMostSize = spans[0].size / 2, rightMostSize = spans[n - 1].size / 2;\n    var vLower = null, vUpper = null;\n    if (lowerBound) {\n        vLower = new Variable(lowerBound, leftMost.weight * 1000);\n        vs.push(vLower);\n        cs.push(new Constraint(vLower, leftMost, leftMostSize));\n    }\n    if (upperBound) {\n        vUpper = new Variable(upperBound, rightMost.weight * 1000);\n        vs.push(vUpper);\n        cs.push(new Constraint(rightMost, vUpper, rightMostSize));\n    }\n    var solver = new Solver(vs, cs);\n    solver.solve();\n    return {\n        newCenters: vs.slice(0, spans.length).map(function (v) { return v.position(); }),\n        lowerBound: vLower ? vLower.position() : leftMost.position() - leftMostSize,\n        upperBound: vUpper ? vUpper.position() : rightMost.position() + rightMostSize\n    };\n}\nexports.removeOverlapInOneDimension = removeOverlapInOneDimension;\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vpsc.js","sourceRoot":"","sources":["../../WebCola/src/vpsc.ts"],"names":[],"mappings":"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"}"]} - - -/***/ }), - -/***/ "./node_modules/@eastdesire/jscolor/jscolor.js": -/*!*****************************************************!*\ - !*** ./node_modules/@eastdesire/jscolor/jscolor.js ***! - \*****************************************************/ -/***/ (function(module) { - -/** - * jscolor - JavaScript Color Picker - * - * @link http://jscolor.com - * @license For open source use: GPLv3 - * For commercial use: JSColor Commercial License - * @author Jan Odvarko - East Desire - * - * See usage examples at http://jscolor.com/examples/ - */ - - -(function (global, factory) { - - 'use strict'; - - if ( true && typeof module.exports === 'object') { - // Export jscolor as a module - module.exports = global.document ? - factory (global) : - function (win) { - if (!win.document) { - throw new Error('jscolor needs a window with document'); - } - return factory(win); - } - return; - } - - // Default use (no module export) - factory(global); - -})(typeof window !== 'undefined' ? window : this, function (window) { // BEGIN factory - -// BEGIN jscolor code - - -'use strict'; - - -var jscolor = (function () { // BEGIN jscolor - -var jsc = { - - - initialized : false, - - instances : [], // created instances of jscolor - - readyQueue : [], // functions waiting to be called after init - - - register : function () { - if (typeof window !== 'undefined' && window.document) { - window.document.addEventListener('DOMContentLoaded', jsc.pub.init, false); - } - }, - - - installBySelector : function (selector, rootNode) { - rootNode = rootNode ? jsc.node(rootNode) : window.document; - if (!rootNode) { - throw new Error('Missing root node'); - } - - var elms = rootNode.querySelectorAll(selector); - - // for backward compatibility with DEPRECATED installation/configuration using className - var matchClass = new RegExp('(^|\\s)(' + jsc.pub.lookupClass + ')(\\s*(\\{[^}]*\\})|\\s|$)', 'i'); - - for (var i = 0; i < elms.length; i += 1) { - - if (elms[i].jscolor && elms[i].jscolor instanceof jsc.pub) { - continue; // jscolor already installed on this element - } - - if (elms[i].type !== undefined && elms[i].type.toLowerCase() == 'color' && jsc.isColorAttrSupported) { - continue; // skips inputs of type 'color' if supported by the browser - } - - var dataOpts, m; - - if ( - (dataOpts = jsc.getDataAttr(elms[i], 'jscolor')) !== null || - (elms[i].className && (m = elms[i].className.match(matchClass))) // installation using className (DEPRECATED) - ) { - var targetElm = elms[i]; - - var optsStr = ''; - if (dataOpts !== null) { - optsStr = dataOpts; - - } else if (m) { // installation using className (DEPRECATED) - console.warn('Installation using class name is DEPRECATED. Use data-jscolor="" attribute instead.' + jsc.docsRef); - if (m[4]) { - optsStr = m[4]; - } - } - - var opts = null; - if (optsStr.trim()) { - try { - opts = jsc.parseOptionsStr(optsStr); - } catch (e) { - console.warn(e + '\n' + optsStr); - } - } - - try { - new jsc.pub(targetElm, opts); - } catch (e) { - console.warn(e); - } - } - } - }, - - - parseOptionsStr : function (str) { - var opts = null; - - try { - opts = JSON.parse(str); - - } catch (eParse) { - if (!jsc.pub.looseJSON) { - throw new Error('Could not parse jscolor options as JSON: ' + eParse); - } else { - // loose JSON syntax is enabled -> try to evaluate the options string as JavaScript object - try { - opts = (new Function ('var opts = (' + str + '); return typeof opts === "object" ? opts : {};'))(); - } catch (eEval) { - throw new Error('Could not evaluate jscolor options: ' + eEval); - } - } - } - return opts; - }, - - - getInstances : function () { - var inst = []; - for (var i = 0; i < jsc.instances.length; i += 1) { - // if the targetElement still exists, the instance is considered "alive" - if (jsc.instances[i] && jsc.instances[i].targetElement) { - inst.push(jsc.instances[i]); - } - } - return inst; - }, - - - createEl : function (tagName) { - var el = window.document.createElement(tagName); - jsc.setData(el, 'gui', true); - return el; - }, - - - node : function (nodeOrSelector) { - if (!nodeOrSelector) { - return null; - } - - if (typeof nodeOrSelector === 'string') { - // query selector - var sel = nodeOrSelector; - var el = null; - try { - el = window.document.querySelector(sel); - } catch (e) { - console.warn(e); - return null; - } - if (!el) { - console.warn('No element matches the selector: %s', sel); - } - return el; - } - - if (jsc.isNode(nodeOrSelector)) { - // DOM node - return nodeOrSelector; - } - - console.warn('Invalid node of type %s: %s', typeof nodeOrSelector, nodeOrSelector); - return null; - }, - - - // See https://stackoverflow.com/questions/384286/ - isNode : function (val) { - if (typeof Node === 'object') { - return val instanceof Node; - } - return val && typeof val === 'object' && typeof val.nodeType === 'number' && typeof val.nodeName === 'string'; - }, - - - nodeName : function (node) { - if (node && node.nodeName) { - return node.nodeName.toLowerCase(); - } - return false; - }, - - - removeChildren : function (node) { - while (node.firstChild) { - node.removeChild(node.firstChild); - } - }, - - - isTextInput : function (el) { - return el && jsc.nodeName(el) === 'input' && el.type.toLowerCase() === 'text'; - }, - - - isButton : function (el) { - if (!el) { - return false; - } - var n = jsc.nodeName(el); - return ( - (n === 'button') || - (n === 'input' && ['button', 'submit', 'reset'].indexOf(el.type.toLowerCase()) > -1) - ); - }, - - - isButtonEmpty : function (el) { - switch (jsc.nodeName(el)) { - case 'input': return (!el.value || el.value.trim() === ''); - case 'button': return (el.textContent.trim() === ''); - } - return null; // could not determine element's text - }, - - - // See https://github.com/WICG/EventListenerOptions/blob/gh-pages/explainer.md - isPassiveEventSupported : (function () { - var supported = false; - - try { - var opts = Object.defineProperty({}, 'passive', { - get: function () { supported = true; } - }); - window.addEventListener('testPassive', null, opts); - window.removeEventListener('testPassive', null, opts); - } catch (e) {} - - return supported; - })(), - - - isColorAttrSupported : (function () { - var elm = window.document.createElement('input'); - if (elm.setAttribute) { - elm.setAttribute('type', 'color'); - if (elm.type.toLowerCase() == 'color') { - return true; - } - } - return false; - })(), - - - dataProp : '_data_jscolor', - - - // usage: - // setData(obj, prop, value) - // setData(obj, {prop:value, ...}) - // - setData : function () { - var obj = arguments[0]; - - if (arguments.length === 3) { - // setting a single property - var data = obj.hasOwnProperty(jsc.dataProp) ? obj[jsc.dataProp] : (obj[jsc.dataProp] = {}); - var prop = arguments[1]; - var value = arguments[2]; - - data[prop] = value; - return true; - - } else if (arguments.length === 2 && typeof arguments[1] === 'object') { - // setting multiple properties - var data = obj.hasOwnProperty(jsc.dataProp) ? obj[jsc.dataProp] : (obj[jsc.dataProp] = {}); - var map = arguments[1]; - - for (var prop in map) { - if (map.hasOwnProperty(prop)) { - data[prop] = map[prop]; - } - } - return true; - } - - throw new Error('Invalid arguments'); - }, - - - // usage: - // removeData(obj, prop, [prop...]) - // - removeData : function () { - var obj = arguments[0]; - if (!obj.hasOwnProperty(jsc.dataProp)) { - return true; // data object does not exist - } - for (var i = 1; i < arguments.length; i += 1) { - var prop = arguments[i]; - delete obj[jsc.dataProp][prop]; - } - return true; - }, - - - getData : function (obj, prop, setDefault) { - if (!obj.hasOwnProperty(jsc.dataProp)) { - // data object does not exist - if (setDefault !== undefined) { - obj[jsc.dataProp] = {}; // create data object - } else { - return undefined; // no value to return - } - } - var data = obj[jsc.dataProp]; - - if (!data.hasOwnProperty(prop) && setDefault !== undefined) { - data[prop] = setDefault; - } - return data[prop]; - }, - - - getDataAttr : function (el, name) { - var attrName = 'data-' + name; - var attrValue = el.getAttribute(attrName); - return attrValue; - }, - - - setDataAttr : function (el, name, value) { - var attrName = 'data-' + name; - el.setAttribute(attrName, value); - }, - - - _attachedGroupEvents : {}, - - - attachGroupEvent : function (groupName, el, evnt, func) { - if (!jsc._attachedGroupEvents.hasOwnProperty(groupName)) { - jsc._attachedGroupEvents[groupName] = []; - } - jsc._attachedGroupEvents[groupName].push([el, evnt, func]); - el.addEventListener(evnt, func, false); - }, - - - detachGroupEvents : function (groupName) { - if (jsc._attachedGroupEvents.hasOwnProperty(groupName)) { - for (var i = 0; i < jsc._attachedGroupEvents[groupName].length; i += 1) { - var evt = jsc._attachedGroupEvents[groupName][i]; - evt[0].removeEventListener(evt[1], evt[2], false); - } - delete jsc._attachedGroupEvents[groupName]; - } - }, - - - preventDefault : function (e) { - if (e.preventDefault) { e.preventDefault(); } - e.returnValue = false; - }, - - - triggerEvent : function (el, eventName, bubbles, cancelable) { - if (!el) { - return; - } - - var ev = null; - - if (typeof Event === 'function') { - ev = new Event(eventName, { - bubbles: bubbles, - cancelable: cancelable - }); - } else { - // IE - ev = window.document.createEvent('Event'); - ev.initEvent(eventName, bubbles, cancelable); - } - - if (!ev) { - return false; - } - - // so that we know that the event was triggered internally - jsc.setData(ev, 'internal', true); - - el.dispatchEvent(ev); - return true; - }, - - - triggerInputEvent : function (el, eventName, bubbles, cancelable) { - if (!el) { - return; - } - if (jsc.isTextInput(el)) { - jsc.triggerEvent(el, eventName, bubbles, cancelable); - } - }, - - - eventKey : function (ev) { - var keys = { - 9: 'Tab', - 13: 'Enter', - 27: 'Escape', - }; - if (typeof ev.code === 'string') { - return ev.code; - } else if (ev.keyCode !== undefined && keys.hasOwnProperty(ev.keyCode)) { - return keys[ev.keyCode]; - } - return null; - }, - - - strList : function (str) { - if (!str) { - return []; - } - return str.replace(/^\s+|\s+$/g, '').split(/\s+/); - }, - - - // The className parameter (str) can only contain a single class name - hasClass : function (elm, className) { - if (!className) { - return false; - } - if (elm.classList !== undefined) { - return elm.classList.contains(className); - } - // polyfill - return -1 != (' ' + elm.className.replace(/\s+/g, ' ') + ' ').indexOf(' ' + className + ' '); - }, - - - // The className parameter (str) can contain multiple class names separated by whitespace - addClass : function (elm, className) { - var classNames = jsc.strList(className); - - if (elm.classList !== undefined) { - for (var i = 0; i < classNames.length; i += 1) { - elm.classList.add(classNames[i]); - } - return; - } - // polyfill - for (var i = 0; i < classNames.length; i += 1) { - if (!jsc.hasClass(elm, classNames[i])) { - elm.className += (elm.className ? ' ' : '') + classNames[i]; - } - } - }, - - - // The className parameter (str) can contain multiple class names separated by whitespace - removeClass : function (elm, className) { - var classNames = jsc.strList(className); - - if (elm.classList !== undefined) { - for (var i = 0; i < classNames.length; i += 1) { - elm.classList.remove(classNames[i]); - } - return; - } - // polyfill - for (var i = 0; i < classNames.length; i += 1) { - var repl = new RegExp( - '^\\s*' + classNames[i] + '\\s*|' + - '\\s*' + classNames[i] + '\\s*$|' + - '\\s+' + classNames[i] + '(\\s+)', - 'g' - ); - elm.className = elm.className.replace(repl, '$1'); - } - }, - - - getCompStyle : function (elm) { - var compStyle = window.getComputedStyle ? window.getComputedStyle(elm) : elm.currentStyle; - - // Note: In Firefox, getComputedStyle returns null in a hidden iframe, - // that's why we need to check if the returned value is non-empty - if (!compStyle) { - return {}; - } - return compStyle; - }, - - - // Note: - // Setting a property to NULL reverts it to the state before it was first set - // with the 'reversible' flag enabled - // - setStyle : function (elm, styles, important, reversible) { - // using '' for standard priority (IE10 apparently doesn't like value undefined) - var priority = important ? 'important' : ''; - var origStyle = null; - - for (var prop in styles) { - if (styles.hasOwnProperty(prop)) { - var setVal = null; - - if (styles[prop] === null) { - // reverting a property value - - if (!origStyle) { - // get the original style object, but dont't try to create it if it doesn't exist - origStyle = jsc.getData(elm, 'origStyle'); - } - if (origStyle && origStyle.hasOwnProperty(prop)) { - // we have property's original value -> use it - setVal = origStyle[prop]; - } - - } else { - // setting a property value - - if (reversible) { - if (!origStyle) { - // get the original style object and if it doesn't exist, create it - origStyle = jsc.getData(elm, 'origStyle', {}); - } - if (!origStyle.hasOwnProperty(prop)) { - // original property value not yet stored -> store it - origStyle[prop] = elm.style[prop]; - } - } - setVal = styles[prop]; - } - - if (setVal !== null) { - elm.style.setProperty(prop, setVal, priority); - } - } - } - }, - - - hexColor : function (r, g, b) { - return '#' + ( - ('0' + Math.round(r).toString(16)).slice(-2) + - ('0' + Math.round(g).toString(16)).slice(-2) + - ('0' + Math.round(b).toString(16)).slice(-2) - ).toUpperCase(); - }, - - - hexaColor : function (r, g, b, a) { - return '#' + ( - ('0' + Math.round(r).toString(16)).slice(-2) + - ('0' + Math.round(g).toString(16)).slice(-2) + - ('0' + Math.round(b).toString(16)).slice(-2) + - ('0' + Math.round(a * 255).toString(16)).slice(-2) - ).toUpperCase(); - }, - - - rgbColor : function (r, g, b) { - return 'rgb(' + - Math.round(r) + ',' + - Math.round(g) + ',' + - Math.round(b) + - ')'; - }, - - - rgbaColor : function (r, g, b, a) { - return 'rgba(' + - Math.round(r) + ',' + - Math.round(g) + ',' + - Math.round(b) + ',' + - (Math.round((a===undefined || a===null ? 1 : a) * 100) / 100) + - ')'; - }, - - - linearGradient : (function () { - - function getFuncName () { - var stdName = 'linear-gradient'; - var prefixes = ['', '-webkit-', '-moz-', '-o-', '-ms-']; - var helper = window.document.createElement('div'); - - for (var i = 0; i < prefixes.length; i += 1) { - var tryFunc = prefixes[i] + stdName; - var tryVal = tryFunc + '(to right, rgba(0,0,0,0), rgba(0,0,0,0))'; - - helper.style.background = tryVal; - if (helper.style.background) { // CSS background successfully set -> function name is supported - return tryFunc; - } - } - return stdName; // fallback to standard 'linear-gradient' without vendor prefix - } - - var funcName = getFuncName(); - - return function () { - return funcName + '(' + Array.prototype.join.call(arguments, ', ') + ')'; - }; - - })(), - - - setBorderRadius : function (elm, value) { - jsc.setStyle(elm, {'border-radius' : value || '0'}); - }, - - - setBoxShadow : function (elm, value) { - jsc.setStyle(elm, {'box-shadow': value || 'none'}); - }, - - - getElementPos : function (e, relativeToViewport) { - var x=0, y=0; - var rect = e.getBoundingClientRect(); - x = rect.left; - y = rect.top; - if (!relativeToViewport) { - var viewPos = jsc.getViewPos(); - x += viewPos[0]; - y += viewPos[1]; - } - return [x, y]; - }, - - - getElementSize : function (e) { - return [e.offsetWidth, e.offsetHeight]; - }, - - - // get pointer's X/Y coordinates relative to viewport - getAbsPointerPos : function (e) { - var x = 0, y = 0; - if (typeof e.changedTouches !== 'undefined' && e.changedTouches.length) { - // touch devices - x = e.changedTouches[0].clientX; - y = e.changedTouches[0].clientY; - } else if (typeof e.clientX === 'number') { - x = e.clientX; - y = e.clientY; - } - return { x: x, y: y }; - }, - - - // get pointer's X/Y coordinates relative to target element - getRelPointerPos : function (e) { - var target = e.target || e.srcElement; - var targetRect = target.getBoundingClientRect(); - - var x = 0, y = 0; - - var clientX = 0, clientY = 0; - if (typeof e.changedTouches !== 'undefined' && e.changedTouches.length) { - // touch devices - clientX = e.changedTouches[0].clientX; - clientY = e.changedTouches[0].clientY; - } else if (typeof e.clientX === 'number') { - clientX = e.clientX; - clientY = e.clientY; - } - - x = clientX - targetRect.left; - y = clientY - targetRect.top; - return { x: x, y: y }; - }, - - - getViewPos : function () { - var doc = window.document.documentElement; - return [ - (window.pageXOffset || doc.scrollLeft) - (doc.clientLeft || 0), - (window.pageYOffset || doc.scrollTop) - (doc.clientTop || 0) - ]; - }, - - - getViewSize : function () { - var doc = window.document.documentElement; - return [ - (window.innerWidth || doc.clientWidth), - (window.innerHeight || doc.clientHeight), - ]; - }, - - - // r: 0-255 - // g: 0-255 - // b: 0-255 - // - // returns: [ 0-360, 0-100, 0-100 ] - // - RGB_HSV : function (r, g, b) { - r /= 255; - g /= 255; - b /= 255; - var n = Math.min(Math.min(r,g),b); - var v = Math.max(Math.max(r,g),b); - var m = v - n; - if (m === 0) { return [ null, 0, 100 * v ]; } - var h = r===n ? 3+(b-g)/m : (g===n ? 5+(r-b)/m : 1+(g-r)/m); - return [ - 60 * (h===6?0:h), - 100 * (m/v), - 100 * v - ]; - }, - - - // h: 0-360 - // s: 0-100 - // v: 0-100 - // - // returns: [ 0-255, 0-255, 0-255 ] - // - HSV_RGB : function (h, s, v) { - var u = 255 * (v / 100); - - if (h === null) { - return [ u, u, u ]; - } - - h /= 60; - s /= 100; - - var i = Math.floor(h); - var f = i%2 ? h-i : 1-(h-i); - var m = u * (1 - s); - var n = u * (1 - s * f); - switch (i) { - case 6: - case 0: return [u,n,m]; - case 1: return [n,u,m]; - case 2: return [m,u,n]; - case 3: return [m,n,u]; - case 4: return [n,m,u]; - case 5: return [u,m,n]; - } - }, - - - parseColorString : function (str) { - var ret = { - rgba: null, - format: null // 'hex' | 'hexa' | 'rgb' | 'rgba' - }; - - var m; - - if (m = str.match(/^\W*([0-9A-F]{3,8})\W*$/i)) { - // HEX notation - - if (m[1].length === 8) { - // 8-char notation (= with alpha) - ret.format = 'hexa'; - ret.rgba = [ - parseInt(m[1].slice(0,2),16), - parseInt(m[1].slice(2,4),16), - parseInt(m[1].slice(4,6),16), - parseInt(m[1].slice(6,8),16) / 255 - ]; - - } else if (m[1].length === 6) { - // 6-char notation - ret.format = 'hex'; - ret.rgba = [ - parseInt(m[1].slice(0,2),16), - parseInt(m[1].slice(2,4),16), - parseInt(m[1].slice(4,6),16), - null - ]; - - } else if (m[1].length === 3) { - // 3-char notation - ret.format = 'hex'; - ret.rgba = [ - parseInt(m[1].charAt(0) + m[1].charAt(0),16), - parseInt(m[1].charAt(1) + m[1].charAt(1),16), - parseInt(m[1].charAt(2) + m[1].charAt(2),16), - null - ]; - - } else { - return false; - } - - return ret; - } - - if (m = str.match(/^\W*rgba?\(([^)]*)\)\W*$/i)) { - // rgb(...) or rgba(...) notation - - var par = m[1].split(','); - var re = /^\s*(\d+|\d*\.\d+|\d+\.\d*)\s*$/; - var mR, mG, mB, mA; - if ( - par.length >= 3 && - (mR = par[0].match(re)) && - (mG = par[1].match(re)) && - (mB = par[2].match(re)) - ) { - ret.format = 'rgb'; - ret.rgba = [ - parseFloat(mR[1]) || 0, - parseFloat(mG[1]) || 0, - parseFloat(mB[1]) || 0, - null - ]; - - if ( - par.length >= 4 && - (mA = par[3].match(re)) - ) { - ret.format = 'rgba'; - ret.rgba[3] = parseFloat(mA[1]) || 0; - } - return ret; - } - } - - return false; - }, - - - parsePaletteValue : function (mixed) { - var vals = []; - - if (typeof mixed === 'string') { // input is a string of space separated color values - // rgb() and rgba() may contain spaces too, so let's find all color values by regex - mixed.replace(/#[0-9A-F]{3}([0-9A-F]{3})?|rgba?\(([^)]*)\)/ig, function (val) { - vals.push(val); - }); - } else if (Array.isArray(mixed)) { // input is an array of color values - vals = mixed; - } - - // convert all values into uniform color format - - var colors = []; - - for (var i = 0; i < vals.length; i++) { - var color = jsc.parseColorString(vals[i]); - if (color) { - colors.push(color); - } - } - - return colors; - }, - - - containsTranparentColor : function (colors) { - for (var i = 0; i < colors.length; i++) { - var a = colors[i].rgba[3]; - if (a !== null && a < 1.0) { - return true; - } - } - return false; - }, - - - isAlphaFormat : function (format) { - switch (format.toLowerCase()) { - case 'hexa': - case 'rgba': - return true; - } - return false; - }, - - - // Canvas scaling for retina displays - // - // adapted from https://www.html5rocks.com/en/tutorials/canvas/hidpi/ - // - scaleCanvasForHighDPR : function (canvas) { - var dpr = window.devicePixelRatio || 1; - canvas.width *= dpr; - canvas.height *= dpr; - var ctx = canvas.getContext('2d'); - ctx.scale(dpr, dpr); - }, - - - genColorPreviewCanvas : function (color, separatorPos, specWidth, scaleForHighDPR) { - - var sepW = Math.round(jsc.pub.previewSeparator.length); - var sqSize = jsc.pub.chessboardSize; - var sqColor1 = jsc.pub.chessboardColor1; - var sqColor2 = jsc.pub.chessboardColor2; - - var cWidth = specWidth ? specWidth : sqSize * 2; - var cHeight = sqSize * 2; - - var canvas = jsc.createEl('canvas'); - var ctx = canvas.getContext('2d'); - - canvas.width = cWidth; - canvas.height = cHeight; - if (scaleForHighDPR) { - jsc.scaleCanvasForHighDPR(canvas); - } - - // transparency chessboard - background - ctx.fillStyle = sqColor1; - ctx.fillRect(0, 0, cWidth, cHeight); - - // transparency chessboard - squares - ctx.fillStyle = sqColor2; - for (var x = 0; x < cWidth; x += sqSize * 2) { - ctx.fillRect(x, 0, sqSize, sqSize); - ctx.fillRect(x + sqSize, sqSize, sqSize, sqSize); - } - - if (color) { - // actual color in foreground - ctx.fillStyle = color; - ctx.fillRect(0, 0, cWidth, cHeight); - } - - var start = null; - switch (separatorPos) { - case 'left': - start = 0; - ctx.clearRect(0, 0, sepW/2, cHeight); - break; - case 'right': - start = cWidth - sepW; - ctx.clearRect(cWidth - (sepW/2), 0, sepW/2, cHeight); - break; - } - if (start !== null) { - ctx.lineWidth = 1; - for (var i = 0; i < jsc.pub.previewSeparator.length; i += 1) { - ctx.beginPath(); - ctx.strokeStyle = jsc.pub.previewSeparator[i]; - ctx.moveTo(0.5 + start + i, 0); - ctx.lineTo(0.5 + start + i, cHeight); - ctx.stroke(); - } - } - - return { - canvas: canvas, - width: cWidth, - height: cHeight, - }; - }, - - - // if position or width is not set => fill the entire element (0%-100%) - genColorPreviewGradient : function (color, position, width) { - var params = []; - - if (position && width) { - params = [ - 'to ' + {'left':'right', 'right':'left'}[position], - color + ' 0%', - color + ' ' + width + 'px', - 'rgba(0,0,0,0) ' + (width + 1) + 'px', - 'rgba(0,0,0,0) 100%', - ]; - } else { - params = [ - 'to right', - color + ' 0%', - color + ' 100%', - ]; - } - - return jsc.linearGradient.apply(this, params); - }, - - - redrawPosition : function () { - - if (!jsc.picker || !jsc.picker.owner) { - return; // picker is not shown - } - - var thisObj = jsc.picker.owner; - - if (thisObj.container !== window.document.body) { - - jsc._drawPosition(thisObj, 0, 0, 'relative', false); - - } else { - - var tp, vp; - - if (thisObj.fixed) { - // Fixed elements are positioned relative to viewport, - // therefore we can ignore the scroll offset - tp = jsc.getElementPos(thisObj.targetElement, true); // target pos - vp = [0, 0]; // view pos - } else { - tp = jsc.getElementPos(thisObj.targetElement); // target pos - vp = jsc.getViewPos(); // view pos - } - - var ts = jsc.getElementSize(thisObj.targetElement); // target size - var vs = jsc.getViewSize(); // view size - var pd = jsc.getPickerDims(thisObj); - var ps = [pd.borderW, pd.borderH]; // picker outer size - var a, b, c; - switch (thisObj.position.toLowerCase()) { - case 'left': a=1; b=0; c=-1; break; - case 'right':a=1; b=0; c=1; break; - case 'top': a=0; b=1; c=-1; break; - default: a=0; b=1; c=1; break; - } - var l = (ts[b]+ps[b])/2; - - // compute picker position - if (!thisObj.smartPosition) { - var pp = [ - tp[a], - tp[b]+ts[b]-l+l*c - ]; - } else { - var pp = [ - -vp[a]+tp[a]+ps[a] > vs[a] ? - (-vp[a]+tp[a]+ts[a]/2 > vs[a]/2 && tp[a]+ts[a]-ps[a] >= 0 ? tp[a]+ts[a]-ps[a] : tp[a]) : - tp[a], - -vp[b]+tp[b]+ts[b]+ps[b]-l+l*c > vs[b] ? - (-vp[b]+tp[b]+ts[b]/2 > vs[b]/2 && tp[b]+ts[b]-l-l*c >= 0 ? tp[b]+ts[b]-l-l*c : tp[b]+ts[b]-l+l*c) : - (tp[b]+ts[b]-l+l*c >= 0 ? tp[b]+ts[b]-l+l*c : tp[b]+ts[b]-l-l*c) - ]; - } - - var x = pp[a]; - var y = pp[b]; - var positionValue = thisObj.fixed ? 'fixed' : 'absolute'; - var contractShadow = - (pp[0] + ps[0] > tp[0] || pp[0] < tp[0] + ts[0]) && - (pp[1] + ps[1] < tp[1] + ts[1]); - - jsc._drawPosition(thisObj, x, y, positionValue, contractShadow); - - } - - }, - - - _drawPosition : function (thisObj, x, y, positionValue, contractShadow) { - var vShadow = contractShadow ? 0 : thisObj.shadowBlur; // px - - jsc.picker.wrap.style.position = positionValue; - jsc.picker.wrap.style.left = x + 'px'; - jsc.picker.wrap.style.top = y + 'px'; - - jsc.setBoxShadow( - jsc.picker.boxS, - thisObj.shadow ? - new jsc.BoxShadow(0, vShadow, thisObj.shadowBlur, 0, thisObj.shadowColor) : - null); - }, - - - getPickerDims : function (thisObj) { - var w = 2 * thisObj.controlBorderWidth + thisObj.width; - var h = 2 * thisObj.controlBorderWidth + thisObj.height; - - var sliderSpace = 2 * thisObj.controlBorderWidth + 2 * jsc.getControlPadding(thisObj) + thisObj.sliderSize; - - if (jsc.getSliderChannel(thisObj)) { - w += sliderSpace; - } - if (thisObj.hasAlphaChannel()) { - w += sliderSpace; - } - - var pal = jsc.getPaletteDims(thisObj, w); - - if (pal.height) { - h += pal.height + thisObj.padding; - } - if (thisObj.closeButton) { - h += 2 * thisObj.controlBorderWidth + thisObj.padding + thisObj.buttonHeight; - } - - var pW = w + (2 * thisObj.padding); - var pH = h + (2 * thisObj.padding); - - return { - contentW: w, - contentH: h, - paddedW: pW, - paddedH: pH, - borderW: pW + (2 * thisObj.borderWidth), - borderH: pH + (2 * thisObj.borderWidth), - palette: pal, - }; - }, - - - getPaletteDims : function (thisObj, width) { - var cols = 0, rows = 0, cellW = 0, cellH = 0, height = 0; - var sampleCount = thisObj._palette ? thisObj._palette.length : 0; - - if (sampleCount) { - cols = thisObj.paletteCols; - rows = cols > 0 ? Math.ceil(sampleCount / cols) : 0; - - // color sample's dimensions (includes border) - cellW = Math.max(1, Math.floor((width - ((cols - 1) * thisObj.paletteSpacing)) / cols)); - cellH = thisObj.paletteHeight ? Math.min(thisObj.paletteHeight, cellW) : cellW; - } - - if (rows) { - height = - rows * cellH + - (rows - 1) * thisObj.paletteSpacing; - } - - return { - cols: cols, - rows: rows, - cellW: cellW, - cellH: cellH, - width: width, - height: height, - }; - }, - - - getControlPadding : function (thisObj) { - return Math.max( - thisObj.padding / 2, - (2 * thisObj.pointerBorderWidth + thisObj.pointerThickness) - thisObj.controlBorderWidth - ); - }, - - - getPadYChannel : function (thisObj) { - switch (thisObj.mode.charAt(1).toLowerCase()) { - case 'v': return 'v'; break; - } - return 's'; - }, - - - getSliderChannel : function (thisObj) { - if (thisObj.mode.length > 2) { - switch (thisObj.mode.charAt(2).toLowerCase()) { - case 's': return 's'; break; - case 'v': return 'v'; break; - } - } - return null; - }, - - - // calls function specified in picker's property - triggerCallback : function (thisObj, prop) { - if (!thisObj[prop]) { - return; // callback func not specified - } - var callback = null; - - if (typeof thisObj[prop] === 'string') { - // string with code - try { - callback = new Function (thisObj[prop]); - } catch (e) { - console.error(e); - } - } else { - // function - callback = thisObj[prop]; - } - - if (callback) { - callback.call(thisObj); - } - }, - - - // Triggers a color change related event(s) on all picker instances. - // It is possible to specify multiple events separated with a space. - triggerGlobal : function (eventNames) { - var inst = jsc.getInstances(); - for (var i = 0; i < inst.length; i += 1) { - inst[i].trigger(eventNames); - } - }, - - - _pointerMoveEvent : { - mouse: 'mousemove', - touch: 'touchmove' - }, - _pointerEndEvent : { - mouse: 'mouseup', - touch: 'touchend' - }, - - - _pointerOrigin : null, - - - onDocumentKeyUp : function (e) { - if (['Tab', 'Escape'].indexOf(jsc.eventKey(e)) !== -1) { - if (jsc.picker && jsc.picker.owner) { - jsc.picker.owner.tryHide(); - } - } - }, - - - onWindowResize : function (e) { - jsc.redrawPosition(); - }, - - - onWindowScroll : function (e) { - jsc.redrawPosition(); - }, - - - onParentScroll : function (e) { - // hide the picker when one of the parent elements is scrolled - if (jsc.picker && jsc.picker.owner) { - jsc.picker.owner.tryHide(); - } - }, - - - onDocumentMouseDown : function (e) { - var target = e.target || e.srcElement; - - if (target.jscolor && target.jscolor instanceof jsc.pub) { // clicked targetElement -> show picker - if (target.jscolor.showOnClick && !target.disabled) { - target.jscolor.show(); - } - } else if (jsc.getData(target, 'gui')) { // clicked jscolor's GUI element - var control = jsc.getData(target, 'control'); - if (control) { - // jscolor's control - jsc.onControlPointerStart(e, target, jsc.getData(target, 'control'), 'mouse'); - } - } else { - // mouse is outside the picker's controls -> hide the color picker! - if (jsc.picker && jsc.picker.owner) { - jsc.picker.owner.tryHide(); - } - } - }, - - - onPickerTouchStart : function (e) { - var target = e.target || e.srcElement; - - if (jsc.getData(target, 'control')) { - jsc.onControlPointerStart(e, target, jsc.getData(target, 'control'), 'touch'); - } - }, - - - onControlPointerStart : function (e, target, controlName, pointerType) { - var thisObj = jsc.getData(target, 'instance'); - - jsc.preventDefault(e); - - var registerDragEvents = function (doc, offset) { - jsc.attachGroupEvent('drag', doc, jsc._pointerMoveEvent[pointerType], - jsc.onDocumentPointerMove(e, target, controlName, pointerType, offset)); - jsc.attachGroupEvent('drag', doc, jsc._pointerEndEvent[pointerType], - jsc.onDocumentPointerEnd(e, target, controlName, pointerType)); - }; - - registerDragEvents(window.document, [0, 0]); - - if (window.parent && window.frameElement) { - var rect = window.frameElement.getBoundingClientRect(); - var ofs = [-rect.left, -rect.top]; - registerDragEvents(window.parent.window.document, ofs); - } - - var abs = jsc.getAbsPointerPos(e); - var rel = jsc.getRelPointerPos(e); - jsc._pointerOrigin = { - x: abs.x - rel.x, - y: abs.y - rel.y - }; - - switch (controlName) { - case 'pad': - // if the value slider is at the bottom, move it up - if (jsc.getSliderChannel(thisObj) === 'v' && thisObj.channels.v === 0) { - thisObj.fromHSVA(null, null, 100, null); - } - jsc.setPad(thisObj, e, 0, 0); - break; - - case 'sld': - jsc.setSld(thisObj, e, 0); - break; - - case 'asld': - jsc.setASld(thisObj, e, 0); - break; - } - thisObj.trigger('input'); - }, - - - onDocumentPointerMove : function (e, target, controlName, pointerType, offset) { - return function (e) { - var thisObj = jsc.getData(target, 'instance'); - switch (controlName) { - case 'pad': - jsc.setPad(thisObj, e, offset[0], offset[1]); - break; - - case 'sld': - jsc.setSld(thisObj, e, offset[1]); - break; - - case 'asld': - jsc.setASld(thisObj, e, offset[1]); - break; - } - thisObj.trigger('input'); - } - }, - - - onDocumentPointerEnd : function (e, target, controlName, pointerType) { - return function (e) { - var thisObj = jsc.getData(target, 'instance'); - jsc.detachGroupEvents('drag'); - - // Always trigger changes AFTER detaching outstanding mouse handlers, - // in case some color change that occured in user-defined onChange/onInput handler - // intruded into current mouse events - thisObj.trigger('input'); - thisObj.trigger('change'); - }; - }, - - - onPaletteSampleClick : function (e) { - var target = e.currentTarget; - var thisObj = jsc.getData(target, 'instance'); - var color = jsc.getData(target, 'color'); - - // when format is flexible, use the original format of this color sample - if (thisObj.format.toLowerCase() === 'any') { - thisObj._setFormat(color.format); // adapt format - if (!jsc.isAlphaFormat(thisObj.getFormat())) { - color.rgba[3] = 1.0; // when switching to a format that doesn't support alpha, set full opacity - } - } - - // if this color doesn't specify alpha, use alpha of 1.0 (if applicable) - if (color.rgba[3] === null) { - if (thisObj.paletteSetsAlpha === true || (thisObj.paletteSetsAlpha === 'auto' && thisObj._paletteHasTransparency)) { - color.rgba[3] = 1.0; - } - } - - thisObj.fromRGBA.apply(thisObj, color.rgba); - - thisObj.trigger('input'); - thisObj.trigger('change'); - - if (thisObj.hideOnPaletteClick) { - thisObj.hide(); - } - }, - - - setPad : function (thisObj, e, ofsX, ofsY) { - var pointerAbs = jsc.getAbsPointerPos(e); - var x = ofsX + pointerAbs.x - jsc._pointerOrigin.x - thisObj.padding - thisObj.controlBorderWidth; - var y = ofsY + pointerAbs.y - jsc._pointerOrigin.y - thisObj.padding - thisObj.controlBorderWidth; - - var xVal = x * (360 / (thisObj.width - 1)); - var yVal = 100 - (y * (100 / (thisObj.height - 1))); - - switch (jsc.getPadYChannel(thisObj)) { - case 's': thisObj.fromHSVA(xVal, yVal, null, null); break; - case 'v': thisObj.fromHSVA(xVal, null, yVal, null); break; - } - }, - - - setSld : function (thisObj, e, ofsY) { - var pointerAbs = jsc.getAbsPointerPos(e); - var y = ofsY + pointerAbs.y - jsc._pointerOrigin.y - thisObj.padding - thisObj.controlBorderWidth; - var yVal = 100 - (y * (100 / (thisObj.height - 1))); - - switch (jsc.getSliderChannel(thisObj)) { - case 's': thisObj.fromHSVA(null, yVal, null, null); break; - case 'v': thisObj.fromHSVA(null, null, yVal, null); break; - } - }, - - - setASld : function (thisObj, e, ofsY) { - var pointerAbs = jsc.getAbsPointerPos(e); - var y = ofsY + pointerAbs.y - jsc._pointerOrigin.y - thisObj.padding - thisObj.controlBorderWidth; - var yVal = 1.0 - (y * (1.0 / (thisObj.height - 1))); - - if (yVal < 1.0) { - // if format is flexible and the current format doesn't support alpha, switch to a suitable one - var fmt = thisObj.getFormat(); - if (thisObj.format.toLowerCase() === 'any' && !jsc.isAlphaFormat(fmt)) { - thisObj._setFormat(fmt === 'hex' ? 'hexa' : 'rgba'); - } - } - - thisObj.fromHSVA(null, null, null, yVal); - }, - - - createPadCanvas : function () { - - var ret = { - elm: null, - draw: null - }; - - var canvas = jsc.createEl('canvas'); - var ctx = canvas.getContext('2d'); - - var drawFunc = function (width, height, type) { - canvas.width = width; - canvas.height = height; - - ctx.clearRect(0, 0, canvas.width, canvas.height); - - var hGrad = ctx.createLinearGradient(0, 0, canvas.width, 0); - hGrad.addColorStop(0 / 6, '#F00'); - hGrad.addColorStop(1 / 6, '#FF0'); - hGrad.addColorStop(2 / 6, '#0F0'); - hGrad.addColorStop(3 / 6, '#0FF'); - hGrad.addColorStop(4 / 6, '#00F'); - hGrad.addColorStop(5 / 6, '#F0F'); - hGrad.addColorStop(6 / 6, '#F00'); - - ctx.fillStyle = hGrad; - ctx.fillRect(0, 0, canvas.width, canvas.height); - - var vGrad = ctx.createLinearGradient(0, 0, 0, canvas.height); - switch (type.toLowerCase()) { - case 's': - vGrad.addColorStop(0, 'rgba(255,255,255,0)'); - vGrad.addColorStop(1, 'rgba(255,255,255,1)'); - break; - case 'v': - vGrad.addColorStop(0, 'rgba(0,0,0,0)'); - vGrad.addColorStop(1, 'rgba(0,0,0,1)'); - break; - } - ctx.fillStyle = vGrad; - ctx.fillRect(0, 0, canvas.width, canvas.height); - }; - - ret.elm = canvas; - ret.draw = drawFunc; - - return ret; - }, - - - createSliderGradient : function () { - - var ret = { - elm: null, - draw: null - }; - - var canvas = jsc.createEl('canvas'); - var ctx = canvas.getContext('2d'); - - var drawFunc = function (width, height, color1, color2) { - canvas.width = width; - canvas.height = height; - - ctx.clearRect(0, 0, canvas.width, canvas.height); - - var grad = ctx.createLinearGradient(0, 0, 0, canvas.height); - grad.addColorStop(0, color1); - grad.addColorStop(1, color2); - - ctx.fillStyle = grad; - ctx.fillRect(0, 0, canvas.width, canvas.height); - }; - - ret.elm = canvas; - ret.draw = drawFunc; - - return ret; - }, - - - createASliderGradient : function () { - - var ret = { - elm: null, - draw: null - }; - - var canvas = jsc.createEl('canvas'); - var ctx = canvas.getContext('2d'); - - var drawFunc = function (width, height, color) { - canvas.width = width; - canvas.height = height; - - ctx.clearRect(0, 0, canvas.width, canvas.height); - - var sqSize = canvas.width / 2; - var sqColor1 = jsc.pub.chessboardColor1; - var sqColor2 = jsc.pub.chessboardColor2; - - // dark gray background - ctx.fillStyle = sqColor1; - ctx.fillRect(0, 0, canvas.width, canvas.height); - - if (sqSize > 0) { // to avoid infinite loop - for (var y = 0; y < canvas.height; y += sqSize * 2) { - // light gray squares - ctx.fillStyle = sqColor2; - ctx.fillRect(0, y, sqSize, sqSize); - ctx.fillRect(sqSize, y + sqSize, sqSize, sqSize); - } - } - - var grad = ctx.createLinearGradient(0, 0, 0, canvas.height); - grad.addColorStop(0, color); - grad.addColorStop(1, 'rgba(0,0,0,0)'); - - ctx.fillStyle = grad; - ctx.fillRect(0, 0, canvas.width, canvas.height); - }; - - ret.elm = canvas; - ret.draw = drawFunc; - - return ret; - }, - - - BoxShadow : (function () { - var BoxShadow = function (hShadow, vShadow, blur, spread, color, inset) { - this.hShadow = hShadow; - this.vShadow = vShadow; - this.blur = blur; - this.spread = spread; - this.color = color; - this.inset = !!inset; - }; - - BoxShadow.prototype.toString = function () { - var vals = [ - Math.round(this.hShadow) + 'px', - Math.round(this.vShadow) + 'px', - Math.round(this.blur) + 'px', - Math.round(this.spread) + 'px', - this.color - ]; - if (this.inset) { - vals.push('inset'); - } - return vals.join(' '); - }; - - return BoxShadow; - })(), - - - flags : { - leaveValue : 1 << 0, - leaveAlpha : 1 << 1, - leavePreview : 1 << 2, - }, - - - enumOpts : { - format: ['auto', 'any', 'hex', 'hexa', 'rgb', 'rgba'], - previewPosition: ['left', 'right'], - mode: ['hsv', 'hvs', 'hs', 'hv'], - position: ['left', 'right', 'top', 'bottom'], - alphaChannel: ['auto', true, false], - paletteSetsAlpha: ['auto', true, false], - }, - - - deprecatedOpts : { - // : ( can be null) - 'styleElement': 'previewElement', - 'onFineChange': 'onInput', - 'overwriteImportant': 'forceStyle', - 'closable': 'closeButton', - 'insetWidth': 'controlBorderWidth', - 'insetColor': 'controlBorderColor', - 'refine': null, - }, - - - docsRef : ' ' + 'See https://jscolor.com/docs/', - - - // - // Usage: - // var myPicker = new JSColor( [, ]) - // - // (constructor is accessible via both 'jscolor' and 'JSColor' name) - // - - pub : function (targetElement, opts) { - - var THIS = this; - - if (!opts) { - opts = {}; - } - - this.channels = { - r: 255, // red [0-255] - g: 255, // green [0-255] - b: 255, // blue [0-255] - h: 0, // hue [0-360] - s: 0, // saturation [0-100] - v: 100, // value (brightness) [0-100] - a: 1.0, // alpha (opacity) [0.0 - 1.0] - }; - - // General options - // - this.format = 'auto'; // 'auto' | 'any' | 'hex' | 'hexa' | 'rgb' | 'rgba' - Format of the input/output value - this.value = undefined; // INITIAL color value in any supported format. To change it later, use method fromString(), fromHSVA(), fromRGBA() or channel() - this.alpha = undefined; // INITIAL alpha value. To change it later, call method channel('A', ) - this.random = false; // whether to randomize the initial color. Either true | false, or an array of ranges: [minV, maxV, minS, maxS, minH, maxH, minA, maxA] - this.onChange = undefined; // called when color changes. Value can be either a function or a string with JS code. - this.onInput = undefined; // called repeatedly as the color is being changed, e.g. while dragging a slider. Value can be either a function or a string with JS code. - this.valueElement = undefined; // element that will be used to display and input the color value - this.alphaElement = undefined; // element that will be used to display and input the alpha (opacity) value - this.previewElement = undefined; // element that will preview the picked color using CSS background - this.previewPosition = 'left'; // 'left' | 'right' - position of the color preview in previewElement - this.previewSize = 32; // (px) width of the color preview displayed in previewElement - this.previewPadding = 8; // (px) space between color preview and content of the previewElement - this.required = true; // whether the associated text input must always contain a color value. If false, the input can be left empty. - this.hash = true; // whether to prefix the HEX color code with # symbol (only applicable for HEX format) - this.uppercase = true; // whether to show the HEX color code in upper case (only applicable for HEX format) - this.forceStyle = true; // whether to overwrite CSS style of the previewElement using !important flag - - // Color Picker options - // - this.width = 181; // width of the color spectrum (in px) - this.height = 101; // height of the color spectrum (in px) - this.mode = 'HSV'; // 'HSV' | 'HVS' | 'HS' | 'HV' - layout of the color picker controls - this.alphaChannel = 'auto'; // 'auto' | true | false - if alpha channel is enabled, the alpha slider will be visible. If 'auto', it will be determined according to color format - this.position = 'bottom'; // 'left' | 'right' | 'top' | 'bottom' - position relative to the target element - this.smartPosition = true; // automatically change picker position when there is not enough space for it - this.showOnClick = true; // whether to show the picker when user clicks its target element - this.hideOnLeave = true; // whether to automatically hide the picker when user leaves its target element (e.g. upon clicking the document) - this.palette = []; // colors to be displayed in the palette, specified as an array or a string of space separated color values (in any supported format) - this.paletteCols = 10; // number of columns in the palette - this.paletteSetsAlpha = 'auto'; // 'auto' | true | false - if true, palette colors that don't specify alpha will set alpha to 1.0 - this.paletteHeight = 16; // maximum height (px) of a row in the palette - this.paletteSpacing = 4; // distance (px) between color samples in the palette - this.hideOnPaletteClick = false; // when set to true, clicking the palette will also hide the color picker - this.sliderSize = 16; // px - this.crossSize = 8; // px - this.closeButton = false; // whether to display the Close button - this.closeText = 'Close'; - this.buttonColor = 'rgba(0,0,0,1)'; // CSS color - this.buttonHeight = 18; // px - this.padding = 12; // px - this.backgroundColor = 'rgba(255,255,255,1)'; // CSS color - this.borderWidth = 1; // px - this.borderColor = 'rgba(187,187,187,1)'; // CSS color - this.borderRadius = 8; // px - this.controlBorderWidth = 1; // px - this.controlBorderColor = 'rgba(187,187,187,1)'; // CSS color - this.shadow = true; // whether to display a shadow - this.shadowBlur = 15; // px - this.shadowColor = 'rgba(0,0,0,0.2)'; // CSS color - this.pointerColor = 'rgba(76,76,76,1)'; // CSS color - this.pointerBorderWidth = 1; // px - this.pointerBorderColor = 'rgba(255,255,255,1)'; // CSS color - this.pointerThickness = 2; // px - this.zIndex = 5000; - this.container = undefined; // where to append the color picker (BODY element by default) - - // Experimental - // - this.minS = 0; // min allowed saturation (0 - 100) - this.maxS = 100; // max allowed saturation (0 - 100) - this.minV = 0; // min allowed value (brightness) (0 - 100) - this.maxV = 100; // max allowed value (brightness) (0 - 100) - this.minA = 0.0; // min allowed alpha (opacity) (0.0 - 1.0) - this.maxA = 1.0; // max allowed alpha (opacity) (0.0 - 1.0) - - - // Getter: option(name) - // Setter: option(name, value) - // option({name:value, ...}) - // - this.option = function () { - if (!arguments.length) { - throw new Error('No option specified'); - } - - if (arguments.length === 1 && typeof arguments[0] === 'string') { - // getting a single option - try { - return getOption(arguments[0]); - } catch (e) { - console.warn(e); - } - return false; - - } else if (arguments.length >= 2 && typeof arguments[0] === 'string') { - // setting a single option - try { - if (!setOption(arguments[0], arguments[1])) { - return false; - } - } catch (e) { - console.warn(e); - return false; - } - this.redraw(); // immediately redraws the picker, if it's displayed - this.exposeColor(); // in case some preview-related or format-related option was changed - return true; - - } else if (arguments.length === 1 && typeof arguments[0] === 'object') { - // setting multiple options - var opts = arguments[0]; - var success = true; - for (var opt in opts) { - if (opts.hasOwnProperty(opt)) { - try { - if (!setOption(opt, opts[opt])) { - success = false; - } - } catch (e) { - console.warn(e); - success = false; - } - } - } - this.redraw(); // immediately redraws the picker, if it's displayed - this.exposeColor(); // in case some preview-related or format-related option was changed - return success; - } - - throw new Error('Invalid arguments'); - } - - - // Getter: channel(name) - // Setter: channel(name, value) - // - this.channel = function (name, value) { - if (typeof name !== 'string') { - throw new Error('Invalid value for channel name: ' + name); - } - - if (value === undefined) { - // getting channel value - if (!this.channels.hasOwnProperty(name.toLowerCase())) { - console.warn('Getting unknown channel: ' + name); - return false; - } - return this.channels[name.toLowerCase()]; - - } else { - // setting channel value - var res = false; - switch (name.toLowerCase()) { - case 'r': res = this.fromRGBA(value, null, null, null); break; - case 'g': res = this.fromRGBA(null, value, null, null); break; - case 'b': res = this.fromRGBA(null, null, value, null); break; - case 'h': res = this.fromHSVA(value, null, null, null); break; - case 's': res = this.fromHSVA(null, value, null, null); break; - case 'v': res = this.fromHSVA(null, null, value, null); break; - case 'a': res = this.fromHSVA(null, null, null, value); break; - default: - console.warn('Setting unknown channel: ' + name); - return false; - } - if (res) { - this.redraw(); // immediately redraws the picker, if it's displayed - return true; - } - } - - return false; - } - - - // Triggers given input event(s) by: - // - executing on callback specified as picker's option - // - triggering standard DOM event listeners attached to the value element - // - // It is possible to specify multiple events separated with a space. - // - this.trigger = function (eventNames) { - var evs = jsc.strList(eventNames); - for (var i = 0; i < evs.length; i += 1) { - var ev = evs[i].toLowerCase(); - - // trigger a callback - var callbackProp = null; - switch (ev) { - case 'input': callbackProp = 'onInput'; break; - case 'change': callbackProp = 'onChange'; break; - } - if (callbackProp) { - jsc.triggerCallback(this, callbackProp); - } - - // trigger standard DOM event listeners on the value element - jsc.triggerInputEvent(this.valueElement, ev, true, true); - } - }; - - - // h: 0-360 - // s: 0-100 - // v: 0-100 - // a: 0.0-1.0 - // - this.fromHSVA = function (h, s, v, a, flags) { // null = don't change - if (h === undefined) { h = null; } - if (s === undefined) { s = null; } - if (v === undefined) { v = null; } - if (a === undefined) { a = null; } - - if (h !== null) { - if (isNaN(h)) { return false; } - this.channels.h = Math.max(0, Math.min(360, h)); - } - if (s !== null) { - if (isNaN(s)) { return false; } - this.channels.s = Math.max(0, Math.min(100, this.maxS, s), this.minS); - } - if (v !== null) { - if (isNaN(v)) { return false; } - this.channels.v = Math.max(0, Math.min(100, this.maxV, v), this.minV); - } - if (a !== null) { - if (isNaN(a)) { return false; } - this.channels.a = this.hasAlphaChannel() ? - Math.max(0, Math.min(1, this.maxA, a), this.minA) : - 1.0; // if alpha channel is disabled, the color should stay 100% opaque - } - - var rgb = jsc.HSV_RGB( - this.channels.h, - this.channels.s, - this.channels.v - ); - this.channels.r = rgb[0]; - this.channels.g = rgb[1]; - this.channels.b = rgb[2]; - - this.exposeColor(flags); - return true; - }; - - - // r: 0-255 - // g: 0-255 - // b: 0-255 - // a: 0.0-1.0 - // - this.fromRGBA = function (r, g, b, a, flags) { // null = don't change - if (r === undefined) { r = null; } - if (g === undefined) { g = null; } - if (b === undefined) { b = null; } - if (a === undefined) { a = null; } - - if (r !== null) { - if (isNaN(r)) { return false; } - r = Math.max(0, Math.min(255, r)); - } - if (g !== null) { - if (isNaN(g)) { return false; } - g = Math.max(0, Math.min(255, g)); - } - if (b !== null) { - if (isNaN(b)) { return false; } - b = Math.max(0, Math.min(255, b)); - } - if (a !== null) { - if (isNaN(a)) { return false; } - this.channels.a = this.hasAlphaChannel() ? - Math.max(0, Math.min(1, this.maxA, a), this.minA) : - 1.0; // if alpha channel is disabled, the color should stay 100% opaque - } - - var hsv = jsc.RGB_HSV( - r===null ? this.channels.r : r, - g===null ? this.channels.g : g, - b===null ? this.channels.b : b - ); - if (hsv[0] !== null) { - this.channels.h = Math.max(0, Math.min(360, hsv[0])); - } - if (hsv[2] !== 0) { // fully black color stays black through entire saturation range, so let's not change saturation - this.channels.s = Math.max(0, this.minS, Math.min(100, this.maxS, hsv[1])); - } - this.channels.v = Math.max(0, this.minV, Math.min(100, this.maxV, hsv[2])); - - // update RGB according to final HSV, as some values might be trimmed - var rgb = jsc.HSV_RGB(this.channels.h, this.channels.s, this.channels.v); - this.channels.r = rgb[0]; - this.channels.g = rgb[1]; - this.channels.b = rgb[2]; - - this.exposeColor(flags); - return true; - }; - - - // DEPRECATED. Use .fromHSVA() instead - // - this.fromHSV = function (h, s, v, flags) { - console.warn('fromHSV() method is DEPRECATED. Using fromHSVA() instead.' + jsc.docsRef); - return this.fromHSVA(h, s, v, null, flags); - }; - - - // DEPRECATED. Use .fromRGBA() instead - // - this.fromRGB = function (r, g, b, flags) { - console.warn('fromRGB() method is DEPRECATED. Using fromRGBA() instead.' + jsc.docsRef); - return this.fromRGBA(r, g, b, null, flags); - }; - - - this.fromString = function (str, flags) { - if (!this.required && str.trim() === '') { - // setting empty string to an optional color input - this.setPreviewElementBg(null); - this.setValueElementValue(''); - return true; - } - - var color = jsc.parseColorString(str); - if (!color) { - return false; // could not parse - } - if (this.format.toLowerCase() === 'any') { - this._setFormat(color.format); // adapt format - if (!jsc.isAlphaFormat(this.getFormat())) { - color.rgba[3] = 1.0; // when switching to a format that doesn't support alpha, set full opacity - } - } - this.fromRGBA( - color.rgba[0], - color.rgba[1], - color.rgba[2], - color.rgba[3], - flags - ); - return true; - }; - - - this.randomize = function (minV, maxV, minS, maxS, minH, maxH, minA, maxA) { - if (minV === undefined) { minV = 0; } - if (maxV === undefined) { maxV = 100; } - if (minS === undefined) { minS = 0; } - if (maxS === undefined) { maxS = 100; } - if (minH === undefined) { minH = 0; } - if (maxH === undefined) { maxH = 359; } - if (minA === undefined) { minA = 1; } - if (maxA === undefined) { maxA = 1; } - - this.fromHSVA( - minH + Math.floor(Math.random() * (maxH - minH + 1)), - minS + Math.floor(Math.random() * (maxS - minS + 1)), - minV + Math.floor(Math.random() * (maxV - minV + 1)), - ((100 * minA) + Math.floor(Math.random() * (100 * (maxA - minA) + 1))) / 100 - ); - }; - - - this.toString = function (format) { - if (format === undefined) { - format = this.getFormat(); // format not specified -> use the current format - } - switch (format.toLowerCase()) { - case 'hex': return this.toHEXString(); break; - case 'hexa': return this.toHEXAString(); break; - case 'rgb': return this.toRGBString(); break; - case 'rgba': return this.toRGBAString(); break; - } - return false; - }; - - - this.toHEXString = function () { - return jsc.hexColor( - this.channels.r, - this.channels.g, - this.channels.b - ); - }; - - - this.toHEXAString = function () { - return jsc.hexaColor( - this.channels.r, - this.channels.g, - this.channels.b, - this.channels.a - ); - }; - - - this.toRGBString = function () { - return jsc.rgbColor( - this.channels.r, - this.channels.g, - this.channels.b - ); - }; - - - this.toRGBAString = function () { - return jsc.rgbaColor( - this.channels.r, - this.channels.g, - this.channels.b, - this.channels.a - ); - }; - - - this.toGrayscale = function () { - return ( - 0.213 * this.channels.r + - 0.715 * this.channels.g + - 0.072 * this.channels.b - ); - }; - - - this.toCanvas = function () { - return jsc.genColorPreviewCanvas(this.toRGBAString()).canvas; - }; - - - this.toDataURL = function () { - return this.toCanvas().toDataURL(); - }; - - - this.toBackground = function () { - return jsc.pub.background(this.toRGBAString()); - }; - - - this.isLight = function () { - return this.toGrayscale() > 255 / 2; - }; - - - this.hide = function () { - if (isPickerOwner()) { - detachPicker(); - } - }; - - - this.show = function () { - drawPicker(); - }; - - - this.redraw = function () { - if (isPickerOwner()) { - drawPicker(); - } - }; - - - this.getFormat = function () { - return this._currentFormat; - }; - - - this._setFormat = function (format) { - this._currentFormat = format.toLowerCase(); - }; - - - this.hasAlphaChannel = function () { - if (this.alphaChannel === 'auto') { - return ( - this.format.toLowerCase() === 'any' || // format can change on the fly (e.g. from hex to rgba), so let's consider the alpha channel enabled - jsc.isAlphaFormat(this.getFormat()) || // the current format supports alpha channel - this.alpha !== undefined || // initial alpha value is set, so we're working with alpha channel - this.alphaElement !== undefined // the alpha value is redirected, so we're working with alpha channel - ); - } - - return this.alphaChannel; // the alpha channel is explicitly set - }; - - - this.processValueInput = function (str) { - if (!this.fromString(str)) { - // could not parse the color value - let's just expose the current color - this.exposeColor(); - } - }; - - - this.processAlphaInput = function (str) { - if (!this.fromHSVA(null, null, null, parseFloat(str))) { - // could not parse the alpha value - let's just expose the current color - this.exposeColor(); - } - }; - - - this.exposeColor = function (flags) { - var colorStr = this.toString(); - var fmt = this.getFormat(); - - // reflect current color in data- attribute - jsc.setDataAttr(this.targetElement, 'current-color', colorStr); - - if (!(flags & jsc.flags.leaveValue) && this.valueElement) { - if (fmt === 'hex' || fmt === 'hexa') { - if (!this.uppercase) { colorStr = colorStr.toLowerCase(); } - if (!this.hash) { colorStr = colorStr.replace(/^#/, ''); } - } - this.setValueElementValue(colorStr); - } - - if (!(flags & jsc.flags.leaveAlpha) && this.alphaElement) { - var alphaVal = Math.round(this.channels.a * 100) / 100; - this.setAlphaElementValue(alphaVal); - } - - if (!(flags & jsc.flags.leavePreview) && this.previewElement) { - var previewPos = null; // 'left' | 'right' (null -> fill the entire element) - - if ( - jsc.isTextInput(this.previewElement) || // text input - (jsc.isButton(this.previewElement) && !jsc.isButtonEmpty(this.previewElement)) // button with text - ) { - previewPos = this.previewPosition; - } - - this.setPreviewElementBg(this.toRGBAString()); - } - - if (isPickerOwner()) { - redrawPad(); - redrawSld(); - redrawASld(); - } - }; - - - this.setPreviewElementBg = function (color) { - if (!this.previewElement) { - return; - } - - var position = null; // color preview position: null | 'left' | 'right' - var width = null; // color preview width: px | null = fill the entire element - if ( - jsc.isTextInput(this.previewElement) || // text input - (jsc.isButton(this.previewElement) && !jsc.isButtonEmpty(this.previewElement)) // button with text - ) { - position = this.previewPosition; - width = this.previewSize; - } - - var backgrounds = []; - - if (!color) { - // there is no color preview to display -> let's remove any previous background image - backgrounds.push({ - image: 'none', - position: 'left top', - size: 'auto', - repeat: 'no-repeat', - origin: 'padding-box', - }); - } else { - // CSS gradient for background color preview - backgrounds.push({ - image: jsc.genColorPreviewGradient( - color, - position, - width ? width - jsc.pub.previewSeparator.length : null - ), - position: 'left top', - size: 'auto', - repeat: position ? 'repeat-y' : 'repeat', - origin: 'padding-box', - }); - - // data URL of generated PNG image with a gray transparency chessboard - var preview = jsc.genColorPreviewCanvas( - 'rgba(0,0,0,0)', - position ? {'left':'right', 'right':'left'}[position] : null, - width, - true - ); - backgrounds.push({ - image: 'url(\'' + preview.canvas.toDataURL() + '\')', - position: (position || 'left') + ' top', - size: preview.width + 'px ' + preview.height + 'px', - repeat: position ? 'repeat-y' : 'repeat', - origin: 'padding-box', - }); - } - - var bg = { - image: [], - position: [], - size: [], - repeat: [], - origin: [], - }; - for (var i = 0; i < backgrounds.length; i += 1) { - bg.image.push(backgrounds[i].image); - bg.position.push(backgrounds[i].position); - bg.size.push(backgrounds[i].size); - bg.repeat.push(backgrounds[i].repeat); - bg.origin.push(backgrounds[i].origin); - } - - // set previewElement's background-images - var sty = { - 'background-image': bg.image.join(', '), - 'background-position': bg.position.join(', '), - 'background-size': bg.size.join(', '), - 'background-repeat': bg.repeat.join(', '), - 'background-origin': bg.origin.join(', '), - }; - jsc.setStyle(this.previewElement, sty, this.forceStyle); - - - // set/restore previewElement's padding - var padding = { - left: null, - right: null, - }; - if (position) { - padding[position] = (this.previewSize + this.previewPadding) + 'px'; - } - - var sty = { - 'padding-left': padding.left, - 'padding-right': padding.right, - }; - jsc.setStyle(this.previewElement, sty, this.forceStyle, true); - }; - - - this.setValueElementValue = function (str) { - if (this.valueElement) { - if (jsc.nodeName(this.valueElement) === 'input') { - this.valueElement.value = str; - } else { - this.valueElement.innerHTML = str; - } - } - }; - - - this.setAlphaElementValue = function (str) { - if (this.alphaElement) { - if (jsc.nodeName(this.alphaElement) === 'input') { - this.alphaElement.value = str; - } else { - this.alphaElement.innerHTML = str; - } - } - }; - - - this._processParentElementsInDOM = function () { - if (this._parentElementsProcessed) { return; } - this._parentElementsProcessed = true; - - var elm = this.targetElement; - do { - // If the target element or one of its parent nodes has fixed position, - // then use fixed positioning instead - var compStyle = jsc.getCompStyle(elm); - if (compStyle.position && compStyle.position.toLowerCase() === 'fixed') { - this.fixed = true; - } - - if (elm !== this.targetElement) { - // Ensure to attach onParentScroll only once to each parent element - // (multiple targetElements can share the same parent nodes) - // - // Note: It's not just offsetParents that can be scrollable, - // that's why we loop through all parent nodes - if (!jsc.getData(elm, 'hasScrollListener')) { - elm.addEventListener('scroll', jsc.onParentScroll, false); - jsc.setData(elm, 'hasScrollListener', true); - } - } - } while ((elm = elm.parentNode) && jsc.nodeName(elm) !== 'body'); - }; - - - this.tryHide = function () { - if (this.hideOnLeave) { - this.hide(); - } - }; - - - this.set__palette = function (val) { - this.palette = val; - this._palette = jsc.parsePaletteValue(val); - this._paletteHasTransparency = jsc.containsTranparentColor(this._palette); - }; - - - function setOption (option, value) { - if (typeof option !== 'string') { - throw new Error('Invalid value for option name: ' + option); - } - - // enum option - if (jsc.enumOpts.hasOwnProperty(option)) { - if (typeof value === 'string') { // enum string values are case insensitive - value = value.toLowerCase(); - } - if (jsc.enumOpts[option].indexOf(value) === -1) { - throw new Error('Option \'' + option + '\' has invalid value: ' + value); - } - } - - // deprecated option - if (jsc.deprecatedOpts.hasOwnProperty(option)) { - var oldOpt = option; - var newOpt = jsc.deprecatedOpts[option]; - if (newOpt) { - // if we have a new name for this option, let's log a warning and use the new name - console.warn('Option \'%s\' is DEPRECATED, using \'%s\' instead.' + jsc.docsRef, oldOpt, newOpt); - option = newOpt; - } else { - // new name not available for the option - throw new Error('Option \'' + option + '\' is DEPRECATED'); - } - } - - var setter = 'set__' + option; - - if (typeof THIS[setter] === 'function') { // a setter exists for this option - THIS[setter](value); - return true; - - } else if (option in THIS) { // option exists as a property - THIS[option] = value; - return true; - } - - throw new Error('Unrecognized configuration option: ' + option); - } - - - function getOption (option) { - if (typeof option !== 'string') { - throw new Error('Invalid value for option name: ' + option); - } - - // deprecated option - if (jsc.deprecatedOpts.hasOwnProperty(option)) { - var oldOpt = option; - var newOpt = jsc.deprecatedOpts[option]; - if (newOpt) { - // if we have a new name for this option, let's log a warning and use the new name - console.warn('Option \'%s\' is DEPRECATED, using \'%s\' instead.' + jsc.docsRef, oldOpt, newOpt); - option = newOpt; - } else { - // new name not available for the option - throw new Error('Option \'' + option + '\' is DEPRECATED'); - } - } - - var getter = 'get__' + option; - - if (typeof THIS[getter] === 'function') { // a getter exists for this option - return THIS[getter](value); - - } else if (option in THIS) { // option exists as a property - return THIS[option]; - } - - throw new Error('Unrecognized configuration option: ' + option); - } - - - function detachPicker () { - jsc.removeClass(THIS.targetElement, jsc.pub.activeClassName); - jsc.picker.wrap.parentNode.removeChild(jsc.picker.wrap); - delete jsc.picker.owner; - } - - - function drawPicker () { - - // At this point, when drawing the picker, we know what the parent elements are - // and we can do all related DOM operations, such as registering events on them - // or checking their positioning - THIS._processParentElementsInDOM(); - - if (!jsc.picker) { - jsc.picker = { - owner: null, // owner picker instance - wrap : jsc.createEl('div'), - box : jsc.createEl('div'), - boxS : jsc.createEl('div'), // shadow area - boxB : jsc.createEl('div'), // border - pad : jsc.createEl('div'), - padB : jsc.createEl('div'), // border - padM : jsc.createEl('div'), // mouse/touch area - padCanvas : jsc.createPadCanvas(), - cross : jsc.createEl('div'), - crossBY : jsc.createEl('div'), // border Y - crossBX : jsc.createEl('div'), // border X - crossLY : jsc.createEl('div'), // line Y - crossLX : jsc.createEl('div'), // line X - sld : jsc.createEl('div'), // slider - sldB : jsc.createEl('div'), // border - sldM : jsc.createEl('div'), // mouse/touch area - sldGrad : jsc.createSliderGradient(), - sldPtrS : jsc.createEl('div'), // slider pointer spacer - sldPtrIB : jsc.createEl('div'), // slider pointer inner border - sldPtrMB : jsc.createEl('div'), // slider pointer middle border - sldPtrOB : jsc.createEl('div'), // slider pointer outer border - asld : jsc.createEl('div'), // alpha slider - asldB : jsc.createEl('div'), // border - asldM : jsc.createEl('div'), // mouse/touch area - asldGrad : jsc.createASliderGradient(), - asldPtrS : jsc.createEl('div'), // slider pointer spacer - asldPtrIB : jsc.createEl('div'), // slider pointer inner border - asldPtrMB : jsc.createEl('div'), // slider pointer middle border - asldPtrOB : jsc.createEl('div'), // slider pointer outer border - pal : jsc.createEl('div'), // palette - btn : jsc.createEl('div'), - btnT : jsc.createEl('span'), // text - }; - - jsc.picker.pad.appendChild(jsc.picker.padCanvas.elm); - jsc.picker.padB.appendChild(jsc.picker.pad); - jsc.picker.cross.appendChild(jsc.picker.crossBY); - jsc.picker.cross.appendChild(jsc.picker.crossBX); - jsc.picker.cross.appendChild(jsc.picker.crossLY); - jsc.picker.cross.appendChild(jsc.picker.crossLX); - jsc.picker.padB.appendChild(jsc.picker.cross); - jsc.picker.box.appendChild(jsc.picker.padB); - jsc.picker.box.appendChild(jsc.picker.padM); - - jsc.picker.sld.appendChild(jsc.picker.sldGrad.elm); - jsc.picker.sldB.appendChild(jsc.picker.sld); - jsc.picker.sldB.appendChild(jsc.picker.sldPtrOB); - jsc.picker.sldPtrOB.appendChild(jsc.picker.sldPtrMB); - jsc.picker.sldPtrMB.appendChild(jsc.picker.sldPtrIB); - jsc.picker.sldPtrIB.appendChild(jsc.picker.sldPtrS); - jsc.picker.box.appendChild(jsc.picker.sldB); - jsc.picker.box.appendChild(jsc.picker.sldM); - - jsc.picker.asld.appendChild(jsc.picker.asldGrad.elm); - jsc.picker.asldB.appendChild(jsc.picker.asld); - jsc.picker.asldB.appendChild(jsc.picker.asldPtrOB); - jsc.picker.asldPtrOB.appendChild(jsc.picker.asldPtrMB); - jsc.picker.asldPtrMB.appendChild(jsc.picker.asldPtrIB); - jsc.picker.asldPtrIB.appendChild(jsc.picker.asldPtrS); - jsc.picker.box.appendChild(jsc.picker.asldB); - jsc.picker.box.appendChild(jsc.picker.asldM); - - jsc.picker.box.appendChild(jsc.picker.pal); - - jsc.picker.btn.appendChild(jsc.picker.btnT); - jsc.picker.box.appendChild(jsc.picker.btn); - - jsc.picker.boxB.appendChild(jsc.picker.box); - jsc.picker.wrap.appendChild(jsc.picker.boxS); - jsc.picker.wrap.appendChild(jsc.picker.boxB); - - jsc.picker.wrap.addEventListener('touchstart', jsc.onPickerTouchStart, - jsc.isPassiveEventSupported ? {passive: false} : false); - } - - var p = jsc.picker; - - var displaySlider = !!jsc.getSliderChannel(THIS); - var displayAlphaSlider = THIS.hasAlphaChannel(); - var pickerDims = jsc.getPickerDims(THIS); - var crossOuterSize = (2 * THIS.pointerBorderWidth + THIS.pointerThickness + 2 * THIS.crossSize); - var controlPadding = jsc.getControlPadding(THIS); - var borderRadius = Math.min( - THIS.borderRadius, - Math.round(THIS.padding * Math.PI)); // px - var padCursor = 'crosshair'; - - // wrap - p.wrap.className = 'jscolor-picker-wrap'; - p.wrap.style.clear = 'both'; - p.wrap.style.width = pickerDims.borderW + 'px'; - p.wrap.style.height = pickerDims.borderH + 'px'; - p.wrap.style.zIndex = THIS.zIndex; - - // picker - p.box.className = 'jscolor-picker'; - p.box.style.width = pickerDims.paddedW + 'px'; - p.box.style.height = pickerDims.paddedH + 'px'; - p.box.style.position = 'relative'; - - // picker shadow - p.boxS.className = 'jscolor-picker-shadow'; - p.boxS.style.position = 'absolute'; - p.boxS.style.left = '0'; - p.boxS.style.top = '0'; - p.boxS.style.width = '100%'; - p.boxS.style.height = '100%'; - jsc.setBorderRadius(p.boxS, borderRadius + 'px'); - - // picker border - p.boxB.className = 'jscolor-picker-border'; - p.boxB.style.position = 'relative'; - p.boxB.style.border = THIS.borderWidth + 'px solid'; - p.boxB.style.borderColor = THIS.borderColor; - p.boxB.style.background = THIS.backgroundColor; - jsc.setBorderRadius(p.boxB, borderRadius + 'px'); - - // IE hack: - // If the element is transparent, IE will trigger the event on the elements under it, - // e.g. on Canvas or on elements with border - p.padM.style.background = 'rgba(255,0,0,.2)'; - p.sldM.style.background = 'rgba(0,255,0,.2)'; - p.asldM.style.background = 'rgba(0,0,255,.2)'; - - p.padM.style.opacity = - p.sldM.style.opacity = - p.asldM.style.opacity = - '0'; - - // pad - p.pad.style.position = 'relative'; - p.pad.style.width = THIS.width + 'px'; - p.pad.style.height = THIS.height + 'px'; - - // pad - color spectrum (HSV and HVS) - p.padCanvas.draw(THIS.width, THIS.height, jsc.getPadYChannel(THIS)); - - // pad border - p.padB.style.position = 'absolute'; - p.padB.style.left = THIS.padding + 'px'; - p.padB.style.top = THIS.padding + 'px'; - p.padB.style.border = THIS.controlBorderWidth + 'px solid'; - p.padB.style.borderColor = THIS.controlBorderColor; - - // pad mouse area - p.padM.style.position = 'absolute'; - p.padM.style.left = 0 + 'px'; - p.padM.style.top = 0 + 'px'; - p.padM.style.width = (THIS.padding + 2 * THIS.controlBorderWidth + THIS.width + controlPadding) + 'px'; - p.padM.style.height = (2 * THIS.controlBorderWidth + 2 * THIS.padding + THIS.height) + 'px'; - p.padM.style.cursor = padCursor; - jsc.setData(p.padM, { - instance: THIS, - control: 'pad', - }) - - // pad cross - p.cross.style.position = 'absolute'; - p.cross.style.left = - p.cross.style.top = - '0'; - p.cross.style.width = - p.cross.style.height = - crossOuterSize + 'px'; - - // pad cross border Y and X - p.crossBY.style.position = - p.crossBX.style.position = - 'absolute'; - p.crossBY.style.background = - p.crossBX.style.background = - THIS.pointerBorderColor; - p.crossBY.style.width = - p.crossBX.style.height = - (2 * THIS.pointerBorderWidth + THIS.pointerThickness) + 'px'; - p.crossBY.style.height = - p.crossBX.style.width = - crossOuterSize + 'px'; - p.crossBY.style.left = - p.crossBX.style.top = - (Math.floor(crossOuterSize / 2) - Math.floor(THIS.pointerThickness / 2) - THIS.pointerBorderWidth) + 'px'; - p.crossBY.style.top = - p.crossBX.style.left = - '0'; - - // pad cross line Y and X - p.crossLY.style.position = - p.crossLX.style.position = - 'absolute'; - p.crossLY.style.background = - p.crossLX.style.background = - THIS.pointerColor; - p.crossLY.style.height = - p.crossLX.style.width = - (crossOuterSize - 2 * THIS.pointerBorderWidth) + 'px'; - p.crossLY.style.width = - p.crossLX.style.height = - THIS.pointerThickness + 'px'; - p.crossLY.style.left = - p.crossLX.style.top = - (Math.floor(crossOuterSize / 2) - Math.floor(THIS.pointerThickness / 2)) + 'px'; - p.crossLY.style.top = - p.crossLX.style.left = - THIS.pointerBorderWidth + 'px'; - - - // slider - p.sld.style.overflow = 'hidden'; - p.sld.style.width = THIS.sliderSize + 'px'; - p.sld.style.height = THIS.height + 'px'; - - // slider gradient - p.sldGrad.draw(THIS.sliderSize, THIS.height, '#000', '#000'); - - // slider border - p.sldB.style.display = displaySlider ? 'block' : 'none'; - p.sldB.style.position = 'absolute'; - p.sldB.style.left = (THIS.padding + THIS.width + 2 * THIS.controlBorderWidth + 2 * controlPadding) + 'px'; - p.sldB.style.top = THIS.padding + 'px'; - p.sldB.style.border = THIS.controlBorderWidth + 'px solid'; - p.sldB.style.borderColor = THIS.controlBorderColor; - - // slider mouse area - p.sldM.style.display = displaySlider ? 'block' : 'none'; - p.sldM.style.position = 'absolute'; - p.sldM.style.left = (THIS.padding + THIS.width + 2 * THIS.controlBorderWidth + controlPadding) + 'px'; - p.sldM.style.top = 0 + 'px'; - p.sldM.style.width = ( - (THIS.sliderSize + 2 * controlPadding + 2 * THIS.controlBorderWidth) + - (displayAlphaSlider ? 0 : Math.max(0, THIS.padding - controlPadding)) // remaining padding to the right edge - ) + 'px'; - p.sldM.style.height = (2 * THIS.controlBorderWidth + 2 * THIS.padding + THIS.height) + 'px'; - p.sldM.style.cursor = 'default'; - jsc.setData(p.sldM, { - instance: THIS, - control: 'sld', - }); - - // slider pointer inner and outer border - p.sldPtrIB.style.border = - p.sldPtrOB.style.border = - THIS.pointerBorderWidth + 'px solid ' + THIS.pointerBorderColor; - - // slider pointer outer border - p.sldPtrOB.style.position = 'absolute'; - p.sldPtrOB.style.left = -(2 * THIS.pointerBorderWidth + THIS.pointerThickness) + 'px'; - p.sldPtrOB.style.top = '0'; - - // slider pointer middle border - p.sldPtrMB.style.border = THIS.pointerThickness + 'px solid ' + THIS.pointerColor; - - // slider pointer spacer - p.sldPtrS.style.width = THIS.sliderSize + 'px'; - p.sldPtrS.style.height = jsc.pub.sliderInnerSpace + 'px'; - - - // alpha slider - p.asld.style.overflow = 'hidden'; - p.asld.style.width = THIS.sliderSize + 'px'; - p.asld.style.height = THIS.height + 'px'; - - // alpha slider gradient - p.asldGrad.draw(THIS.sliderSize, THIS.height, '#000'); - - // alpha slider border - p.asldB.style.display = displayAlphaSlider ? 'block' : 'none'; - p.asldB.style.position = 'absolute'; - p.asldB.style.left = ( - (THIS.padding + THIS.width + 2 * THIS.controlBorderWidth + controlPadding) + - (displaySlider ? (THIS.sliderSize + 3 * controlPadding + 2 * THIS.controlBorderWidth) : 0) - ) + 'px'; - p.asldB.style.top = THIS.padding + 'px'; - p.asldB.style.border = THIS.controlBorderWidth + 'px solid'; - p.asldB.style.borderColor = THIS.controlBorderColor; - - // alpha slider mouse area - p.asldM.style.display = displayAlphaSlider ? 'block' : 'none'; - p.asldM.style.position = 'absolute'; - p.asldM.style.left = ( - (THIS.padding + THIS.width + 2 * THIS.controlBorderWidth + controlPadding) + - (displaySlider ? (THIS.sliderSize + 2 * controlPadding + 2 * THIS.controlBorderWidth) : 0) - ) + 'px'; - p.asldM.style.top = 0 + 'px'; - p.asldM.style.width = ( - (THIS.sliderSize + 2 * controlPadding + 2 * THIS.controlBorderWidth) + - Math.max(0, THIS.padding - controlPadding) // remaining padding to the right edge - ) + 'px'; - p.asldM.style.height = (2 * THIS.controlBorderWidth + 2 * THIS.padding + THIS.height) + 'px'; - p.asldM.style.cursor = 'default'; - jsc.setData(p.asldM, { - instance: THIS, - control: 'asld', - }) - - // alpha slider pointer inner and outer border - p.asldPtrIB.style.border = - p.asldPtrOB.style.border = - THIS.pointerBorderWidth + 'px solid ' + THIS.pointerBorderColor; - - // alpha slider pointer outer border - p.asldPtrOB.style.position = 'absolute'; - p.asldPtrOB.style.left = -(2 * THIS.pointerBorderWidth + THIS.pointerThickness) + 'px'; - p.asldPtrOB.style.top = '0'; - - // alpha slider pointer middle border - p.asldPtrMB.style.border = THIS.pointerThickness + 'px solid ' + THIS.pointerColor; - - // alpha slider pointer spacer - p.asldPtrS.style.width = THIS.sliderSize + 'px'; - p.asldPtrS.style.height = jsc.pub.sliderInnerSpace + 'px'; - - - // palette - p.pal.className = 'jscolor-palette'; - p.pal.style.display = pickerDims.palette.rows ? 'block' : 'none'; - p.pal.style.position = 'absolute'; - p.pal.style.left = THIS.padding + 'px'; - p.pal.style.top = (2 * THIS.controlBorderWidth + 2 * THIS.padding + THIS.height) + 'px'; - - // palette's color samples - - p.pal.innerHTML = ''; - - var chessboard = jsc.genColorPreviewCanvas('rgba(0,0,0,0)'); - - var si = 0; // color sample's index - for (var r = 0; r < pickerDims.palette.rows; r++) { - for (var c = 0; c < pickerDims.palette.cols && si < THIS._palette.length; c++, si++) { - var sampleColor = THIS._palette[si]; - var sampleCssColor = jsc.rgbaColor.apply(null, sampleColor.rgba); - - var sc = jsc.createEl('div'); // color sample's color - sc.style.width = (pickerDims.palette.cellW - 2 * THIS.controlBorderWidth) + 'px'; - sc.style.height = (pickerDims.palette.cellH - 2 * THIS.controlBorderWidth) + 'px'; - sc.style.backgroundColor = sampleCssColor; - - var sw = jsc.createEl('div'); // color sample's wrap - sw.className = 'jscolor-palette-sample'; - sw.style.display = 'block'; - sw.style.position = 'absolute'; - sw.style.left = ( - pickerDims.palette.cols <= 1 ? 0 : - Math.round(10 * (c * ((pickerDims.contentW - pickerDims.palette.cellW) / (pickerDims.palette.cols - 1)))) / 10 - ) + 'px'; - sw.style.top = (r * (pickerDims.palette.cellH + THIS.paletteSpacing)) + 'px'; - sw.style.border = THIS.controlBorderWidth + 'px solid'; - sw.style.borderColor = THIS.controlBorderColor; - sw.style.cursor = 'pointer'; - if (sampleColor.rgba[3] !== null && sampleColor.rgba[3] < 1.0) { // only create chessboard background if the sample has transparency - sw.style.backgroundImage = 'url(\'' + chessboard.canvas.toDataURL() + '\')'; - sw.style.backgroundRepeat = 'repeat'; - sw.style.backgroundPosition = 'center center'; - } - jsc.setData(sw, { - instance: THIS, - control: 'palette-sample', - color: sampleColor, - }) - sw.addEventListener('click', jsc.onPaletteSampleClick, false); - sw.appendChild(sc); - p.pal.appendChild(sw); - } - } - - - // the Close button - function setBtnBorder () { - var insetColors = THIS.controlBorderColor.split(/\s+/); - var outsetColor = insetColors.length < 2 ? insetColors[0] : insetColors[1] + ' ' + insetColors[0] + ' ' + insetColors[0] + ' ' + insetColors[1]; - p.btn.style.borderColor = outsetColor; - } - var btnPadding = 15; // px - p.btn.className = 'jscolor-btn-close'; - p.btn.style.display = THIS.closeButton ? 'block' : 'none'; - p.btn.style.position = 'absolute'; - p.btn.style.left = THIS.padding + 'px'; - p.btn.style.bottom = THIS.padding + 'px'; - p.btn.style.padding = '0 ' + btnPadding + 'px'; - p.btn.style.maxWidth = (pickerDims.contentW - 2 * THIS.controlBorderWidth - 2 * btnPadding) + 'px'; - p.btn.style.overflow = 'hidden'; - p.btn.style.height = THIS.buttonHeight + 'px'; - p.btn.style.whiteSpace = 'nowrap'; - p.btn.style.border = THIS.controlBorderWidth + 'px solid'; - setBtnBorder(); - p.btn.style.color = THIS.buttonColor; - p.btn.style.font = '12px sans-serif'; - p.btn.style.textAlign = 'center'; - p.btn.style.cursor = 'pointer'; - p.btn.onmousedown = function () { - THIS.hide(); - }; - p.btnT.style.lineHeight = THIS.buttonHeight + 'px'; - p.btnT.innerHTML = ''; - p.btnT.appendChild(window.document.createTextNode(THIS.closeText)); - - // reposition the pointers - redrawPad(); - redrawSld(); - redrawASld(); - - // If we are changing the owner without first closing the picker, - // make sure to first deal with the old owner - if (jsc.picker.owner && jsc.picker.owner !== THIS) { - jsc.removeClass(jsc.picker.owner.targetElement, jsc.pub.activeClassName); - } - - // Set a new picker owner - jsc.picker.owner = THIS; - - // The redrawPosition() method needs picker.owner to be set, that's why we call it here, - // after setting the owner - jsc.redrawPosition(); - - if (p.wrap.parentNode !== THIS.container) { - THIS.container.appendChild(p.wrap); - } - - jsc.addClass(THIS.targetElement, jsc.pub.activeClassName); - } - - - function redrawPad () { - // redraw the pad pointer - var yChannel = jsc.getPadYChannel(THIS); - var x = Math.round((THIS.channels.h / 360) * (THIS.width - 1)); - var y = Math.round((1 - THIS.channels[yChannel] / 100) * (THIS.height - 1)); - var crossOuterSize = (2 * THIS.pointerBorderWidth + THIS.pointerThickness + 2 * THIS.crossSize); - var ofs = -Math.floor(crossOuterSize / 2); - jsc.picker.cross.style.left = (x + ofs) + 'px'; - jsc.picker.cross.style.top = (y + ofs) + 'px'; - - // redraw the slider - switch (jsc.getSliderChannel(THIS)) { - case 's': - var rgb1 = jsc.HSV_RGB(THIS.channels.h, 100, THIS.channels.v); - var rgb2 = jsc.HSV_RGB(THIS.channels.h, 0, THIS.channels.v); - var color1 = 'rgb(' + - Math.round(rgb1[0]) + ',' + - Math.round(rgb1[1]) + ',' + - Math.round(rgb1[2]) + ')'; - var color2 = 'rgb(' + - Math.round(rgb2[0]) + ',' + - Math.round(rgb2[1]) + ',' + - Math.round(rgb2[2]) + ')'; - jsc.picker.sldGrad.draw(THIS.sliderSize, THIS.height, color1, color2); - break; - case 'v': - var rgb = jsc.HSV_RGB(THIS.channels.h, THIS.channels.s, 100); - var color1 = 'rgb(' + - Math.round(rgb[0]) + ',' + - Math.round(rgb[1]) + ',' + - Math.round(rgb[2]) + ')'; - var color2 = '#000'; - jsc.picker.sldGrad.draw(THIS.sliderSize, THIS.height, color1, color2); - break; - } - - // redraw the alpha slider - jsc.picker.asldGrad.draw(THIS.sliderSize, THIS.height, THIS.toHEXString()); - } - - - function redrawSld () { - var sldChannel = jsc.getSliderChannel(THIS); - if (sldChannel) { - // redraw the slider pointer - var y = Math.round((1 - THIS.channels[sldChannel] / 100) * (THIS.height - 1)); - jsc.picker.sldPtrOB.style.top = (y - (2 * THIS.pointerBorderWidth + THIS.pointerThickness) - Math.floor(jsc.pub.sliderInnerSpace / 2)) + 'px'; - } - - // redraw the alpha slider - jsc.picker.asldGrad.draw(THIS.sliderSize, THIS.height, THIS.toHEXString()); - } - - - function redrawASld () { - var y = Math.round((1 - THIS.channels.a) * (THIS.height - 1)); - jsc.picker.asldPtrOB.style.top = (y - (2 * THIS.pointerBorderWidth + THIS.pointerThickness) - Math.floor(jsc.pub.sliderInnerSpace / 2)) + 'px'; - } - - - function isPickerOwner () { - return jsc.picker && jsc.picker.owner === THIS; - } - - - function onValueKeyDown (ev) { - if (jsc.eventKey(ev) === 'Enter') { - if (THIS.valueElement) { - THIS.processValueInput(THIS.valueElement.value); - } - THIS.tryHide(); - } - } - - - function onAlphaKeyDown (ev) { - if (jsc.eventKey(ev) === 'Enter') { - if (THIS.alphaElement) { - THIS.processAlphaInput(THIS.alphaElement.value); - } - THIS.tryHide(); - } - } - - - function onValueChange (ev) { - if (jsc.getData(ev, 'internal')) { - return; // skip if the event was internally triggered by jscolor - } - - var oldVal = THIS.valueElement.value; - - THIS.processValueInput(THIS.valueElement.value); // this might change the value - - jsc.triggerCallback(THIS, 'onChange'); - - if (THIS.valueElement.value !== oldVal) { - // value was additionally changed -> let's trigger the change event again, even though it was natively dispatched - jsc.triggerInputEvent(THIS.valueElement, 'change', true, true); - } - } - - - function onAlphaChange (ev) { - if (jsc.getData(ev, 'internal')) { - return; // skip if the event was internally triggered by jscolor - } - - var oldVal = THIS.alphaElement.value; - - THIS.processAlphaInput(THIS.alphaElement.value); // this might change the value - - jsc.triggerCallback(THIS, 'onChange'); - - // triggering valueElement's onChange (because changing alpha changes the entire color, e.g. with rgba format) - jsc.triggerInputEvent(THIS.valueElement, 'change', true, true); - - if (THIS.alphaElement.value !== oldVal) { - // value was additionally changed -> let's trigger the change event again, even though it was natively dispatched - jsc.triggerInputEvent(THIS.alphaElement, 'change', true, true); - } - } - - - function onValueInput (ev) { - if (jsc.getData(ev, 'internal')) { - return; // skip if the event was internally triggered by jscolor - } - - if (THIS.valueElement) { - THIS.fromString(THIS.valueElement.value, jsc.flags.leaveValue); - } - - jsc.triggerCallback(THIS, 'onInput'); - - // triggering valueElement's onInput - // (not needed, it was dispatched normally by the browser) - } - - - function onAlphaInput (ev) { - if (jsc.getData(ev, 'internal')) { - return; // skip if the event was internally triggered by jscolor - } - - if (THIS.alphaElement) { - THIS.fromHSVA(null, null, null, parseFloat(THIS.alphaElement.value), jsc.flags.leaveAlpha); - } - - jsc.triggerCallback(THIS, 'onInput'); - - // triggering valueElement's onInput (because changing alpha changes the entire color, e.g. with rgba format) - jsc.triggerInputEvent(THIS.valueElement, 'input', true, true); - } - - - // let's process the DEPRECATED 'options' property (this will be later removed) - if (jsc.pub.options) { - // let's set custom default options, if specified - for (var opt in jsc.pub.options) { - if (jsc.pub.options.hasOwnProperty(opt)) { - try { - setOption(opt, jsc.pub.options[opt]); - } catch (e) { - console.warn(e); - } - } - } - } - - - // let's apply configuration presets - // - var presetsArr = []; - - if (opts.preset) { - if (typeof opts.preset === 'string') { - presetsArr = opts.preset.split(/\s+/); - } else if (Array.isArray(opts.preset)) { - presetsArr = opts.preset.slice(); // slice() to clone - } else { - console.warn('Unrecognized preset value'); - } - } - - // always use the 'default' preset. If it's not listed, append it to the end. - if (presetsArr.indexOf('default') === -1) { - presetsArr.push('default'); - } - - // let's apply the presets in reverse order, so that should there be any overlapping options, - // the formerly listed preset will override the latter - for (var i = presetsArr.length - 1; i >= 0; i -= 1) { - var pres = presetsArr[i]; - if (!pres) { - continue; // preset is empty string - } - if (!jsc.pub.presets.hasOwnProperty(pres)) { - console.warn('Unknown preset: %s', pres); - continue; - } - for (var opt in jsc.pub.presets[pres]) { - if (jsc.pub.presets[pres].hasOwnProperty(opt)) { - try { - setOption(opt, jsc.pub.presets[pres][opt]); - } catch (e) { - console.warn(e); - } - } - } - } - - - // let's set specific options for this color picker - var nonProperties = [ - // these options won't be set as instance properties - 'preset', - ]; - for (var opt in opts) { - if (opts.hasOwnProperty(opt)) { - if (nonProperties.indexOf(opt) === -1) { - try { - setOption(opt, opts[opt]); - } catch (e) { - console.warn(e); - } - } - } - } - - - // - // Install the color picker on chosen element(s) - // - - - // Determine picker's container element - if (this.container === undefined) { - this.container = window.document.body; // default container is BODY element - - } else { // explicitly set to custom element - this.container = jsc.node(this.container); - } - - if (!this.container) { - throw new Error('Cannot instantiate color picker without a container element'); - } - - - // Fetch the target element - this.targetElement = jsc.node(targetElement); - - if (!this.targetElement) { - // temporarily customized error message to help with migrating from versions prior to 2.2 - if (typeof targetElement === 'string' && /^[a-zA-Z][\w:.-]*$/.test(targetElement)) { - // targetElement looks like valid ID - var possiblyId = targetElement; - throw new Error('If \'' + possiblyId + '\' is supposed to be an ID, please use \'#' + possiblyId + '\' or any valid CSS selector.'); - } - - throw new Error('Cannot instantiate color picker without a target element'); - } - - if (this.targetElement.jscolor && this.targetElement.jscolor instanceof jsc.pub) { - throw new Error('Color picker already installed on this element'); - } - - - // link this instance with the target element - this.targetElement.jscolor = this; - jsc.addClass(this.targetElement, jsc.pub.className); - - // register this instance - jsc.instances.push(this); - - - // if target is BUTTON - if (jsc.isButton(this.targetElement)) { - - if (this.targetElement.type.toLowerCase() !== 'button') { - // on buttons, always force type to be 'button', e.g. in situations the target