123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452 |
- <!DOCTYPE html><html class="default" lang="en"><head><meta charSet="utf-8"/><meta http-equiv="x-ua-compatible" content="IE=edge"/><title>@rcsb/rcsb-saguaro-3d</title><meta name="description" content="Documentation for @rcsb/rcsb-saguaro-3d"/><meta name="viewport" content="width=device-width, initial-scale=1"/><link rel="stylesheet" href="assets/style.css"/><link rel="stylesheet" href="assets/highlight.css"/><script defer src="assets/main.js"></script><script async src="assets/search.js" id="tsd-search-script"></script><script async src="assets/navigation.js" id="tsd-nav-script"></script></head><body><script>document.documentElement.dataset.theme = localStorage.getItem("tsd-theme") || "os"</script><header class="tsd-page-toolbar">
- <div class="tsd-toolbar-contents container">
- <div class="table-cell" id="tsd-search" data-base=".">
- <div class="field"><label for="tsd-search-field" class="tsd-widget tsd-toolbar-icon search no-caption"><svg width="16" height="16" viewBox="0 0 16 16" fill="none"><use href="#icon-search"></use></svg></label><input type="text" id="tsd-search-field" aria-label="Search"/></div>
- <div class="field">
- <div id="tsd-toolbar-links"></div></div>
- <ul class="results">
- <li class="state loading">Preparing search index...</li>
- <li class="state failure">The search index is not available</li></ul><a href="index.html" class="title">@rcsb/rcsb-saguaro-3d</a></div>
- <div class="table-cell" id="tsd-widgets"><a href="#" class="tsd-widget tsd-toolbar-icon menu no-caption" data-toggle="menu" aria-label="Menu"><svg width="16" height="16" viewBox="0 0 16 16" fill="none"><use href="#icon-menu"></use></svg></a></div></div></header>
- <div class="container container-main">
- <div class="col-content">
- <div class="tsd-page-title">
- <h2>@rcsb/rcsb-saguaro-3d</h2></div>
- <div class="tsd-panel tsd-typography"><a id="md:rcsb-saguaro-3d" class="tsd-anchor"></a><h1><a href="#md:rcsb-saguaro-3d">rcsb-saguaro-3D</a></h1><p>RCSB Saguaro Web 3D is an open-source library built on the top of the <a href="https://rcsb.github.io/rcsb-saguaro">RCSB Saguaro 1D Feature Viewer</a>
- and <a href="https://github.com/rcsb/rcsb-Molstar">RCSB Molstar</a> designed to display protein features at the <a href="https://www.rcsb.org">RCSB Web Site</a>.
- The package collects protein annotations from the <a href="https://1d-coordinates.rcsb.org">1D Coordinate Server</a>
- and the main <a href="https://data.rcsb.org">RCSB Data API</a> and generates Protein Feature Summaries.
- The package allows access to RCSB Saguaro and Molstar methods to add or change the displayed data. </p>
- <p>When using rcsb-saguaro, please cite:</p>
- <p>Joan Segura, Yana Rose, Sebastian Bittrich, Stephen K Burley, Jose M Duarte.
- RCSB Protein Data Bank 1D3D module: displaying positional features on macromolecular assemblies, Bioinformatics, 2022; <a href="https://doi.org/10.1093/bioinformatics/btac317">https://doi.org/10.1093/bioinformatics/btac317</a></p>
- <div id="pfv"></div>
- <script crossorigin src="https://unpkg.com/react@17/umd/react.production.min.js"></script>
- <script crossorigin src="https://unpkg.com/react-dom@17/umd/react-dom.production.min.js"></script>
- <script crossorigin src="https://cdn.jsdelivr.net/npm/@rcsb/rcsb-saguaro-3d/build/dist/app.js"></script>
- <script type="text/javascript">
- var __assign = (this && this.__assign) || function () {
- __assign = Object.assign || function(t) {
- for (var s, i = 1, n = arguments.length; i < n; i++) {
- s = arguments[i];
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
- t[p] = s[p];
- }
- return t;
- };
- return __assign.apply(this, arguments);
- };
- var rowConfigChainA = [
- {
- trackId: "sequenceTrack",
- trackHeight: 20,
- trackColor: "#F9F9F9",
- displayType: "sequence" /* SEQUENCE */,
- nonEmptyDisplay: true,
- rowTitle: "CHAIN A",
- trackData: [
- {
- begin: 1,
- value: "CGVPAIQPVLSGLSRIVNGEEAVPGSWPWQVSLQDKTGFHFCGGSLINENWVVTAAHCGVTTSDVVVAGEFDQGSSSEKIQKLKIAKVFKNSKYNSLTINNDITLLKLSTAASFSQTVSAVCLPSASDDFAAGTTCVTTGWGLTRYTNANTPDRLQQASLPLLSNTNCKKYWGTKIKDAMICAGASGVSSCMGDSGGPLVCKKNGAWTLVGIVSWGSSTCSTSTPGVYARVTALVNWVQQTLAAN"
- }
- ]
- }, {
- trackId: "blockTrack",
- trackHeight: 20,
- trackColor: "#F9F9F9",
- displayType: "block" /* BLOCK */,
- displayColor: "#76ae91",
- rowTitle: "FEATURE",
- trackData: [{
- begin: 20,
- end: 25
- }, {
- begin: 150,
- end: 160
- }]
- }
- ];
- var rowConfigChainB = [
- {
- trackId: "sequenceTrack",
- trackHeight: 20,
- trackColor: "#F9F9F9",
- displayType: "sequence" /* SEQUENCE */,
- nonEmptyDisplay: true,
- rowTitle: "CHAIN B",
- trackData: [
- {
- begin: 1,
- value: "TEFGSELKSFPEVVGKTVDQAREYFTLHYPQYDVYFLPEGSPVTLDLRYNRVRVFYNPGTNVVNHVPHVG"
- }
- ]
- }, {
- trackId: "blockTrack",
- trackHeight: 20,
- trackColor: "#F9F9F9",
- displayType: "block" /* BLOCK */,
- displayColor: "#f17070",
- rowTitle: "FEATURE",
- trackData: [{
- begin: 20,
- end: 50
- }]
- }
- ];
- var fvConfigChainA = {
- boardId: "1acb.A_board",
- boardConfig: {
- range: {
- min: 1,
- max: 245
- },
- disableMenu:true,
- rowTitleWidth: 80,
- trackWidth: 670,
- includeAxis: true
- },
- rowConfig: rowConfigChainA,
- sequenceSelectionChangeCallback: function (plugin, stateManager, sequenceRegion) {
- stateManager.selectionState.clearSelection("select", { modelId: "1acb_board", labelAsymId: "A" });
- plugin.clearSelection("select", { modelId: "1acb_board", labelAsymId: "A" });
- if (sequenceRegion.length > 0) {
- var regions = sequenceRegion.map(function (r) {
- var _a;
- return ({
- modelId: "1acb_board",
- labelAsymId: "A",
- region: { begin: r.begin, end: (_a = r.end) !== null && _a !== void 0 ? _a : r.begin, source: "sequence" }
- });
- });
- stateManager.selectionState.addSelectionFromMultipleRegions(regions, "select");
- plugin.select(regions.map(function (r) { return (__assign(__assign({}, r), { begin: r.region.begin, end: r.region.end })); }), "select", "add");
- }
- else {
- plugin.resetCamera();
- }
- },
- sequenceElementClickCallback: function (plugin, selectorManager, d) {
- var _a;
- if (d != null)
- plugin.cameraFocus("1acb_board", "A", d.begin, (_a = d.end) !== null && _a !== void 0 ? _a : d.begin);
- },
- sequenceHoverCallback: function (plugin, selectorManager, elements) {
- if (elements == null || elements.length == 0)
- plugin.clearSelection("hover");
- else
- plugin.select(elements.map(function (e) {
- var _a;
- return ({
- modelId: "1acb_board",
- labelAsymId: "A",
- begin: e.begin,
- end: (_a = e.end) !== null && _a !== void 0 ? _a : e.begin
- });
- }), "hover", "set");
- },
- structureSelectionCallback: function (plugin, pfv, stateManager) {
- const sel = stateManager.selectionState.getSelectionWithCondition("1acb_board", "A", "select");
- if(sel == null) {
- pfv.clearSelection("select");
- plugin.resetCamera();
- }else {
- pfv.setSelection({elements: sel.regions, mode: "select"});
- }
- },
- structureHoverCallback: function (plugin, pfv, stateManager) {
- var sel = stateManager.selectionState.getSelectionWithCondition("1acb_board", "A", "hover");
- if (sel == null)
- pfv.clearSelection("hover");
- else
- pfv.setSelection({ elements: sel.regions, mode: "hover" });
- }
- };
- var fvConfigChainB = {
- boardId: "1acb.B_board",
- boardConfig: {
- range: {
- min: 1,
- max: 70
- },
- disableMenu:true,
- rowTitleWidth: 80,
- trackWidth: 670,
- includeAxis: true
- },
- rowConfig: rowConfigChainB,
- sequenceSelectionChangeCallback: function (plugin, stateManager, sequenceRegion) {
- stateManager.selectionState.clearSelection("select", { modelId: "1acb_board", labelAsymId: "B" });
- plugin.clearSelection("select", { modelId: "1acb_board", labelAsymId: "B" });
- if (sequenceRegion.length > 0) {
- var regions = sequenceRegion.map(function (r) {
- var _a;
- return ({
- modelId: "1acb_board",
- labelAsymId: "B",
- region: { begin: r.begin, end: (_a = r.end) !== null && _a !== void 0 ? _a : r.begin, source: "sequence" }
- });
- });
- stateManager.selectionState.addSelectionFromMultipleRegions(regions, "select");
- plugin.select(regions.map(function (r) { return (__assign(__assign({}, r), { begin: r.region.begin, end: r.region.end })); }), "select", "add");
- }
- else {
- plugin.resetCamera();
- }
- },
- sequenceElementClickCallback: function (plugin, selectorManager, d) {
- var _a;
- if (d != null)
- plugin.cameraFocus("1acb_board", "B", d.begin, (_a = d.end) !== null && _a !== void 0 ? _a : d.begin);
- },
- sequenceHoverCallback: function (plugin, selectorManager, elements) {
- if (elements == null || elements.length == 0)
- plugin.clearSelection("hover");
- else
- plugin.select(elements.map(function (e) {
- var _a;
- return ({
- modelId: "1acb_board",
- labelAsymId: "B",
- begin: e.begin,
- end: (_a = e.end) !== null && _a !== void 0 ? _a : e.begin
- });
- }), "hover", "set");
- },
- structureSelectionCallback: function (plugin, pfv, stateManager) {
- const sel = stateManager.selectionState.getSelectionWithCondition("1acb_board", "B", "select");
- if (sel == null) {
- pfv.clearSelection("select");
- plugin.resetCamera();
- }
- else {
- pfv.setSelection({ elements: sel.regions, mode: "select" });
- }
- },
- structureHoverCallback: function (plugin, pfv, stateManager) {
- var sel = stateManager.selectionState.getSelectionWithCondition("1acb_board", "B", "hover");
- if (sel == null)
- pfv.clearSelection("hover");
- else
- pfv.setSelection({ elements: sel.regions, mode: "hover" });
- }
- };
- var blockChainA = {
- blockId: "chainA",
- featureViewConfig: [fvConfigChainA]
- };
- var blockChainB = {
- blockId: "chainB",
- featureViewConfig: [fvConfigChainB]
- };
- var blockSelectorElement = function (blockSelectorManager) {
- return (React.createElement("div", null,
- React.createElement("select", { onChange: function (e) {
- blockSelectorManager.setActiveBlock(e.target.value);
- } },
- React.createElement("option", { value: "chainA" }, "Chain A"),
- React.createElement("option", { value: "chainB" }, "Chain B"))));
- };
- var customConfig = {
- blockConfig: [blockChainA, blockChainB],
- blockSelectorElement: blockSelectorElement
- };
- var sequenceConfig = {
- title: undefined,
- subtitle: undefined,
- config: customConfig
- };
- var molstarConfig = {
- loadConfig: {
- loadMethod: "loadPdbId",
- loadParams: {
- entryId: "1acb",
- id: "1acb_board"
- }
- },
- structureViewerConfig: {
- viewerProps:{
- showImportControls: true,
- showSessionControls: false
- }
- },
- };
- document.addEventListener("DOMContentLoaded", function (event) {
- var panel3d = new RcsbFv3D.custom({
- elementId: "pfv",
- structurePanelConfig: molstarConfig,
- sequencePanelConfig: sequenceConfig,
- cssConfig: {
- overwriteCss:true,
- rootPanel:{
- display:"flex",
- flexDirection:"column-reverse"
- },
- structurePanel:{
- width: 750,
- height: 700
- },
- sequencePanel:{
- width:750,
- marginBottom:5
- }
- },
- });
- panel3d.render();
- });
- </script>
- <a id="md:cdn-javascript" class="tsd-anchor"></a><h3><a href="#md:cdn-javascript">CDN JavaScript</a></h3><p><code><script src="https://cdn.jsdelivr.net/npm/@rcsb/rcsb-saguaro-3d/build/dist/app.js" type="text/javascript"></script></code></p>
- <a id="md:node-module-instalation" class="tsd-anchor"></a><h3><a href="#md:node-module-instalation">Node Module Instalation</a></h3><p><code>npm install @rcsb/rcsb-saguaro-3d</code></p>
- <a id="md:building-amp-running" class="tsd-anchor"></a><h2><a href="#md:building-amp-running">Building & Running</a></h2><a id="md:build-app" class="tsd-anchor"></a><h3><a href="#md:build-app">Build app</a></h3><pre><code><span class="hl-0">npm</span><span class="hl-1"> </span><span class="hl-0">install</span><br/><span class="hl-0">npm</span><span class="hl-1"> </span><span class="hl-0">run</span><span class="hl-1"> </span><span class="hl-0">buildApp</span>
- </code><button>Copy</button></pre>
- <a id="md:testing" class="tsd-anchor"></a><h3><a href="#md:testing">Testing</a></h3><p>Different testing example are available in the <code>src/examples</code> folder</p>
- <ul>
- <li><code>npm install</code></li>
- <li><code>npm run devServer</code></li>
- </ul>
- <p>Go to:</p>
- <ul>
- <li><code>http://localhost:9000/assembly.html</code></li>
- <li><code>http://localhost:9000/assembly-interface.html</code></li>
- <li><code>http://localhost:9000/uniprot.html</code>
- ...</li>
- </ul>
- <a id="md:library-documentation" class="tsd-anchor"></a><h3><a href="#md:library-documentation">Library Documentation</a></h3><ul>
- <li>Documentation <a href="https://rcsb.github.io/rcsb-saguaro-3d/index.html">page</a></li>
- <li>TypeScript classes documentation can be found <a href="https://rcsb.github.io/rcsb-saguaro-3d/modules.html">here</a></li>
- </ul>
- <a id="md:main-classes-and-interfaces" class="tsd-anchor"></a><h3><a href="#md:main-classes-and-interfaces">Main Classes and Interfaces</a></h3><a id="md:assembly-view" class="tsd-anchor"></a><h4><a href="#md:assembly-view">Assembly view</a></h4><p>Class <strong><code>RcsbFv3DAssembly</code></strong> (<code>src/RcsbFv3D/RcsbFv3DAssembly.tsx</code>) builds a predefined 1D/3D view for PDB assemblies. This method is used in the RCSB PDB web portal
- to display 1D positional features of PDB models (ex: <a href="https://www.rcsb.org/3d-sequence/4HHB">4hhb</a>). Its configuration requires a single PDB Id.
- In addition, <code>additionalConfig</code> allows to configure the feature viewer as describe in rcsb-saguaro-app <a href="https://rcsb.github.io/rcsb-saguaro-app/interfaces/_internal_.RcsbFvAdditionalConfig.html">API</a>.
- This parameter exposes the board configuration through the attribute <code>boardConfig</code> (<a href="https://rcsb.github.io/rcsb-saguaro/interfaces/RcsbFvBoardConfigInterface.html">ref</a>).
- The component will be mounted in the html element with id <code>elementId</code>. If there is no html element in the current document,
- a new div element will be added, and the component will be displayed in full screen mode. </p>
- <pre><code class="language-typescript"><span class="hl-2">export</span><span class="hl-1"> </span><span class="hl-3">interface</span><span class="hl-1"> </span><span class="hl-4">RcsbFv3DAssemblyInterface</span><span class="hl-1"> {</span><br/><span class="hl-1"> </span><span class="hl-0">elementId</span><span class="hl-1">?: </span><span class="hl-4">string</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-0">config</span><span class="hl-1">: {</span><br/><span class="hl-1"> </span><span class="hl-0">entryId</span><span class="hl-1">: </span><span class="hl-4">string</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-0">assemblyId</span><span class="hl-1">?: </span><span class="hl-4">string</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-0">title</span><span class="hl-1">?: </span><span class="hl-4">string</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-0">subtitle</span><span class="hl-1">?: </span><span class="hl-4">string</span><span class="hl-1">;</span><br/><span class="hl-1"> };</span><br/><span class="hl-1"> </span><span class="hl-0">additionalConfig</span><span class="hl-1">?: </span><span class="hl-4">RcsbFv3DAssemblyAdditionalConfig</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-0">instanceSequenceConfig</span><span class="hl-1">?: </span><span class="hl-4">InstanceSequenceConfig</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-0">molstarProps</span><span class="hl-1">?: </span><span class="hl-4">Partial</span><span class="hl-1"><</span><span class="hl-4">ViewerProps</span><span class="hl-1">>;</span><br/><span class="hl-1"> </span><span class="hl-0">cssConfig</span><span class="hl-1">?: </span><span class="hl-4">RcsbFv3DCssConfig</span><span class="hl-1">;</span><br/><span class="hl-1">}</span>
- </code><button>Copy</button></pre>
- <p>Source code example can be found in <code>src/examples/assembly/index.tsx</code>.</p>
- <a id="md:custom-view" class="tsd-anchor"></a><h4><a href="#md:custom-view">Custom view</a></h4><p>Class <strong><code>RcsbFv3DCustom</code></strong> file <code>src/RcsbFv3D/RcsbFv3DCustom.tsx</code> builds a customized view between one or more feature viewers and a single Molstar plugin.
- The configuration interface encodes the parameters for the feature viewers (<code>sequencePanelConfig</code>), the Molstar plugin (<code>structurePanelConfig</code>) and
- their dynamic interaction.</p>
- <pre><code class="language-typescript"><span class="hl-3">interface</span><span class="hl-1"> </span><span class="hl-4">RcsbFv3DCustomInterface</span><span class="hl-1"> {</span><br/><span class="hl-1"> </span><span class="hl-0">elementId</span><span class="hl-1">?: </span><span class="hl-4">string</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-0">structurePanelConfig</span><span class="hl-1">: </span><span class="hl-4">RcsbFvStructureConfigInterface</span><span class="hl-1"><</span><br/><span class="hl-1"> </span><span class="hl-4">LoadMolstarInterface</span><span class="hl-1">,</span><br/><span class="hl-1"> { </span><span class="hl-0">viewerProps</span><span class="hl-1">:</span><span class="hl-4">Partial</span><span class="hl-1"><</span><span class="hl-4">ViewerProps</span><span class="hl-1">> }</span><br/><span class="hl-1"> >;</span><br/><span class="hl-1"> </span><span class="hl-0">sequencePanelConfig</span><span class="hl-1">: {</span><br/><span class="hl-1"> </span><span class="hl-0">config</span><span class="hl-1">: </span><span class="hl-4">CustomViewInterface</span><span class="hl-1"><</span><span class="hl-4">LoadMolstarInterface</span><span class="hl-1">>;</span><br/><span class="hl-1"> </span><span class="hl-0">title</span><span class="hl-1">?: </span><span class="hl-4">string</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-0">subtitle</span><span class="hl-1">?: </span><span class="hl-4">string</span><span class="hl-1">;</span><br/><span class="hl-1"> }</span><br/><span class="hl-1"> </span><span class="hl-0">cssConfig</span><span class="hl-1">?: </span><span class="hl-4">RcsbFv3DCssConfig</span><span class="hl-1">;</span><br/><br/><span class="hl-1">}</span>
- </code><button>Copy</button></pre>
- <p><img src="https://raw.githubusercontent.com/rcsb/rcsb-saguaro-3d/master/.github/img/config_img.png" alt="Alt text" title="Custom config schema"></p>
- <a id="md:structural-panel" class="tsd-anchor"></a><h5><a href="#md:structural-panel">Structural Panel</a></h5><p>The structural panel configuration <code>structurePanelConfig: RcsbFvStructureConfigInterface<LoadMolstarInterface,{viewerProps:Partial<ViewerProps>}></code> includes the loading configuration for the 3D structural data
- and the Molstar plugin. A full description of the structural panel configuration can be found <a href="https://rcsb.github.io/rcsb-saguaro-3d/interfaces/RcsbFv3DAssembly._internal_.RcsbFvStructureConfigInterface.html">here</a></p>
- <pre><code class="language-typescript"><span class="hl-3">interface</span><span class="hl-1"> </span><span class="hl-4">RcsbFvStructureConfigInterface</span><span class="hl-1"><</span><span class="hl-4">R</span><span class="hl-1">,</span><span class="hl-4">S</span><span class="hl-1">> {</span><br/><span class="hl-1"> </span><span class="hl-0">loadConfig</span><span class="hl-1">: </span><span class="hl-4">R</span><span class="hl-1"> | </span><span class="hl-4">Array</span><span class="hl-1"><</span><span class="hl-4">R</span><span class="hl-1">>;</span><br/><span class="hl-1"> </span><span class="hl-0">structureViewerConfig</span><span class="hl-1">: </span><span class="hl-4">S</span><span class="hl-1">;</span><br/><span class="hl-1">}</span>
- </code><button>Copy</button></pre>
- <p>The attribute <code>loadConfig: LoadMolstarInterface</code> encodes the configuration for loading the 3D structural data. </p>
- <pre><code class="language-typescript"><span class="hl-3">interface</span><span class="hl-1"> </span><span class="hl-4">LoadMolstarInterface</span><span class="hl-1"> {</span><br/><span class="hl-1"> </span><span class="hl-0">loadMethod</span><span class="hl-1">: </span><span class="hl-4">LoadMethod</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-0">loadParams</span><span class="hl-1">: </span><span class="hl-4">LoadParams</span><span class="hl-1">;</span><br/><span class="hl-1">}</span>
- </code><button>Copy</button></pre>
- <ul>
- <li><code>loadMethod: LoadMethod</code> is an enumerated value that indicates the source of the structural models</li>
- </ul>
- <pre><code class="language-typescript"><span class="hl-3">enum</span><span class="hl-1"> </span><span class="hl-4">LoadMethod</span><span class="hl-1"> {</span><br/><span class="hl-1"> </span><span class="hl-5">loadPdbId</span><span class="hl-1"> = </span><span class="hl-6">"loadPdbId"</span><span class="hl-1">,</span><br/><span class="hl-1"> </span><span class="hl-5">loadStructureFromUrl</span><span class="hl-1"> = </span><span class="hl-6">"loadStructureFromUrl"</span><br/><span class="hl-1">}</span>
- </code><button>Copy</button></pre>
- <ul>
- <li><code>loadParams: LoadParams</code> encode the parameters needed to collect and load the data. If <code>id</code> is provided, it can be used to identify the 3D models
- in the methods defined by <code>SaguaroPluginPublicInterface</code></li>
- </ul>
- <pre><code class="language-typescript"><span class="hl-3">interface</span><span class="hl-1"> </span><span class="hl-4">LoadParams</span><span class="hl-1"> {</span><br/><span class="hl-1"> </span><span class="hl-0">id</span><span class="hl-1">?: </span><span class="hl-4">string</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-0">pdbId</span><span class="hl-1">?: </span><span class="hl-4">string</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-0">url</span><span class="hl-1">?: </span><span class="hl-4">string</span><span class="hl-1">,</span><br/><span class="hl-1"> </span><span class="hl-0">isBinary</span><span class="hl-1">?: </span><span class="hl-4">boolean</span><br/><span class="hl-1">}</span>
- </code><button>Copy</button></pre>
- <a id="md:sequence-panel" class="tsd-anchor"></a><h5><a href="#md:sequence-panel">Sequence panel</a></h5><p>The sequence panel organizes information in different blocks where each block encodes the configuration
- (<code>blockConfig</code>) to display one or more feature viewers. Only a single block can be displayed at a time. The optional parameter <code>blockSelectorElement</code> defines a React component
- that renders the html element used to change the displayed block. The class <code>BlockSelectorManager</code> is used to select which block is
- displayed are those that are hidden. For example, <code>blockSelectorManager.setActiveBlock("myBlock")</code> will display the feature viewers defined in the block
- with <code>blockId</code> <code>"myBlock"</code> (see <code>FeatureBlockInterface</code>) and hide the others. Additionally, <code>blockChangeCallback</code> defines a function that will be executed
- when the displayed block changes.</p>
- <pre><code class="language-typescript"><span class="hl-3">interface</span><span class="hl-1"> </span><span class="hl-4">CustomViewInterface</span><span class="hl-1"> {</span><br/><span class="hl-1"> </span><span class="hl-0">blockConfig</span><span class="hl-1">: </span><span class="hl-4">FeatureBlockInterface</span><span class="hl-1"> | </span><span class="hl-4">Array</span><span class="hl-1"><</span><span class="hl-4">FeatureBlockInterface</span><span class="hl-1">>;</span><br/><span class="hl-1"> </span><span class="hl-7">blockSelectorElement</span><span class="hl-1">?: (</span><span class="hl-0">blockSelector</span><span class="hl-1">: </span><span class="hl-4">BlockSelectorManager</span><span class="hl-1">) </span><span class="hl-3">=></span><span class="hl-1"> </span><span class="hl-4">JSX</span><span class="hl-1">.</span><span class="hl-4">Element</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-7">blockChangeCallback</span><span class="hl-1">?: (</span><span class="hl-0">plugin</span><span class="hl-1">: </span><span class="hl-4">StructureViewerPublicInterface</span><span class="hl-1">, </span><span class="hl-0">pfvList</span><span class="hl-1">: </span><span class="hl-4">Array</span><span class="hl-1"><</span><span class="hl-4">RcsbFv</span><span class="hl-1">>, </span><span class="hl-0">selection</span><span class="hl-1">: </span><span class="hl-4">RcsbFvSelectorManager</span><span class="hl-1">) </span><span class="hl-3">=></span><span class="hl-1"> </span><span class="hl-4">void</span><span class="hl-1">;</span><br/><span class="hl-1">}</span>
- </code><button>Copy</button></pre>
- <p>Source code example can be found in <code>src/examples/multiple-chain/index.tsx</code>.</p>
- <p>Each block must contain a unique block identifier (<code>blockId</code>) and the configuration for all the feature viewers that will be rendered
- when the block is activated (<code>featureViewConfig</code>).</p>
- <pre><code class="language-typescript"><span class="hl-3">interface</span><span class="hl-1"> </span><span class="hl-4">FeatureBlockInterface</span><span class="hl-1"> {</span><br/><span class="hl-1"> </span><span class="hl-0">blockId</span><span class="hl-1">:</span><span class="hl-4">string</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-0">featureViewConfig</span><span class="hl-1">: </span><span class="hl-4">Array</span><span class="hl-1"><</span><span class="hl-4">FeatureViewInterface</span><span class="hl-1">> | </span><span class="hl-4">FeatureViewInterface</span><span class="hl-1">;</span><br/><span class="hl-1">}</span>
- </code><button>Copy</button></pre>
- <p>The interface for each feature viewer defines its dynamic interaction with the Molstar plugin through different event callbacks functions</p>
- <ul>
- <li><code>sequenceSelectionChangeCallback</code> defines how the Molstar plugin reacts when the feature viewer selection changes</li>
- <li><code>sequenceElementClickCallback</code> defines how the Molstar plugin reacts when a feature viewer element (positional annotation) is clicked</li>
- <li><code>sequenceHoverCallback</code> defines how the Molstar plugin reacts when the mouse hovers the feature viewer or any of its elements</li>
- <li><code>structureSelectionCallback</code> defines how the protein feature viewer reacts when the Molstar plugin selection changes</li>
- <li><code>structureHoverCallback</code> defines how the protein feature viewer reacts when displayed models on the Molstar plugin are hovered</li>
- </ul>
- <pre><code class="language-typescript"><span class="hl-2">export</span><span class="hl-1"> </span><span class="hl-3">interface</span><span class="hl-1"> </span><span class="hl-4">FeatureViewInterface</span><span class="hl-1"> {</span><br/><span class="hl-1"> </span><span class="hl-0">boardId</span><span class="hl-1">?:</span><span class="hl-4">string</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-0">boardConfig</span><span class="hl-1">: </span><span class="hl-4">RcsbFvBoardConfigInterface</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-0">rowConfig</span><span class="hl-1">: </span><span class="hl-4">Array</span><span class="hl-1"><</span><span class="hl-4">RcsbFvRowConfigInterface</span><span class="hl-1">>;</span><br/><span class="hl-1"> </span><span class="hl-7">sequenceSelectionChangeCallback</span><span class="hl-1">: (</span><span class="hl-0">plugin</span><span class="hl-1">: </span><span class="hl-4">StructureViewerPublicInterface</span><span class="hl-1">, </span><span class="hl-0">selectorManager</span><span class="hl-1">: </span><span class="hl-4">RcsbFvSelectorManager</span><span class="hl-1">, </span><span class="hl-0">sequenceRegion</span><span class="hl-1">: </span><span class="hl-4">Array</span><span class="hl-1"><</span><span class="hl-4">RcsbFvTrackDataElementInterface</span><span class="hl-1">>) </span><span class="hl-3">=></span><span class="hl-1"> </span><span class="hl-4">void</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-7">sequenceElementClickCallback</span><span class="hl-1">: (</span><span class="hl-0">plugin</span><span class="hl-1">: </span><span class="hl-4">StructureViewerPublicInterface</span><span class="hl-1">, </span><span class="hl-0">selectorManager</span><span class="hl-1">: </span><span class="hl-4">RcsbFvSelectorManager</span><span class="hl-1">, </span><span class="hl-0">d</span><span class="hl-1">: </span><span class="hl-4">RcsbFvTrackDataElementInterface</span><span class="hl-1">) </span><span class="hl-3">=></span><span class="hl-1"> </span><span class="hl-4">void</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-7">sequenceHoverCallback</span><span class="hl-1">: (</span><span class="hl-0">plugin</span><span class="hl-1">: </span><span class="hl-4">StructureViewerPublicInterface</span><span class="hl-1">, </span><span class="hl-0">selectorManager</span><span class="hl-1">: </span><span class="hl-4">RcsbFvSelectorManager</span><span class="hl-1">, </span><span class="hl-0">hoverRegion</span><span class="hl-1">: </span><span class="hl-4">Array</span><span class="hl-1"><</span><span class="hl-4">RcsbFvTrackDataElementInterface</span><span class="hl-1">>) </span><span class="hl-3">=></span><span class="hl-1"> </span><span class="hl-4">void</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-7">structureSelectionCallback</span><span class="hl-1">: (</span><span class="hl-0">plugin</span><span class="hl-1">: </span><span class="hl-4">StructureViewerPublicInterface</span><span class="hl-1">, </span><span class="hl-0">pfv</span><span class="hl-1">: </span><span class="hl-4">RcsbFv</span><span class="hl-1">, </span><span class="hl-0">selectorManager</span><span class="hl-1">: </span><span class="hl-4">RcsbFvSelectorManager</span><span class="hl-1">) </span><span class="hl-3">=></span><span class="hl-1"> </span><span class="hl-4">void</span><span class="hl-1">;</span><br/><span class="hl-1"> </span><span class="hl-7">structureHoverCallback</span><span class="hl-1">: (</span><span class="hl-0">plugin</span><span class="hl-1">: </span><span class="hl-4">StructureViewerPublicInterface</span><span class="hl-1">, </span><span class="hl-0">pfv</span><span class="hl-1">: </span><span class="hl-4">RcsbFv</span><span class="hl-1">, </span><span class="hl-0">selectorManager</span><span class="hl-1">: </span><span class="hl-4">RcsbFvSelectorManager</span><span class="hl-1">) </span><span class="hl-3">=></span><span class="hl-1"> </span><span class="hl-4">void</span><span class="hl-1">;</span><br/><span class="hl-1">}</span>
- </code><button>Copy</button></pre>
- <p><code>plugin: SaguaroPluginPublicInterface</code> exposes the interface to interact with the Molstar plugin
- and change model representations (<a href="https://rcsb.github.io/rcsb-saguaro-3d/interfaces/RcsbFv3DAssembly._internal_.StructureViewerPublicInterface.html">ref</a>).
- It provides multiple methods such as hide, display or select to modify how structural data is displayed. The parameter <code>pfv: RcsbFv</code>
- allows to access the feature viewer API (<a href="https://rcsb.github.io/rcsb-saguaro/classes/RcsbFv.html">ref</a>). It exposes methods to modify
- selections, change board configuration, zoom or adding new tracks.</p>
- <p>Source code example can be found in <code>src/examples/single-chain/index.tsx</code></p>
- <a id="md:contributing" class="tsd-anchor"></a><h2><a href="#md:contributing">Contributing</a></h2><p>All contributions are welcome. Please, make a pull request or open an issue.</p>
- <a id="md:license" class="tsd-anchor"></a><h2><a href="#md:license">License</a></h2><p>The MIT License</p>
- <pre><code><span class="hl-7">Copyright</span><span class="hl-1"> (</span><span class="hl-0">c</span><span class="hl-1">) </span><span class="hl-8">2021</span><span class="hl-1"> - </span><span class="hl-0">now</span><span class="hl-1">, </span><span class="hl-5">RCSB</span><span class="hl-1"> </span><span class="hl-5">PDB</span><span class="hl-1"> </span><span class="hl-0">and</span><span class="hl-1"> </span><span class="hl-0">contributors</span>
- </code><button>Copy</button></pre>
- <p>Permission is hereby granted, free of charge, to any person obtaining a copy
- of this software and associated documentation files (the "Software"), to deal
- in the Software without restriction, including without limitation the rights
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- copies of the Software, and to permit persons to whom the Software is
- furnished to do so, subject to the following conditions:</p>
- <p>The above copyright notice and this permission notice shall be included in
- all copies or substantial portions of the Software.</p>
- <p>THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- THE SOFTWARE.</p>
- </div></div>
- <div class="col-sidebar">
- <div class="page-menu">
- <div class="tsd-navigation settings">
- <details class="tsd-index-accordion"><summary class="tsd-accordion-summary">
- <h3><svg width="20" height="20" viewBox="0 0 24 24" fill="none"><use href="#icon-chevronDown"></use></svg>Settings</h3></summary>
- <div class="tsd-accordion-details">
- <div class="tsd-filter-visibility">
- <h4 class="uppercase">Member Visibility</h4><form>
- <ul id="tsd-filter-options">
- <li class="tsd-filter-item"><label class="tsd-filter-input"><input type="checkbox" id="tsd-filter-protected" name="protected"/><svg width="32" height="32" viewBox="0 0 32 32" aria-hidden="true"><use href="#icon-checkbox"></use></svg><span>Protected</span></label></li>
- <li class="tsd-filter-item"><label class="tsd-filter-input"><input type="checkbox" id="tsd-filter-private" name="private"/><svg width="32" height="32" viewBox="0 0 32 32" aria-hidden="true"><use href="#icon-checkbox"></use></svg><span>Private</span></label></li>
- <li class="tsd-filter-item"><label class="tsd-filter-input"><input type="checkbox" id="tsd-filter-inherited" name="inherited" checked/><svg width="32" height="32" viewBox="0 0 32 32" aria-hidden="true"><use href="#icon-checkbox"></use></svg><span>Inherited</span></label></li></ul></form></div>
- <div class="tsd-theme-toggle">
- <h4 class="uppercase">Theme</h4><select id="tsd-theme"><option value="os">OS</option><option value="light">Light</option><option value="dark">Dark</option></select></div></div></details></div>
- <details open class="tsd-index-accordion tsd-page-navigation"><summary class="tsd-accordion-summary">
- <h3><svg width="20" height="20" viewBox="0 0 24 24" fill="none"><use href="#icon-chevronDown"></use></svg>On This Page</h3></summary>
- <div class="tsd-accordion-details">
- <ul>
- <li>
- <ul>
- <li><a href="#md:rcsb-saguaro-3d"><span>rcsb-<wbr/>saguaro-<wbr/>3D</span></a></li>
- <li>
- <ul>
- <li><a href="#md:cdn-javascript"><span>CDN <wbr/>Java<wbr/>Script</span></a></li>
- <li>
- <ul>
- <li><a href="#md:node-module-instalation"><span>Node <wbr/>Module <wbr/>Instalation</span></a></li></ul></li>
- <li><a href="#md:building-amp-running"><span>Building & <wbr/>Running</span></a></li>
- <li>
- <ul>
- <li><a href="#md:build-app"><span>Build app</span></a></li>
- <li><a href="#md:testing"><span>Testing</span></a></li>
- <li><a href="#md:library-documentation"><span>Library <wbr/>Documentation</span></a></li>
- <li><a href="#md:main-classes-and-interfaces"><span>Main <wbr/>Classes and <wbr/>Interfaces</span></a></li>
- <li>
- <ul>
- <li><a href="#md:assembly-view"><span>Assembly view</span></a></li>
- <li><a href="#md:custom-view"><span>Custom view</span></a></li>
- <li>
- <ul>
- <li><a href="#md:structural-panel"><span>Structural <wbr/>Panel</span></a></li>
- <li><a href="#md:sequence-panel"><span>Sequence panel</span></a></li></ul></li></ul></li></ul></li>
- <li><a href="#md:contributing"><span>Contributing</span></a></li>
- <li><a href="#md:license"><span>License</span></a></li></ul></li></ul></li></ul></div></details></div>
- <div class="site-menu">
- <nav class="tsd-navigation"><a href="index.html" class="current"><svg class="tsd-kind-icon" viewBox="0 0 24 24"><use href="#icon-1"></use></svg><span>@rcsb/rcsb-saguaro-3d</span></a>
- <ul class="tsd-small-nested-navigation" id="tsd-nav-container" data-base=".">
- <li><a href="modules/RcsbFv3DAssembly.html"><svg class="tsd-kind-icon" viewBox="0 0 24 24"><use href="#icon-2"></use></svg>RcsbFv3DAssembly</a></li>
- <li><a href="modules/RcsbFv3DCustom.html"><svg class="tsd-kind-icon" viewBox="0 0 24 24"><use href="#icon-2"></use></svg>RcsbFv3DCustom</a></li>
- <li><a href="modules/RcsbFv3DSequenceIdentity.html"><svg class="tsd-kind-icon" viewBox="0 0 24 24"><use href="#icon-2"></use></svg>RcsbFv3DSequenceIdentity</a></li>
- <li><a href="modules/RcsbFv3DUniprot.html"><svg class="tsd-kind-icon" viewBox="0 0 24 24"><use href="#icon-2"></use></svg>RcsbFv3DUniprot</a></li></ul></nav></div></div></div>
- <div class="tsd-generator">
- <p>Generated using <a href="https://typedoc.org/" rel="noopener" target="_blank">TypeDoc</a></p></div>
- <div class="overlay"></div><svg style="display: none"><g id="icon-1"><rect fill="var(--color-icon-background)" stroke="var(--color-ts-namespace)" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="6"></rect><path d="M9.33 16V7.24H10.77L13.446 14.74C13.43 14.54 13.41 14.296 13.386 14.008C13.37 13.712 13.354 13.404 13.338 13.084C13.33 12.756 13.326 12.448 13.326 12.16V7.24H14.37V16H12.93L10.266 8.5C10.282 8.692 10.298 8.936 10.314 9.232C10.33 9.52 10.342 9.828 10.35 10.156C10.366 10.476 10.374 10.784 10.374 11.08V16H9.33Z" fill="var(--color-text)"></path></g><g id="icon-2"><rect fill="var(--color-icon-background)" stroke="var(--color-ts-namespace)" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="6"></rect><path d="M9.33 16V7.24H10.77L13.446 14.74C13.43 14.54 13.41 14.296 13.386 14.008C13.37 13.712 13.354 13.404 13.338 13.084C13.33 12.756 13.326 12.448 13.326 12.16V7.24H14.37V16H12.93L10.266 8.5C10.282 8.692 10.298 8.936 10.314 9.232C10.33 9.52 10.342 9.828 10.35 10.156C10.366 10.476 10.374 10.784 10.374 11.08V16H9.33Z" fill="var(--color-text)"></path></g><g id="icon-4"><rect fill="var(--color-icon-background)" stroke="var(--color-ts-namespace)" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="6"></rect><path d="M9.33 16V7.24H10.77L13.446 14.74C13.43 14.54 13.41 14.296 13.386 14.008C13.37 13.712 13.354 13.404 13.338 13.084C13.33 12.756 13.326 12.448 13.326 12.16V7.24H14.37V16H12.93L10.266 8.5C10.282 8.692 10.298 8.936 10.314 9.232C10.33 9.52 10.342 9.828 10.35 10.156C10.366 10.476 10.374 10.784 10.374 11.08V16H9.33Z" fill="var(--color-text)"></path></g><g id="icon-8"><rect fill="var(--color-icon-background)" stroke="var(--color-ts-enum)" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="6"></rect><path d="M9.45 16V7.24H14.49V8.224H10.518V10.936H14.07V11.908H10.518V15.016H14.49V16H9.45Z" fill="var(--color-text)"></path></g><g id="icon-16"><rect fill="var(--color-icon-background)" stroke="#FF984D" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="12"></rect><path d="M9.354 16V7.24H12.174C12.99 7.24 13.638 7.476 14.118 7.948C14.606 8.412 14.85 9.036 14.85 9.82C14.85 10.604 14.606 11.232 14.118 11.704C13.638 12.168 12.99 12.4 12.174 12.4H10.434V16H9.354ZM10.434 11.428H12.174C12.646 11.428 13.022 11.284 13.302 10.996C13.59 10.7 13.734 10.308 13.734 9.82C13.734 9.324 13.59 8.932 13.302 8.644C13.022 8.356 12.646 8.212 12.174 8.212H10.434V11.428Z" fill="var(--color-text)"></path></g><g id="icon-32"><rect fill="var(--color-icon-background)" stroke="var(--color-ts-variable)" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="6"></rect><path d="M11.106 16L8.85 7.24H9.966L11.454 13.192C11.558 13.608 11.646 13.996 11.718 14.356C11.79 14.708 11.842 14.976 11.874 15.16C11.906 14.976 11.954 14.708 12.018 14.356C12.09 13.996 12.178 13.608 12.282 13.192L13.758 7.24H14.85L12.582 16H11.106Z" fill="var(--color-text)"></path></g><g id="icon-64"><rect fill="var(--color-icon-background)" stroke="var(--color-ts-function)" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="6"></rect><path d="M9.39 16V7.24H14.55V8.224H10.446V11.128H14.238V12.112H10.47V16H9.39Z" fill="var(--color-text)"></path></g><g id="icon-128"><rect fill="var(--color-icon-background)" stroke="var(--color-ts-class)" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="6"></rect><path d="M11.898 16.1201C11.098 16.1201 10.466 15.8961 10.002 15.4481C9.53803 15.0001 9.30603 14.3841 9.30603 13.6001V9.64012C9.30603 8.85612 9.53803 8.24012 10.002 7.79212C10.466 7.34412 11.098 7.12012 11.898 7.12012C12.682 7.12012 13.306 7.34812 13.77 7.80412C14.234 8.25212 14.466 8.86412 14.466 9.64012H13.386C13.386 9.14412 13.254 8.76412 12.99 8.50012C12.734 8.22812 12.37 8.09212 11.898 8.09212C11.426 8.09212 11.054 8.22412 10.782 8.48812C10.518 8.75212 10.386 9.13212 10.386 9.62812V13.6001C10.386 14.0961 10.518 14.4801 10.782 14.7521C11.054 15.0161 11.426 15.1481 11.898 15.1481C12.37 15.1481 12.734 15.0161 12.99 14.7521C13.254 14.4801 13.386 14.0961 13.386 13.6001H14.466C14.466 14.3761 14.234 14.9921 13.77 15.4481C13.306 15.8961 12.682 16.1201 11.898 16.1201Z" fill="var(--color-text)"></path></g><g id="icon-256"><rect fill="var(--color-icon-background)" stroke="var(--color-ts-interface)" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="6"></rect><path d="M9.51 16V15.016H11.298V8.224H9.51V7.24H14.19V8.224H12.402V15.016H14.19V16H9.51Z" fill="var(--color-text)"></path></g><g id="icon-512"><rect fill="var(--color-icon-background)" stroke="#4D7FFF" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="12"></rect><path d="M11.898 16.1201C11.098 16.1201 10.466 15.8961 10.002 15.4481C9.53803 15.0001 9.30603 14.3841 9.30603 13.6001V9.64012C9.30603 8.85612 9.53803 8.24012 10.002 7.79212C10.466 7.34412 11.098 7.12012 11.898 7.12012C12.682 7.12012 13.306 7.34812 13.77 7.80412C14.234 8.25212 14.466 8.86412 14.466 9.64012H13.386C13.386 9.14412 13.254 8.76412 12.99 8.50012C12.734 8.22812 12.37 8.09212 11.898 8.09212C11.426 8.09212 11.054 8.22412 10.782 8.48812C10.518 8.75212 10.386 9.13212 10.386 9.62812V13.6001C10.386 14.0961 10.518 14.4801 10.782 14.7521C11.054 15.0161 11.426 15.1481 11.898 15.1481C12.37 15.1481 12.734 15.0161 12.99 14.7521C13.254 14.4801 13.386 14.0961 13.386 13.6001H14.466C14.466 14.3761 14.234 14.9921 13.77 15.4481C13.306 15.8961 12.682 16.1201 11.898 16.1201Z" fill="var(--color-text)"></path></g><g id="icon-1024"><rect fill="var(--color-icon-background)" stroke="#FF984D" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="12"></rect><path d="M9.354 16V7.24H12.174C12.99 7.24 13.638 7.476 14.118 7.948C14.606 8.412 14.85 9.036 14.85 9.82C14.85 10.604 14.606 11.232 14.118 11.704C13.638 12.168 12.99 12.4 12.174 12.4H10.434V16H9.354ZM10.434 11.428H12.174C12.646 11.428 13.022 11.284 13.302 10.996C13.59 10.7 13.734 10.308 13.734 9.82C13.734 9.324 13.59 8.932 13.302 8.644C13.022 8.356 12.646 8.212 12.174 8.212H10.434V11.428Z" fill="var(--color-text)"></path></g><g id="icon-2048"><rect fill="var(--color-icon-background)" stroke="#FF4DB8" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="12"></rect><path d="M9.162 16V7.24H10.578L11.514 10.072C11.602 10.328 11.674 10.584 11.73 10.84C11.794 11.088 11.842 11.28 11.874 11.416C11.906 11.28 11.954 11.088 12.018 10.84C12.082 10.584 12.154 10.324 12.234 10.06L13.122 7.24H14.538V16H13.482V12.82C13.482 12.468 13.49 12.068 13.506 11.62C13.53 11.172 13.558 10.716 13.59 10.252C13.622 9.78 13.654 9.332 13.686 8.908C13.726 8.476 13.762 8.1 13.794 7.78L12.366 12.16H11.334L9.894 7.78C9.934 8.092 9.97 8.456 10.002 8.872C10.042 9.28 10.078 9.716 10.11 10.18C10.142 10.636 10.166 11.092 10.182 11.548C10.206 12.004 10.218 12.428 10.218 12.82V16H9.162Z" fill="var(--color-text)"></path></g><g id="icon-4096"><rect fill="var(--color-icon-background)" stroke="var(--color-ts-function)" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="6"></rect><path d="M9.39 16V7.24H14.55V8.224H10.446V11.128H14.238V12.112H10.47V16H9.39Z" fill="var(--color-text)"></path></g><g id="icon-8192"><rect fill="var(--color-icon-background)" stroke="#FF984D" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="12"></rect><path d="M9.354 16V7.24H12.174C12.99 7.24 13.638 7.476 14.118 7.948C14.606 8.412 14.85 9.036 14.85 9.82C14.85 10.604 14.606 11.232 14.118 11.704C13.638 12.168 12.99 12.4 12.174 12.4H10.434V16H9.354ZM10.434 11.428H12.174C12.646 11.428 13.022 11.284 13.302 10.996C13.59 10.7 13.734 10.308 13.734 9.82C13.734 9.324 13.59 8.932 13.302 8.644C13.022 8.356 12.646 8.212 12.174 8.212H10.434V11.428Z" fill="var(--color-text)"></path></g><g id="icon-16384"><rect fill="var(--color-icon-background)" stroke="#4D7FFF" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="12"></rect><path d="M11.898 16.1201C11.098 16.1201 10.466 15.8961 10.002 15.4481C9.53803 15.0001 9.30603 14.3841 9.30603 13.6001V9.64012C9.30603 8.85612 9.53803 8.24012 10.002 7.79212C10.466 7.34412 11.098 7.12012 11.898 7.12012C12.682 7.12012 13.306 7.34812 13.77 7.80412C14.234 8.25212 14.466 8.86412 14.466 9.64012H13.386C13.386 9.14412 13.254 8.76412 12.99 8.50012C12.734 8.22812 12.37 8.09212 11.898 8.09212C11.426 8.09212 11.054 8.22412 10.782 8.48812C10.518 8.75212 10.386 9.13212 10.386 9.62812V13.6001C10.386 14.0961 10.518 14.4801 10.782 14.7521C11.054 15.0161 11.426 15.1481 11.898 15.1481C12.37 15.1481 12.734 15.0161 12.99 14.7521C13.254 14.4801 13.386 14.0961 13.386 13.6001H14.466C14.466 14.3761 14.234 14.9921 13.77 15.4481C13.306 15.8961 12.682 16.1201 11.898 16.1201Z" fill="var(--color-text)"></path></g><g id="icon-32768"><rect fill="var(--color-icon-background)" stroke="#FF984D" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="12"></rect><path d="M9.354 16V7.24H12.174C12.99 7.24 13.638 7.476 14.118 7.948C14.606 8.412 14.85 9.036 14.85 9.82C14.85 10.604 14.606 11.232 14.118 11.704C13.638 12.168 12.99 12.4 12.174 12.4H10.434V16H9.354ZM10.434 11.428H12.174C12.646 11.428 13.022 11.284 13.302 10.996C13.59 10.7 13.734 10.308 13.734 9.82C13.734 9.324 13.59 8.932 13.302 8.644C13.022 8.356 12.646 8.212 12.174 8.212H10.434V11.428Z" fill="var(--color-text)"></path></g><g id="icon-65536"><rect fill="var(--color-icon-background)" stroke="var(--color-ts-type-alias)" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="6"></rect><path d="M11.31 16V8.224H8.91V7.24H14.79V8.224H12.39V16H11.31Z" fill="var(--color-text)"></path></g><g id="icon-131072"><rect fill="var(--color-icon-background)" stroke="var(--color-ts-type-alias)" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="6"></rect><path d="M11.31 16V8.224H8.91V7.24H14.79V8.224H12.39V16H11.31Z" fill="var(--color-text)"></path></g><g id="icon-262144"><rect fill="var(--color-icon-background)" stroke="#FF4D4D" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="12"></rect><path d="M8.85 16L11.13 7.24H12.582L14.85 16H13.758L13.182 13.672H10.53L9.954 16H8.85ZM10.746 12.76H12.954L12.282 10.06C12.154 9.548 12.054 9.12 11.982 8.776C11.91 8.432 11.866 8.208 11.85 8.104C11.834 8.208 11.79 8.432 11.718 8.776C11.646 9.12 11.546 9.544 11.418 10.048L10.746 12.76Z" fill="var(--color-text)"></path></g><g id="icon-524288"><rect fill="var(--color-icon-background)" stroke="#FF4D4D" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="12"></rect><path d="M8.85 16L11.13 7.24H12.582L14.85 16H13.758L13.182 13.672H10.53L9.954 16H8.85ZM10.746 12.76H12.954L12.282 10.06C12.154 9.548 12.054 9.12 11.982 8.776C11.91 8.432 11.866 8.208 11.85 8.104C11.834 8.208 11.79 8.432 11.718 8.776C11.646 9.12 11.546 9.544 11.418 10.048L10.746 12.76Z" fill="var(--color-text)"></path></g><g id="icon-1048576"><rect fill="var(--color-icon-background)" stroke="#FF4D4D" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="12"></rect><path d="M8.85 16L11.13 7.24H12.582L14.85 16H13.758L13.182 13.672H10.53L9.954 16H8.85ZM10.746 12.76H12.954L12.282 10.06C12.154 9.548 12.054 9.12 11.982 8.776C11.91 8.432 11.866 8.208 11.85 8.104C11.834 8.208 11.79 8.432 11.718 8.776C11.646 9.12 11.546 9.544 11.418 10.048L10.746 12.76Z" fill="var(--color-text)"></path></g><g id="icon-2097152"><rect fill="var(--color-icon-background)" stroke="var(--color-ts-type-alias)" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="6"></rect><path d="M11.31 16V8.224H8.91V7.24H14.79V8.224H12.39V16H11.31Z" fill="var(--color-text)"></path></g><g id="icon-4194304"><rect fill="var(--color-icon-background)" stroke="#FF4D82" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="12"></rect><path d="M10.354 17V8.24H13.066C13.586 8.24 14.042 8.348 14.434 8.564C14.826 8.772 15.13 9.064 15.346 9.44C15.562 9.816 15.67 10.256 15.67 10.76C15.67 11.352 15.514 11.86 15.202 12.284C14.898 12.708 14.482 13 13.954 13.16L15.79 17H14.518L12.838 13.28H11.434V17H10.354ZM11.434 12.308H13.066C13.514 12.308 13.874 12.168 14.146 11.888C14.418 11.6 14.554 11.224 14.554 10.76C14.554 10.288 14.418 9.912 14.146 9.632C13.874 9.352 13.514 9.212 13.066 9.212H11.434V12.308Z" fill="var(--color-text)"></path></g><g id="icon-chevronDown"><path d="M4.93896 8.531L12 15.591L19.061 8.531L16.939 6.409L12 11.349L7.06098 6.409L4.93896 8.531Z" fill="var(--color-text)"></path></g><g id="icon-chevronSmall"><path d="M1.5 5.50969L8 11.6609L14.5 5.50969L12.5466 3.66086L8 7.96494L3.45341 3.66086L1.5 5.50969Z" fill="var(--color-text)"></path></g><g id="icon-checkbox"><rect class="tsd-checkbox-background" width="30" height="30" x="1" y="1" rx="6" fill="none"></rect><path class="tsd-checkbox-checkmark" d="M8.35422 16.8214L13.2143 21.75L24.6458 10.25" stroke="none" stroke-width="3.5" stroke-linejoin="round" fill="none"></path></g><g id="icon-menu"><rect x="1" y="3" width="14" height="2" fill="var(--color-text)"></rect><rect x="1" y="7" width="14" height="2" fill="var(--color-text)"></rect><rect x="1" y="11" width="14" height="2" fill="var(--color-text)"></rect></g><g id="icon-search"><path d="M15.7824 13.833L12.6666 10.7177C12.5259 10.5771 12.3353 10.499 12.1353 10.499H11.6259C12.4884 9.39596 13.001 8.00859 13.001 6.49937C13.001 2.90909 10.0914 0 6.50048 0C2.90959 0 0 2.90909 0 6.49937C0 10.0896 2.90959 12.9987 6.50048 12.9987C8.00996 12.9987 9.39756 12.4863 10.5008 11.6239V12.1332C10.5008 12.3332 10.5789 12.5238 10.7195 12.6644L13.8354 15.7797C14.1292 16.0734 14.6042 16.0734 14.8948 15.7797L15.7793 14.8954C16.0731 14.6017 16.0731 14.1267 15.7824 13.833ZM6.50048 10.499C4.29094 10.499 2.50018 8.71165 2.50018 6.49937C2.50018 4.29021 4.28781 2.49976 6.50048 2.49976C8.71001 2.49976 10.5008 4.28708 10.5008 6.49937C10.5008 8.70852 8.71314 10.499 6.50048 10.499Z" fill="var(--color-text)"></path></g><g id="icon-anchor"><g stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round"><path stroke="none" d="M0 0h24v24H0z" fill="none"></path><path d="M10 14a3.5 3.5 0 0 0 5 0l4 -4a3.5 3.5 0 0 0 -5 -5l-.5 .5"></path><path d="M14 10a3.5 3.5 0 0 0 -5 0l-4 4a3.5 3.5 0 0 0 5 5l.5 -.5"></path></g></g></svg></body></html>
|