drugflow-molstar 0.3.77 → 0.3.78
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/drugflow-molstar-0.3.78.css +1 -0
- package/build/drugflow-molstar-component-0.3.77.js +1 -1
- package/build/drugflow-molstar-component-0.3.78.js +25 -0
- package/build/drugflow-molstar-plugin-0.3.77.js +1 -1
- package/build/drugflow-molstar-plugin-0.3.78.js +2 -0
- package/build/drugflow-molstar-plugin-0.3.78.js.LICENSE.txt +39 -0
- package/lib/drugflow-molstar-component-build-0.3.78.js +2 -0
- package/lib/drugflow-molstar-component-build-0.3.78.js.LICENSE.txt +24 -0
- package/lib/index.js +42 -20
- package/package.json +1 -1
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license React
|
|
3
|
+
* react-dom.production.min.js
|
|
4
|
+
*
|
|
5
|
+
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
6
|
+
*
|
|
7
|
+
* This source code is licensed under the MIT license found in the
|
|
8
|
+
* LICENSE file in the root directory of this source tree.
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* @license React
|
|
13
|
+
* react-jsx-runtime.production.min.js
|
|
14
|
+
*
|
|
15
|
+
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
16
|
+
*
|
|
17
|
+
* This source code is licensed under the MIT license found in the
|
|
18
|
+
* LICENSE file in the root directory of this source tree.
|
|
19
|
+
*/
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* @license React
|
|
23
|
+
* react.production.min.js
|
|
24
|
+
*
|
|
25
|
+
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
26
|
+
*
|
|
27
|
+
* This source code is licensed under the MIT license found in the
|
|
28
|
+
* LICENSE file in the root directory of this source tree.
|
|
29
|
+
*/
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* @license React
|
|
33
|
+
* scheduler.production.min.js
|
|
34
|
+
*
|
|
35
|
+
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
36
|
+
*
|
|
37
|
+
* This source code is licensed under the MIT license found in the
|
|
38
|
+
* LICENSE file in the root directory of this source tree.
|
|
39
|
+
*/
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
/*! For license information please see drugflow-molstar-component-build-0.3.78.js.LICENSE.txt */
|
|
2
|
+
(()=>{"use strict";const t="undefined"!=typeof window&&null!=window.customElements&&void 0!==window.customElements.polyfillWrapFlushCallback,e=(t,e,s=null)=>{for(;e!==s;){const s=e.nextSibling;t.removeChild(e),e=s}},s=`{{lit-${String(Math.random()).slice(2)}}}`,i=`\x3c!--${s}--\x3e`,n=new RegExp(`${s}|${i}`),r="$lit$";class o{constructor(t,e){this.parts=[],this.element=e;const i=[],o=[],l=document.createTreeWalker(e.content,133,null,!1);let c=0,p=-1,u=0;const{strings:_,values:{length:m}}=t;for(;u<m;){const t=l.nextNode();if(null!==t){if(p++,1===t.nodeType){if(t.hasAttributes()){const e=t.attributes,{length:s}=e;let i=0;for(let t=0;t<s;t++)a(e[t].name,r)&&i++;for(;i-- >0;){const e=_[u],s=d.exec(e)[2],i=s.toLowerCase()+r,o=t.getAttribute(i);t.removeAttribute(i);const a=o.split(n);this.parts.push({type:"attribute",index:p,name:s,strings:a}),u+=a.length-1}}"TEMPLATE"===t.tagName&&(o.push(t),l.currentNode=t.content)}else if(3===t.nodeType){const e=t.data;if(e.indexOf(s)>=0){const s=t.parentNode,o=e.split(n),l=o.length-1;for(let e=0;e<l;e++){let i,n=o[e];if(""===n)i=h();else{const t=d.exec(n);null!==t&&a(t[2],r)&&(n=n.slice(0,t.index)+t[1]+t[2].slice(0,-r.length)+t[3]),i=document.createTextNode(n)}s.insertBefore(i,t),this.parts.push({type:"node",index:++p})}""===o[l]?(s.insertBefore(h(),t),i.push(t)):t.data=o[l],u+=l}}else if(8===t.nodeType)if(t.data===s){const e=t.parentNode;null!==t.previousSibling&&p!==c||(p++,e.insertBefore(h(),t)),c=p,this.parts.push({type:"node",index:p}),null===t.nextSibling?t.data="":(i.push(t),p--),u++}else{let e=-1;for(;-1!==(e=t.data.indexOf(s,e+1));)this.parts.push({type:"node",index:-1}),u++}}else l.currentNode=o.pop()}for(const t of i)t.parentNode.removeChild(t)}}const a=(t,e)=>{const s=t.length-e.length;return s>=0&&t.slice(s)===e},l=t=>-1!==t.index,h=()=>document.createComment(""),d=/([ \x09\x0a\x0c\x0d])([^\0-\x1F\x7F-\x9F "'>=/]+)([ \x09\x0a\x0c\x0d]*=[ \x09\x0a\x0c\x0d]*(?:[^ \x09\x0a\x0c\x0d"'`<>=]*|"[^"]*|'[^']*))$/;function c(t,e){const{element:{content:s},parts:i}=t,n=document.createTreeWalker(s,133,null,!1);let r=u(i),o=i[r],a=-1,l=0;const h=[];let d=null;for(;n.nextNode();){a++;const t=n.currentNode;for(t.previousSibling===d&&(d=null),e.has(t)&&(h.push(t),null===d&&(d=t)),null!==d&&l++;void 0!==o&&o.index===a;)o.index=null!==d?-1:o.index-l,r=u(i,r),o=i[r]}h.forEach((t=>t.parentNode.removeChild(t)))}const p=t=>{let e=11===t.nodeType?0:1;const s=document.createTreeWalker(t,133,null,!1);for(;s.nextNode();)e++;return e},u=(t,e=-1)=>{for(let s=e+1;s<t.length;s++){const e=t[s];if(l(e))return s}return-1},_=new WeakMap,m=t=>"function"==typeof t&&_.has(t),y={},f={};class g{constructor(t,e,s){this.__parts=[],this.template=t,this.processor=e,this.options=s}update(t){let e=0;for(const s of this.__parts)void 0!==s&&s.setValue(t[e]),e++;for(const t of this.__parts)void 0!==t&&t.commit()}_clone(){const e=t?this.template.element.content.cloneNode(!0):document.importNode(this.template.element.content,!0),s=[],i=this.template.parts,n=document.createTreeWalker(e,133,null,!1);let r,o=0,a=0,h=n.nextNode();for(;o<i.length;)if(r=i[o],l(r)){for(;a<r.index;)a++,"TEMPLATE"===h.nodeName&&(s.push(h),n.currentNode=h.content),null===(h=n.nextNode())&&(n.currentNode=s.pop(),h=n.nextNode());if("node"===r.type){const t=this.processor.handleTextExpression(this.options);t.insertAfterNode(h.previousSibling),this.__parts.push(t)}else this.__parts.push(...this.processor.handleAttributeExpressions(h,r.name,r.strings,this.options));o++}else this.__parts.push(void 0),o++;return t&&(document.adoptNode(e),customElements.upgrade(e)),e}}const S=window.trustedTypes&&trustedTypes.createPolicy("lit-html",{createHTML:t=>t}),v=` ${s} `;const w=t=>null===t||!("object"==typeof t||"function"==typeof t),b=t=>Array.isArray(t)||!(!t||!t[Symbol.iterator]);class x{constructor(t,e,s){this.dirty=!0,this.element=t,this.name=e,this.strings=s,this.parts=[];for(let t=0;t<s.length-1;t++)this.parts[t]=this._createPart()}_createPart(){return new P(this)}_getValue(){const t=this.strings,e=t.length-1,s=this.parts;if(1===e&&""===t[0]&&""===t[1]){const t=s[0].value;if("symbol"==typeof t)return String(t);if("string"==typeof t||!b(t))return t}let i="";for(let n=0;n<e;n++){i+=t[n];const e=s[n];if(void 0!==e){const t=e.value;if(w(t)||!b(t))i+="string"==typeof t?t:String(t);else for(const e of t)i+="string"==typeof e?e:String(e)}}return i+=t[e],i}commit(){this.dirty&&(this.dirty=!1,this.element.setAttribute(this.name,this._getValue()))}}class P{constructor(t){this.value=void 0,this.committer=t}setValue(t){t===y||w(t)&&t===this.value||(this.value=t,m(t)||(this.committer.dirty=!0))}commit(){for(;m(this.value);){const t=this.value;this.value=y,t(this)}this.value!==y&&this.committer.commit()}}class N{constructor(t){this.value=void 0,this.__pendingValue=void 0,this.options=t}appendInto(t){this.startNode=t.appendChild(h()),this.endNode=t.appendChild(h())}insertAfterNode(t){this.startNode=t,this.endNode=t.nextSibling}appendIntoPart(t){t.__insert(this.startNode=h()),t.__insert(this.endNode=h())}insertAfterPart(t){t.__insert(this.startNode=h()),this.endNode=t.endNode,t.endNode=this.startNode}setValue(t){this.__pendingValue=t}commit(){if(null===this.startNode.parentNode)return;for(;m(this.__pendingValue);){const t=this.__pendingValue;this.__pendingValue=y,t(this)}const t=this.__pendingValue;t!==y&&(w(t)?t!==this.value&&this.__commitText(t):t instanceof class{constructor(t,e,s,i){this.strings=t,this.values=e,this.type=s,this.processor=i}getHTML(){const t=this.strings.length-1;let e="",n=!1;for(let o=0;o<t;o++){const t=this.strings[o],a=t.lastIndexOf("\x3c!--");n=(a>-1||n)&&-1===t.indexOf("--\x3e",a+1);const l=d.exec(t);e+=null===l?t+(n?v:i):t.substr(0,l.index)+l[1]+l[2]+r+l[3]+s}return e+=this.strings[t],e}getTemplateElement(){const t=document.createElement("template");let e=this.getHTML();return void 0!==S&&(e=S.createHTML(e)),t.innerHTML=e,t}}?this.__commitTemplateResult(t):t instanceof Node?this.__commitNode(t):b(t)?this.__commitIterable(t):t===f?(this.value=f,this.clear()):this.__commitText(t))}__insert(t){this.endNode.parentNode.insertBefore(t,this.endNode)}__commitNode(t){this.value!==t&&(this.clear(),this.__insert(t),this.value=t)}__commitText(t){const e=this.startNode.nextSibling,s="string"==typeof(t=null==t?"":t)?t:String(t);e===this.endNode.previousSibling&&3===e.nodeType?e.data=s:this.__commitNode(document.createTextNode(s)),this.value=t}__commitTemplateResult(t){const e=this.options.templateFactory(t);if(this.value instanceof g&&this.value.template===e)this.value.update(t.values);else{const s=new g(e,t.processor,this.options),i=s._clone();s.update(t.values),this.__commitNode(i),this.value=s}}__commitIterable(t){Array.isArray(this.value)||(this.value=[],this.clear());const e=this.value;let s,i=0;for(const n of t)s=e[i],void 0===s&&(s=new N(this.options),e.push(s),0===i?s.appendIntoPart(this):s.insertAfterPart(e[i-1])),s.setValue(n),s.commit(),i++;i<e.length&&(e.length=i,this.clear(s&&s.endNode))}clear(t=this.startNode){e(this.startNode.parentNode,t.nextSibling,this.endNode)}}class C{constructor(t,e,s){if(this.value=void 0,this.__pendingValue=void 0,2!==s.length||""!==s[0]||""!==s[1])throw new Error("Boolean attributes can only contain a single expression");this.element=t,this.name=e,this.strings=s}setValue(t){this.__pendingValue=t}commit(){for(;m(this.__pendingValue);){const t=this.__pendingValue;this.__pendingValue=y,t(this)}if(this.__pendingValue===y)return;const t=!!this.__pendingValue;this.value!==t&&(t?this.element.setAttribute(this.name,""):this.element.removeAttribute(this.name),this.value=t),this.__pendingValue=y}}class T extends x{constructor(t,e,s){super(t,e,s),this.single=2===s.length&&""===s[0]&&""===s[1]}_createPart(){return new A(this)}_getValue(){return this.single?this.parts[0].value:super._getValue()}commit(){this.dirty&&(this.dirty=!1,this.element[this.name]=this._getValue())}}class A extends P{}let E=!1;(()=>{try{const t={get capture(){return E=!0,!1}};window.addEventListener("test",t,t),window.removeEventListener("test",t,t)}catch(t){}})();class V{constructor(t,e,s){this.value=void 0,this.__pendingValue=void 0,this.element=t,this.eventName=e,this.eventContext=s,this.__boundHandleEvent=t=>this.handleEvent(t)}setValue(t){this.__pendingValue=t}commit(){for(;m(this.__pendingValue);){const t=this.__pendingValue;this.__pendingValue=y,t(this)}if(this.__pendingValue===y)return;const t=this.__pendingValue,e=this.value,s=null==t||null!=e&&(t.capture!==e.capture||t.once!==e.once||t.passive!==e.passive),i=null!=t&&(null==e||s);s&&this.element.removeEventListener(this.eventName,this.__boundHandleEvent,this.__options),i&&(this.__options=U(t),this.element.addEventListener(this.eventName,this.__boundHandleEvent,this.__options)),this.value=t,this.__pendingValue=y}handleEvent(t){"function"==typeof this.value?this.value.call(this.eventContext||this.element,t):this.value.handleEvent(t)}}const U=t=>t&&(E?{capture:t.capture,passive:t.passive,once:t.once}:t.capture);function O(t){let e=R.get(t.type);void 0===e&&(e={stringsArray:new WeakMap,keyString:new Map},R.set(t.type,e));let i=e.stringsArray.get(t.strings);if(void 0!==i)return i;const n=t.strings.join(s);return i=e.keyString.get(n),void 0===i&&(i=new o(t,t.getTemplateElement()),e.keyString.set(n,i)),e.stringsArray.set(t.strings,i),i}const R=new Map,k=new WeakMap;new class{handleAttributeExpressions(t,e,s,i){const n=e[0];return"."===n?new T(t,e.slice(1),s).parts:"@"===n?[new V(t,e.slice(1),i.eventContext)]:"?"===n?[new C(t,e.slice(1),s)]:new x(t,e,s).parts}handleTextExpression(t){return new N(t)}},"undefined"!=typeof window&&(window.litHtmlVersions||(window.litHtmlVersions=[])).push("1.4.1");const M=(t,e)=>`${t}--${e}`;let q=!0;void 0===window.ShadyCSS?q=!1:void 0===window.ShadyCSS.prepareTemplateDom&&(console.warn("Incompatible ShadyCSS version detected. Please update to at least @webcomponents/webcomponentsjs@2.0.2 and @webcomponents/shadycss@1.3.1."),q=!1);const I=t=>e=>{const i=M(e.type,t);let n=R.get(i);void 0===n&&(n={stringsArray:new WeakMap,keyString:new Map},R.set(i,n));let r=n.stringsArray.get(e.strings);if(void 0!==r)return r;const a=e.strings.join(s);if(r=n.keyString.get(a),void 0===r){const s=e.getTemplateElement();q&&window.ShadyCSS.prepareTemplateDom(s,t),r=new o(e,s),n.keyString.set(a,r)}return n.stringsArray.set(e.strings,r),r},j=["html","svg"],L=new Set;window.JSCompiler_renameProperty=(t,e)=>t;const F={toAttribute(t,e){switch(e){case Boolean:return t?"":null;case Object:case Array:return null==t?t:JSON.stringify(t)}return t},fromAttribute(t,e){switch(e){case Boolean:return null!==t;case Number:return null===t?null:Number(t);case Object:case Array:return JSON.parse(t)}return t}},H=(t,e)=>e!==t&&(e==e||t==t),z={attribute:!0,type:String,converter:F,reflect:!1,hasChanged:H};class B extends HTMLElement{constructor(){super(),this.initialize()}static get observedAttributes(){this.finalize();const t=[];return this._classProperties.forEach(((e,s)=>{const i=this._attributeNameForProperty(s,e);void 0!==i&&(this._attributeToPropertyMap.set(i,s),t.push(i))})),t}static _ensureClassProperties(){if(!this.hasOwnProperty(JSCompiler_renameProperty("_classProperties",this))){this._classProperties=new Map;const t=Object.getPrototypeOf(this)._classProperties;void 0!==t&&t.forEach(((t,e)=>this._classProperties.set(e,t)))}}static createProperty(t,e=z){if(this._ensureClassProperties(),this._classProperties.set(t,e),e.noAccessor||this.prototype.hasOwnProperty(t))return;const s="symbol"==typeof t?Symbol():`__${t}`,i=this.getPropertyDescriptor(t,s,e);void 0!==i&&Object.defineProperty(this.prototype,t,i)}static getPropertyDescriptor(t,e,s){return{get(){return this[e]},set(i){const n=this[t];this[e]=i,this.requestUpdateInternal(t,n,s)},configurable:!0,enumerable:!0}}static getPropertyOptions(t){return this._classProperties&&this._classProperties.get(t)||z}static finalize(){const t=Object.getPrototypeOf(this);if(t.hasOwnProperty("finalized")||t.finalize(),this.finalized=!0,this._ensureClassProperties(),this._attributeToPropertyMap=new Map,this.hasOwnProperty(JSCompiler_renameProperty("properties",this))){const t=this.properties,e=[...Object.getOwnPropertyNames(t),..."function"==typeof Object.getOwnPropertySymbols?Object.getOwnPropertySymbols(t):[]];for(const s of e)this.createProperty(s,t[s])}}static _attributeNameForProperty(t,e){const s=e.attribute;return!1===s?void 0:"string"==typeof s?s:"string"==typeof t?t.toLowerCase():void 0}static _valueHasChanged(t,e,s=H){return s(t,e)}static _propertyValueFromAttribute(t,e){const s=e.type,i=e.converter||F,n="function"==typeof i?i:i.fromAttribute;return n?n(t,s):t}static _propertyValueToAttribute(t,e){if(void 0===e.reflect)return;const s=e.type,i=e.converter;return(i&&i.toAttribute||F.toAttribute)(t,s)}initialize(){this._updateState=0,this._updatePromise=new Promise((t=>this._enableUpdatingResolver=t)),this._changedProperties=new Map,this._saveInstanceProperties(),this.requestUpdateInternal()}_saveInstanceProperties(){this.constructor._classProperties.forEach(((t,e)=>{if(this.hasOwnProperty(e)){const t=this[e];delete this[e],this._instanceProperties||(this._instanceProperties=new Map),this._instanceProperties.set(e,t)}}))}_applyInstanceProperties(){this._instanceProperties.forEach(((t,e)=>this[e]=t)),this._instanceProperties=void 0}connectedCallback(){this.enableUpdating()}enableUpdating(){void 0!==this._enableUpdatingResolver&&(this._enableUpdatingResolver(),this._enableUpdatingResolver=void 0)}disconnectedCallback(){}attributeChangedCallback(t,e,s){e!==s&&this._attributeToProperty(t,s)}_propertyToAttribute(t,e,s=z){const i=this.constructor,n=i._attributeNameForProperty(t,s);if(void 0!==n){const t=i._propertyValueToAttribute(e,s);if(void 0===t)return;this._updateState=8|this._updateState,null==t?this.removeAttribute(n):this.setAttribute(n,t),this._updateState=-9&this._updateState}}_attributeToProperty(t,e){if(8&this._updateState)return;const s=this.constructor,i=s._attributeToPropertyMap.get(t);if(void 0!==i){const t=s.getPropertyOptions(i);this._updateState=16|this._updateState,this[i]=s._propertyValueFromAttribute(e,t),this._updateState=-17&this._updateState}}requestUpdateInternal(t,e,s){let i=!0;if(void 0!==t){const n=this.constructor;s=s||n.getPropertyOptions(t),n._valueHasChanged(this[t],e,s.hasChanged)?(this._changedProperties.has(t)||this._changedProperties.set(t,e),!0!==s.reflect||16&this._updateState||(void 0===this._reflectingProperties&&(this._reflectingProperties=new Map),this._reflectingProperties.set(t,s))):i=!1}!this._hasRequestedUpdate&&i&&(this._updatePromise=this._enqueueUpdate())}requestUpdate(t,e){return this.requestUpdateInternal(t,e),this.updateComplete}async _enqueueUpdate(){this._updateState=4|this._updateState;try{await this._updatePromise}catch(t){}const t=this.performUpdate();return null!=t&&await t,!this._hasRequestedUpdate}get _hasRequestedUpdate(){return 4&this._updateState}get hasUpdated(){return 1&this._updateState}performUpdate(){if(!this._hasRequestedUpdate)return;this._instanceProperties&&this._applyInstanceProperties();let t=!1;const e=this._changedProperties;try{t=this.shouldUpdate(e),t?this.update(e):this._markUpdated()}catch(e){throw t=!1,this._markUpdated(),e}t&&(1&this._updateState||(this._updateState=1|this._updateState,this.firstUpdated(e)),this.updated(e))}_markUpdated(){this._changedProperties=new Map,this._updateState=-5&this._updateState}get updateComplete(){return this._getUpdateComplete()}_getUpdateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._updatePromise}shouldUpdate(t){return!0}update(t){void 0!==this._reflectingProperties&&this._reflectingProperties.size>0&&(this._reflectingProperties.forEach(((t,e)=>this._propertyToAttribute(e,this[e],t))),this._reflectingProperties=void 0),this._markUpdated()}updated(t){}firstUpdated(t){}}B.finalized=!0;const $=Element.prototype;$.msMatchesSelector||$.webkitMatchesSelector;const W=window.ShadowRoot&&(void 0===window.ShadyCSS||window.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,D=Symbol();class J{constructor(t,e){if(e!==D)throw new Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");this.cssText=t}get styleSheet(){return void 0===this._styleSheet&&(W?(this._styleSheet=new CSSStyleSheet,this._styleSheet.replaceSync(this.cssText)):this._styleSheet=null),this._styleSheet}toString(){return this.cssText}}(window.litElementVersions||(window.litElementVersions=[])).push("2.5.1");const G={};class K extends B{static getStyles(){return this.styles}static _getUniqueStyles(){if(this.hasOwnProperty(JSCompiler_renameProperty("_styles",this)))return;const t=this.getStyles();if(Array.isArray(t)){const e=(t,s)=>t.reduceRight(((t,s)=>Array.isArray(s)?e(s,t):(t.add(s),t)),s),s=e(t,new Set),i=[];s.forEach((t=>i.unshift(t))),this._styles=i}else this._styles=void 0===t?[]:[t];this._styles=this._styles.map((t=>{if(t instanceof CSSStyleSheet&&!W){const e=Array.prototype.slice.call(t.cssRules).reduce(((t,e)=>t+e.cssText),"");return new J(String(e),D)}return t}))}initialize(){super.initialize(),this.constructor._getUniqueStyles(),this.renderRoot=this.createRenderRoot(),window.ShadowRoot&&this.renderRoot instanceof window.ShadowRoot&&this.adoptStyles()}createRenderRoot(){return this.attachShadow(this.constructor.shadowRootOptions)}adoptStyles(){const t=this.constructor._styles;0!==t.length&&(void 0===window.ShadyCSS||window.ShadyCSS.nativeShadow?W?this.renderRoot.adoptedStyleSheets=t.map((t=>t instanceof CSSStyleSheet?t:t.styleSheet)):this._needsShimAdoptedStyleSheets=!0:window.ShadyCSS.ScopingShim.prepareAdoptedCssText(t.map((t=>t.cssText)),this.localName))}connectedCallback(){super.connectedCallback(),this.hasUpdated&&void 0!==window.ShadyCSS&&window.ShadyCSS.styleElement(this)}update(t){const e=this.render();super.update(t),e!==G&&this.constructor.render(e,this.renderRoot,{scopeName:this.localName,eventContext:this}),this._needsShimAdoptedStyleSheets&&(this._needsShimAdoptedStyleSheets=!1,this.constructor._styles.forEach((t=>{const e=document.createElement("style");e.textContent=t.cssText,this.renderRoot.appendChild(e)})))}render(){return G}}K.finalized=!0,K.render=(t,s,i)=>{if(!i||"object"!=typeof i||!i.scopeName)throw new Error("The `scopeName` option is required.");const n=i.scopeName,r=k.has(s),o=q&&11===s.nodeType&&!!s.host,a=o&&!L.has(n),l=a?document.createDocumentFragment():s;if(((t,s,i)=>{let n=k.get(s);void 0===n&&(e(s,s.firstChild),k.set(s,n=new N(Object.assign({templateFactory:O},i))),n.appendInto(s)),n.setValue(t),n.commit()})(t,l,Object.assign({templateFactory:I(n)},i)),a){const t=k.get(l);k.delete(l);((t,e,s)=>{L.add(t);const i=s?s.element:document.createElement("template"),n=e.querySelectorAll("style"),{length:r}=n;if(0===r)return void window.ShadyCSS.prepareTemplateStyles(i,t);const o=document.createElement("style");for(let t=0;t<r;t++){const e=n[t];e.parentNode.removeChild(e),o.textContent+=e.textContent}(t=>{j.forEach((e=>{const s=R.get(M(e,t));void 0!==s&&s.keyString.forEach((t=>{const{element:{content:e}}=t,s=new Set;Array.from(e.querySelectorAll("style")).forEach((t=>{s.add(t)})),c(t,s)}))}))})(t);const a=i.content;s?function(t,e,s=null){const{element:{content:i},parts:n}=t;if(null==s)return void i.appendChild(e);const r=document.createTreeWalker(i,133,null,!1);let o=u(n),a=0,l=-1;for(;r.nextNode();)for(l++,r.currentNode===s&&(a=p(e),s.parentNode.insertBefore(e,s));-1!==o&&n[o].index===l;){if(a>0){for(;-1!==o;)n[o].index+=a,o=u(n,o);return}o=u(n,o)}}(s,o,a.firstChild):a.insertBefore(o,a.firstChild),window.ShadyCSS.prepareTemplateStyles(i,t);const l=a.querySelector("style");if(window.ShadyCSS.nativeShadow&&null!==l)e.insertBefore(l.cloneNode(!0),e.firstChild);else if(s){a.insertBefore(o,a.firstChild);const t=new Set;t.add(o),c(s,t)}})(n,l,t.value instanceof g?t.value.template:void 0),e(s,s.firstChild),s.appendChild(l),k.set(s,t)}!r&&o&&window.ShadyCSS.styleElement(s.host)},K.shadowRootOptions={mode:"open"}})();
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright (c) 2017 The Polymer Project Authors. All rights reserved.
|
|
4
|
+
* This code may only be used under the BSD style license found at
|
|
5
|
+
* http://polymer.github.io/LICENSE.txt
|
|
6
|
+
* The complete set of authors may be found at
|
|
7
|
+
* http://polymer.github.io/AUTHORS.txt
|
|
8
|
+
* The complete set of contributors may be found at
|
|
9
|
+
* http://polymer.github.io/CONTRIBUTORS.txt
|
|
10
|
+
* Code distributed by Google as part of the polymer project is also
|
|
11
|
+
* subject to an additional IP rights grant found at
|
|
12
|
+
* http://polymer.github.io/PATENTS.txt
|
|
13
|
+
*/
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
@license
|
|
17
|
+
Copyright (c) 2019 The Polymer Project Authors. All rights reserved.
|
|
18
|
+
This code may only be used under the BSD style license found at
|
|
19
|
+
http://polymer.github.io/LICENSE.txt The complete set of authors may be found at
|
|
20
|
+
http://polymer.github.io/AUTHORS.txt The complete set of contributors may be
|
|
21
|
+
found at http://polymer.github.io/CONTRIBUTORS.txt Code distributed by Google as
|
|
22
|
+
part of the polymer project is also subject to an additional IP rights grant
|
|
23
|
+
found at http://polymer.github.io/PATENTS.txt
|
|
24
|
+
*/
|
package/lib/index.js
CHANGED
|
@@ -2799,24 +2799,25 @@ var DrugflowMolstarPlugin = /** @class */ (function () {
|
|
|
2799
2799
|
* ```
|
|
2800
2800
|
*/
|
|
2801
2801
|
DrugflowMolstarPlugin.prototype.exportInteractionsData = function (componentRef, structureId, filterResId) {
|
|
2802
|
+
var _b, _c;
|
|
2802
2803
|
if (structureId === void 0) { structureId = '0'; }
|
|
2803
2804
|
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
2804
|
-
var InteractionsProvider, interactionTypeLabel, Vec3, fullComponentRef, componentCell, fallbackCell, actualCell, componentStructure_1, interactionsProperty_1, interactions, exportedData, addedInteractions, contacts, unitsFeatures, i, edge, unitA, unitB, featuresA, featuresB, atomInfoA, atomInfoB, interactionType, atom1Key, atom2Key,
|
|
2805
|
+
var InteractionsProvider, interactionTypeLabel, Vec3, fullComponentRef, componentCell, fallbackCell, actualCell, componentStructure_1, interactionsProperty_1, interactions, exportedData, addedInteractions, unitElementToMolIndex, molAtomCount, _d, _e, unit, elements, indexMap, i, contacts, unitsFeatures, i, edge, unitA, unitB, featuresA, featuresB, atomInfoA, atomInfoB, interactionType, atom1Key, atom2Key, _f, key1, key2, uniqueKey, posA, posB, distance, molIndexA, molIndexB, filterMsg, error_7;
|
|
2805
2806
|
var _this = this;
|
|
2806
|
-
return tslib_1.__generator(this, function (
|
|
2807
|
-
switch (
|
|
2807
|
+
return tslib_1.__generator(this, function (_g) {
|
|
2808
|
+
switch (_g.label) {
|
|
2808
2809
|
case 0: return [4 /*yield*/, Promise.resolve().then(function () { return tslib_1.__importStar(require('molstar/lib/mol-model-props/computed/interactions')); })];
|
|
2809
2810
|
case 1:
|
|
2810
|
-
InteractionsProvider = (
|
|
2811
|
+
InteractionsProvider = (_g.sent()).InteractionsProvider;
|
|
2811
2812
|
return [4 /*yield*/, Promise.resolve().then(function () { return tslib_1.__importStar(require('molstar/lib/mol-model-props/computed/interactions/common')); })];
|
|
2812
2813
|
case 2:
|
|
2813
|
-
interactionTypeLabel = (
|
|
2814
|
+
interactionTypeLabel = (_g.sent()).interactionTypeLabel;
|
|
2814
2815
|
return [4 /*yield*/, Promise.resolve().then(function () { return tslib_1.__importStar(require('molstar/lib/mol-math/linear-algebra')); })];
|
|
2815
2816
|
case 3:
|
|
2816
|
-
Vec3 = (
|
|
2817
|
-
|
|
2817
|
+
Vec3 = (_g.sent()).Vec3;
|
|
2818
|
+
_g.label = 4;
|
|
2818
2819
|
case 4:
|
|
2819
|
-
|
|
2820
|
+
_g.trys.push([4, 7, , 8]);
|
|
2820
2821
|
fullComponentRef = componentRef.includes('_') ? componentRef : "".concat(componentRef, "_").concat(structureId);
|
|
2821
2822
|
componentCell = this.plugin.state.data.select(fullComponentRef)[0];
|
|
2822
2823
|
if (!componentCell) {
|
|
@@ -2861,8 +2862,8 @@ var DrugflowMolstarPlugin = /** @class */ (function () {
|
|
|
2861
2862
|
});
|
|
2862
2863
|
}); }))];
|
|
2863
2864
|
case 5:
|
|
2864
|
-
|
|
2865
|
-
|
|
2865
|
+
_g.sent();
|
|
2866
|
+
_g.label = 6;
|
|
2866
2867
|
case 6:
|
|
2867
2868
|
if (!interactionsProperty_1 || !interactionsProperty_1.value) {
|
|
2868
2869
|
console.log('No interactions data found after computation. Make sure you have added interactions representation first.');
|
|
@@ -2871,6 +2872,20 @@ var DrugflowMolstarPlugin = /** @class */ (function () {
|
|
|
2871
2872
|
interactions = interactionsProperty_1.value;
|
|
2872
2873
|
exportedData = [];
|
|
2873
2874
|
addedInteractions = new Set();
|
|
2875
|
+
unitElementToMolIndex = new Map();
|
|
2876
|
+
molAtomCount = 0;
|
|
2877
|
+
for (_d = 0, _e = componentStructure_1.units; _d < _e.length; _d++) {
|
|
2878
|
+
unit = _e[_d];
|
|
2879
|
+
if (unit.kind !== 0)
|
|
2880
|
+
continue; // 只处理原子单元
|
|
2881
|
+
elements = unit.elements;
|
|
2882
|
+
indexMap = new Map();
|
|
2883
|
+
for (i = 0; i < elements.length; i++) {
|
|
2884
|
+
molAtomCount++;
|
|
2885
|
+
indexMap.set(i, molAtomCount); // 索引 -> MOL序号(1-based)
|
|
2886
|
+
}
|
|
2887
|
+
unitElementToMolIndex.set(unit.id, indexMap);
|
|
2888
|
+
}
|
|
2874
2889
|
contacts = interactions.contacts;
|
|
2875
2890
|
unitsFeatures = interactions.unitsFeatures;
|
|
2876
2891
|
for (i = 0; i < contacts.edgeCount; i++) {
|
|
@@ -2894,7 +2909,7 @@ var DrugflowMolstarPlugin = /** @class */ (function () {
|
|
|
2894
2909
|
interactionType = interactionTypeLabel(edge.props.type);
|
|
2895
2910
|
atom1Key = "".concat(atomInfoA.chainId, ":").concat(atomInfoA.resId, ":").concat(atomInfoA.atomName);
|
|
2896
2911
|
atom2Key = "".concat(atomInfoB.chainId, ":").concat(atomInfoB.resId, ":").concat(atomInfoB.atomName);
|
|
2897
|
-
|
|
2912
|
+
_f = atom1Key < atom2Key ? [atom1Key, atom2Key] : [atom2Key, atom1Key], key1 = _f[0], key2 = _f[1];
|
|
2898
2913
|
uniqueKey = "".concat(interactionType, "|").concat(key1, "|").concat(key2);
|
|
2899
2914
|
// 跳过重复的相互作用
|
|
2900
2915
|
if (addedInteractions.has(uniqueKey)) {
|
|
@@ -2904,10 +2919,14 @@ var DrugflowMolstarPlugin = /** @class */ (function () {
|
|
|
2904
2919
|
posA = Vec3.create(featuresA.x[edge.indexA], featuresA.y[edge.indexA], featuresA.z[edge.indexA]);
|
|
2905
2920
|
posB = Vec3.create(featuresB.x[edge.indexB], featuresB.y[edge.indexB], featuresB.z[edge.indexB]);
|
|
2906
2921
|
distance = Vec3.distance(posA, posB);
|
|
2922
|
+
molIndexA = ((_b = unitElementToMolIndex.get(edge.unitA)) === null || _b === void 0 ? void 0 : _b.get(atomInfoA.elementIndex)) || -1;
|
|
2923
|
+
molIndexB = ((_c = unitElementToMolIndex.get(edge.unitB)) === null || _c === void 0 ? void 0 : _c.get(atomInfoB.elementIndex)) || -1;
|
|
2907
2924
|
exportedData.push({
|
|
2908
2925
|
type: interactionType,
|
|
2909
|
-
atomA: atomInfoA,
|
|
2910
|
-
|
|
2926
|
+
atomA: tslib_1.__assign(tslib_1.__assign({}, atomInfoA), { molIndex: molIndexA // 添加:MOL/SDF文件中的原子序号(1-based)
|
|
2927
|
+
}),
|
|
2928
|
+
atomB: tslib_1.__assign(tslib_1.__assign({}, atomInfoB), { molIndex: molIndexB // 添加:MOL/SDF文件中的原子序号(1-based)
|
|
2929
|
+
}),
|
|
2911
2930
|
distance: Math.round(distance * 100) / 100,
|
|
2912
2931
|
// 额外的原始数据
|
|
2913
2932
|
_raw: {
|
|
@@ -2923,7 +2942,7 @@ var DrugflowMolstarPlugin = /** @class */ (function () {
|
|
|
2923
2942
|
console.log("\u2705 Exported ".concat(exportedData.length, " unique interactions from ").concat(fullComponentRef).concat(filterMsg));
|
|
2924
2943
|
return [2 /*return*/, exportedData];
|
|
2925
2944
|
case 7:
|
|
2926
|
-
error_7 =
|
|
2945
|
+
error_7 = _g.sent();
|
|
2927
2946
|
console.error('❌ Failed to export interactions data:', error_7);
|
|
2928
2947
|
throw error_7;
|
|
2929
2948
|
case 8: return [2 /*return*/];
|
|
@@ -2958,7 +2977,8 @@ var DrugflowMolstarPlugin = /** @class */ (function () {
|
|
|
2958
2977
|
resId: 0,
|
|
2959
2978
|
resName: 'UNK',
|
|
2960
2979
|
atomName: 'unknown',
|
|
2961
|
-
atomId: null
|
|
2980
|
+
atomId: null,
|
|
2981
|
+
elementIndex: -1
|
|
2962
2982
|
};
|
|
2963
2983
|
}
|
|
2964
2984
|
try {
|
|
@@ -2969,17 +2989,17 @@ var DrugflowMolstarPlugin = /** @class */ (function () {
|
|
|
2969
2989
|
var offset = features.offsets[featureIndex];
|
|
2970
2990
|
if (offset === undefined) {
|
|
2971
2991
|
console.log('Feature offset undefined for index:', featureIndex);
|
|
2972
|
-
return { chainId: 'unknown', resId: 0, resName: 'UNK', atomName: 'unknown', atomId: null };
|
|
2992
|
+
return { chainId: 'unknown', resId: 0, resName: 'UNK', atomName: 'unknown', atomId: null, elementIndex: -1 };
|
|
2973
2993
|
}
|
|
2974
2994
|
var elementIndex = features.members[offset];
|
|
2975
2995
|
if (elementIndex === undefined || elementIndex < 0) {
|
|
2976
2996
|
console.log('Element index undefined for offset:', offset);
|
|
2977
|
-
return { chainId: 'unknown', resId: 0, resName: 'UNK', atomName: 'unknown', atomId: null };
|
|
2997
|
+
return { chainId: 'unknown', resId: 0, resName: 'UNK', atomName: 'unknown', atomId: null, elementIndex: -1 };
|
|
2978
2998
|
}
|
|
2979
2999
|
// 检查索引是否在有效范围内
|
|
2980
3000
|
if (elementIndex >= unit.elements.length) {
|
|
2981
3001
|
console.log('Element index out of range:', elementIndex, 'max:', unit.elements.length);
|
|
2982
|
-
return { chainId: 'unknown', resId: 0, resName: 'UNK', atomName: 'unknown', atomId: null };
|
|
3002
|
+
return { chainId: 'unknown', resId: 0, resName: 'UNK', atomName: 'unknown', atomId: null, elementIndex: -1 };
|
|
2983
3003
|
}
|
|
2984
3004
|
// 创建 Location 对象(必须传入 structure)
|
|
2985
3005
|
var location_2 = structure_2.StructureElement.Location.create(structure, unit);
|
|
@@ -2997,7 +3017,8 @@ var DrugflowMolstarPlugin = /** @class */ (function () {
|
|
|
2997
3017
|
resId: resId,
|
|
2998
3018
|
resName: resName,
|
|
2999
3019
|
atomName: atomName,
|
|
3000
|
-
atomId: atomId
|
|
3020
|
+
atomId: atomId,
|
|
3021
|
+
elementIndex: elementIndex // 添加:原子在unit.elements中的索引
|
|
3001
3022
|
};
|
|
3002
3023
|
}
|
|
3003
3024
|
catch (error) {
|
|
@@ -3007,7 +3028,8 @@ var DrugflowMolstarPlugin = /** @class */ (function () {
|
|
|
3007
3028
|
resId: 0,
|
|
3008
3029
|
resName: 'UNK',
|
|
3009
3030
|
atomName: 'unknown',
|
|
3010
|
-
atomId: null
|
|
3031
|
+
atomId: null,
|
|
3032
|
+
elementIndex: -1
|
|
3011
3033
|
};
|
|
3012
3034
|
}
|
|
3013
3035
|
};
|