UNPKG

react-mutation-mapper

Version:
304 lines (290 loc) 583 kB
'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var tslib = require('tslib'); var _ = require('lodash'); var mobx = require('mobx'); var mobxReact = require('mobx-react'); var React = require('react'); var cbioportalFrontendCommons = require('cbioportal-frontend-commons'); var classNames = require('classnames'); var cbioportalUtils = require('cbioportal-utils'); var oncokbFrontendCommons = require('oncokb-frontend-commons'); var genomeNexusTsApiClient = require('genome-nexus-ts-api-client'); var oncokbTsApiClient = require('oncokb-ts-api-client'); var autobind = require('autobind-decorator'); var ReactTable = require('react-table'); require('rc-tooltip/assets/bootstrap_white.css'); var Select = require('react-select'); var $ = require('jquery'); var reactCollapse = require('react-collapse'); var numeral = require('numeral'); var Slider = require('react-rangeslider'); require('react-rangeslider/lib/index.css'); var reactBootstrap = require('react-bootstrap'); var oncoKbImg = require('oncokb-styles/dist/images/oncogenic.svg'); require('oncokb-frontend-commons/dist/styles.css'); var request = require('superagent'); var memoize = require('memoize-weak-decorator'); var mobxpromise = require('mobxpromise'); function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; } function _interopNamespace(e) { if (e && e.__esModule) return e; var n = Object.create(null); if (e) { Object.keys(e).forEach(function (k) { if (k !== 'default') { var d = Object.getOwnPropertyDescriptor(e, k); Object.defineProperty(n, k, d.get ? d : { enumerable: true, get: function () { return e[k]; } }); } }); } n["default"] = e; return Object.freeze(n); } var ___default = /*#__PURE__*/_interopDefaultLegacy(_); var ___namespace = /*#__PURE__*/_interopNamespace(_); var React__namespace = /*#__PURE__*/_interopNamespace(React); var React__default = /*#__PURE__*/_interopDefaultLegacy(React); var classNames__default = /*#__PURE__*/_interopDefaultLegacy(classNames); var autobind__default = /*#__PURE__*/_interopDefaultLegacy(autobind); var ReactTable__default = /*#__PURE__*/_interopDefaultLegacy(ReactTable); var Select__default = /*#__PURE__*/_interopDefaultLegacy(Select); var $__default = /*#__PURE__*/_interopDefaultLegacy($); var numeral__default = /*#__PURE__*/_interopDefaultLegacy(numeral); var Slider__default = /*#__PURE__*/_interopDefaultLegacy(Slider); var oncoKbImg__default = /*#__PURE__*/_interopDefaultLegacy(oncoKbImg); var request__default = /*#__PURE__*/_interopDefaultLegacy(request); var memoize__default = /*#__PURE__*/_interopDefaultLegacy(memoize); var annotationStyles = {"annotation-item-load":"annotation-module_annotation-item-load__1pDN0","annotation-item-text":"annotation-module_annotation-item-text__Gy_Jv","annotation-item-error":"annotation-module_annotation-item-error__5BhTo","annotation-item":"annotation-module_annotation-item__2EgnB"}; function loaderIcon(className) { return (React__namespace.createElement("span", { className: classNames__default["default"]("" + annotationStyles['annotation-item'], "" + annotationStyles['annotation-item-load'], className) }, React__namespace.createElement("i", { className: "fa fa-spinner fa-pulse" }))); } function errorIcon(errorMessage) { return (React__namespace.createElement(cbioportalFrontendCommons.DefaultTooltip, { overlay: React__namespace.createElement("span", null, errorMessage), placement: "right", trigger: ['hover', 'focus'], destroyTooltipOnHide: true }, React__namespace.createElement("span", { className: "" + annotationStyles['annotation-item-error'] }, React__namespace.createElement("i", { className: "fa fa-exclamation-triangle text-danger" })))); } var img$6 = ""; var CivicCard = /** @class */ (function (_super) { tslib.__extends(CivicCard, _super); function CivicCard() { return _super !== null && _super.apply(this, arguments) || this; } /** * Generate variants * @param variantMap * @returns {JSX.Element[]} */ Object.defineProperty(CivicCard.prototype, "generateVariants", { enumerable: false, configurable: true, writable: true, value: function (variantMap) { var list = []; if (___default["default"].isEmpty(variantMap)) { list.push(this.variantItem('_naVariant_')); } else { for (var name_1 in variantMap) { var variant = variantMap[name_1]; var entryTypes = ''; for (var evidenceType in variant.evidenceCounts) { entryTypes += evidenceType.toLowerCase() + ': ' + variant.evidenceCounts[evidenceType] + ', '; } entryTypes = entryTypes.slice(0, -2) + '.'; list.push(this.variantItem(name_1, variant.url, variant.name, entryTypes, variant.description)); } } return list; } }); /** * Get variant item * @param url * @param name * @param entryTypes * @param description * @returns {any} */ Object.defineProperty(CivicCard.prototype, "variantItem", { enumerable: false, configurable: true, writable: true, value: function (key, url, name, entryTypes, description) { var result; if (url || name || entryTypes || description) { result = (React__namespace.createElement("div", { key: key, className: "civic-card-variant" }, React__namespace.createElement("div", { className: "civic-card-variant-header" }, React__namespace.createElement("span", { className: "civic-card-variant-name" }, React__namespace.createElement("a", { href: url, target: "_blank" }, name)), React__namespace.createElement("span", { className: "civic-card-variant-entry-types" }, ' ', "Entries: ", entryTypes)), React__namespace.createElement("div", { className: "civic-card-variant-description summary" }, description))); } else { result = (React__namespace.createElement("div", { key: key, className: "civic-card-variant" }, React__namespace.createElement("div", { className: "civic-card-variant-description summary" }, "Information about the oncogenic activity of this alteration is not yet available in CIViC."))); } return result; } }); /** * Render civic card component * @returns {any} */ Object.defineProperty(CivicCard.prototype, "render", { enumerable: false, configurable: true, writable: true, value: function () { return (React__namespace.createElement("div", { className: "civic-card" }, React__namespace.createElement("span", null, React__namespace.createElement("div", { className: "col s12 tip-header" }, this.props.title), React__namespace.createElement("div", { className: "col s12 civic-card-content" }, React__namespace.createElement("div", { className: "col s12 civic-card-gene" }, React__namespace.createElement("p", null, React__namespace.createElement("span", { className: "civic-card-gene-name" }, React__namespace.createElement("a", { href: this.props.geneUrl, target: "_blank" }, React__namespace.createElement("b", null, this.props.geneName))), ' ', "- ", this.props.geneDescription)), React__namespace.createElement("div", { className: "col s12" }, React__namespace.createElement("ul", null, this.generateVariants(this.props.variants))), React__namespace.createElement("div", { className: "item disclaimer" }, React__namespace.createElement("span", null, "Disclaimer: This resource is intended for purely research purposes. It should not be used for emergencies or medical or professional advice.")))), React__namespace.createElement("div", { className: "item footer" }, React__namespace.createElement("a", { href: this.props.geneUrl, target: "_blank" }, React__namespace.createElement("img", { src: img$6, className: "civic-logo", alt: "CIViC" }))))); } }); return CivicCard; }(React__namespace.Component)); var img$5 = ""; var img$4 = ""; function hideArrow(tooltipEl) { var arrowEl = tooltipEl.querySelector('.rc-tooltip-arrow'); arrowEl.style.display = 'none'; } function sortValue$8(civicEntry) { var score = 0; if (civicEntry) { score = 1; } return score; } function download$6(civicEntry) { if (!civicEntry) { return cbioportalUtils.CIVIC_NA_VALUE; } var variants = ___default["default"].values(civicEntry.variants); var values = []; if (variants && variants.length > 0 && variants[0].evidenceCounts) { ___default["default"].forEach(variants[0].evidenceCounts, function (value, key) { values.push(key + ": " + value); }); } // this indicates that we have an entry but the evidence is empty if (values.length === 0) { return cbioportalUtils.CIVIC_NA_VALUE; } return values.join(', '); } var Civic = /** @class */ (function (_super) { tslib.__extends(Civic, _super); function Civic(props) { var _this = _super.call(this, props) || this; Object.defineProperty(_this, "tooltipDataLoadComplete", { enumerable: true, configurable: true, writable: true, value: false }); mobx.makeObservable(_this); _this.cardContent = _this.cardContent.bind(_this); return _this; } Object.defineProperty(Civic.prototype, "render", { enumerable: false, configurable: true, writable: true, value: function () { var civicContent = (React__namespace.createElement("span", { className: "" + annotationStyles['annotation-item'] })); var civicImgWidth = 14; var civicImgHeight = 14; var civicImgSrc = !this.props.hasCivicVariants ? img$4 : img$5; if (this.props.civicStatus == 'error') { civicContent = errorIcon('Error fetching Civic data'); } else if (this.props.civicEntry !== undefined) { if (this.props.civicEntry !== null && this.props.civicStatus == 'complete') { civicContent = (React__namespace.createElement("span", { className: "" + annotationStyles['annotation-item'] }, React__namespace.createElement("img", { width: civicImgWidth, height: civicImgHeight, src: civicImgSrc, alt: "Civic Variant Entry" }))); civicContent = (React__namespace.createElement(cbioportalFrontendCommons.DefaultTooltip, { overlay: this.cardContent.bind(this, this.props.civicEntry), placement: "right", trigger: ['hover', 'focus'], onPopupAlign: hideArrow, destroyTooltipOnHide: false }, civicContent)); } } else { // It's still unknown (undefined) if the current gene has a Civic entry or not. civicContent = loaderIcon('pull-left'); } return civicContent; } }); Object.defineProperty(Civic.prototype, "cardContent", { enumerable: false, configurable: true, writable: true, value: function (civicEntry) { return (React__namespace.createElement(CivicCard, { title: "CIViC Variants", geneName: civicEntry.name, geneDescription: civicEntry.description, geneUrl: civicEntry.url, variants: civicEntry.variants })); } }); tslib.__decorate([ mobx.observable ], Civic.prototype, "tooltipDataLoadComplete", void 0); Civic = tslib.__decorate([ mobxReact.observer ], Civic); return Civic; }(React__namespace.Component)); var NoClinvarData = function () { return (React__namespace.createElement(cbioportalFrontendCommons.DefaultTooltip, { placement: "topLeft", overlay: React__namespace.createElement("span", null, "Variant has no ClinVar data.") }, React__namespace.createElement("span", { style: { height: '100%', width: '100%', display: 'block', overflow: 'hidden', } }, "\u00A0"))); }; var ClinvarSummary = function (props) { if (!props.clinvar) { return React__namespace.createElement(NoClinvarData, null); } else { var clinvarId = props.clinvar.clinvarId; var clinvarLink = "https://www.ncbi.nlm.nih.gov/clinvar/variation/" + clinvarId + "/"; var clinicalSignificance = props.clinvar.clinicalSignificance; var conflictingClinicalSignificance = props.clinvar.conflictingClinicalSignificance; return (React__namespace.createElement(cbioportalFrontendCommons.TruncatedText, { maxLength: 30, text: clinicalSignificance, addTooltip: "always", tooltip: React__namespace.createElement("div", { style: { maxWidth: 300 } }, React__namespace.createElement("div", null, clinicalSignificance), conflictingClinicalSignificance && (React__namespace.createElement("div", null, conflictingClinicalSignificance)), React__namespace.createElement("div", null, "(ClinVar ID:", ' ', React__namespace.createElement("a", { href: clinvarLink, target: "_blank" }, clinvarId), ")")) })); } }; var img$3 = "