-
Notifications
You must be signed in to change notification settings - Fork 1.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
TypeScript Definition for Cytoscape.js - It is being worked on now! #1012
Comments
I'm in the process of completing the work of Fabian-Schmidt. I'll try to get everything upstream by the end of August, but the process of branching and merging is still new to me, so a delay is possible. In the meantime, feel free to bug me for the latest version. Regards, KB5000 |
If it helps: In the discussion at: DefinitelyTyped/DefinitelyTyped#4763 Between that and this project: Can you get the JSON spec to generate the d.ts definition file? |
Would you mind it I made this a typed-typings? |
What is your typed-typings? A curated list of typed definitions? Date: Thu, 23 Jun 2016 11:18:21 -0700 Would you mind it I made this a typed-typings? https://github.com/typed-typings — |
Whatever way Typescript definitions are published, it would be great if it could be automated on the Cytoscape.js side so that they're automatically kept up to date. The I'm not an expert an TS or TS defs, so it would be great if someone wanted to make a PR to do this. Thanks |
Typed-Typings is similar to DefinitelyTyped except rather than having all the typing definition files in a single git repository they can be placed in a number of places. |
okay, great. Sure, do what you got to do regarding cytoscape.js Date: Fri, 24 Jun 2016 10:51:49 -0700 Typed-Typings is similar to DefinitelyTyped except rather than having all the typing definition files in a single git repository they can be placed in a number of places. This also allows for a registry for different versions of the typings. — |
Okay sounds great but I have nothing to do with the cytoscape.js project! I have just expressed a desire to have TS defs for it. Date: Fri, 24 Jun 2016 08:10:20 -0700 Whatever way Typescript definitions are published, it would be great if it could be automated on the Cytoscape.js side so that they're automatically kept up to date. The docmaker.js file generates the HTML version of the docs from docmaker.json. It would be great if docmaker.js could be refashioned into a tsdefmaker.js file to output a .d.ts file. That way, everything could be automated with each release. I'm not an expert an TS or TS defs, so it would be great if someone wanted to make a PR to do this. Thanks — |
@phreed Are you still going to publish the typings? fyi I'm successfully using them in my project, so far so good. Also I've made some significant improvements to them in the Styles/CSS part. |
Pretty soon. |
@phreed Would you mind to share me your typed-typings? I am using cytoscape in an angular2 based projects. Thanks |
Is there some news about cytoscape typing? |
I am continuing to work on them.
and then |
@phreed very thanks for it! |
Why not PR your work-in-progress to the Typescript Definitions repository DefinitelyTyped so others can help you polish it up? |
After #1012 (comment), |
Unless the process of creating ts defs can be completely automated through the existing docs build, then they won't be maintained in the official repo. It would be great if someone would create a community npm package. Maybe @phreed would like to publish https://github.com/phreed/ts-typings/tree/cytoscape to npm, or maybe someone could create a new Github repo based on @phreed's work that could centralise community ts defs for Cytoscape. |
The .d.ts file would have to get updated on interface changes. The alternative would be to actually use TypeScript in this library, which would provide a variety of benefits (type safety => less bugs). In that case .d.ts files would get generated automatically. The official distribution channel for community typings is through DefinitelyTyped (which gets published to |
@phreed's defs are for Typed-Typings rather than DefinitelyTyped. I don't think it's likely that Cytoscape will be rewritten in TS. If the community wants to maintain a separate defs package to support TS users, that's great and we'd be glad to link to it! |
Afaik there are no typings yet for version 3.0.0? :( |
My plan in May is to update to @types and v3. Alternatively I am
considering a Typescript wrapper.
…On Thu, Apr 27, 2017, 04:04 Tom Muylle ***@***.***> wrote:
Afaik there are no typings yet for version 3.0.0? :(
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#1012 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AAM6vB0CbRCGo0KSF0D6n3camv2qAMhPks5r0FougaJpZM4FZKD3>
.
|
@phreed how's it going? Any update? |
This is where things are now |
I have a draft version for the v3 api. |
I believe what you mention was a change from v2.x to v3.x
I have been working on the typings for v3.x here...
https://github.com/phreed/ts-typings/blob/cytoscape3/index.d.ts
I have completed a pass through the latest documentation...
http://js.cytoscape.org/
...but there are probably (certainly) errors.
I am working though the tests based on the examples in that document now
and would welcome any help.
My plan is to release this work as part of DefinitelyTyped...
https://github.com/phreed/DefinitelyTyped
Thanks
…On Wed, May 17, 2017 at 11:15 AM WaynePlummer ***@***.***> wrote:
Should this:
interface Stylesheet {
selector: string;
css: Css.Node | Css.Edge;
}
actually read:
interface Stylesheet {
selector: string;
style: Css.Node | Css.Edge;
}
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#1012 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AAM6vASI5uXqxd9UEy1I8ay2VImpxUanks5r6x0ugaJpZM4FZKD3>
.
|
Either works in 2.x or 3.2, but |
Yes, I deleted my original post once I realised that this must be what was going on... but thanks, @phreed and @maxkfranz both for confirming :) |
The existing tools to convert JSDoc to TypeScript definitions are all oriented to serve as a starting point for writing definitions, not continuously automating their generation. That is because the TypeScript type system is way more expressive to describe JavaScript APIs than JSDoc. |
We don't even have this yet in the lib. There's a hand-rolled docs generator script from a json spec.
Ideally we could use formal jsdoc comments throughout (at least) the public-facing api to generate the docs, ts defs, and flow defs. This would be a good, longterm option. The source doesn't have any jsdoc comments yet, so this would all be todo.
This is the best option in the shortterm.
That should be easy/automatic, because all api changes are documented in each version's milestone. @felixfbecker Do you have an example of jsdoc not being enough? My understanding is that detailed-enough jsdoc comments should suffice for features like intellisense/autocomplete. Tern seems able to do it with just jsdoc comments, so I think ts should be able to do the same. |
@phreed Do you want to push your definition to DefinitelyTyped now? Usually other users need to use it in typescript could take care of it. |
I created a pull request after fix lint and other small errors. Push it to DefinitelyTyped could let other users use it and fix problems when they are using it. Ideally this could be maintained by users automatically without cytoscape developer. DefinitelyTyped/DefinitelyTyped#20511 |
Today the type definition has been merged to DefinitelyTyped, but it has some problems. When I import the module: When I call with cytoscape type source on DefinitelyTyped: https://github.com/DefinitelyTyped/DefinitelyTyped/blob/d9ca7d7efff765abe162023a9aa47f51f473bfd7/types/cytoscape/index.d.ts Can someone familiar with typescript look into it? I've worked on it for the whole day without any solution. |
Shouldn't cytoscape be declared as a class with a constructor, like its done here types/dygraphs/index.d.ts#L924? |
I just submitted an fix for it: DefinitelyTyped/DefinitelyTyped#20616. This would solve the import problem. @opavader |
I am not sure what the best forum is for reporting problems with the cytoscape typings themselves? I have seen two issues:
Thanks for finally getting this up on npm :) |
@WaynePlummer If you like you could submit a pull request on DefinitelyTyped project to fix the problem. |
Any update here? :-) |
@CzechBoy The type definition is already in DefinitelyTyped. |
@wy193777 Ok, so we can closed this issue? |
I think so. Someone has the permission can close it now. |
Hello everyone, This project's main objective was to convert the documentation for Cytoscape, currently a JSON specification with references to Markdown files, to JSDoc annotations. From the JSDoc comments, a Typescript definition file will be generated using tsd-jsdoc module. Right now I am fixing a few minor issues and very soon we will be able to support TypeScript in the new release. PR for the same has been merged. |
@phreed @opavader @Cyberider, and others: Let's get these typings directly into the main Cytoscape repo. What would be involved in this process, i.e.
|
We've done some initial analysis to estimate the coverage of the existing community Typescript definition file . The method isn't perfect, but it will help to identify areas for improvement. Process:
--- ts.json
+++ docs.json
@@ -10,24 +10,27 @@
"ani.progress",
"ani.progress",
"ani.promise",
+ "ani.promise",
"ani.reverse",
"ani.rewind",
+ "ani.run",
+ "ani.running",
"ani.stop",
"ani.time",
"ani.time",
"cy.$",
"cy.$id",
"cy.add",
+ "cy.add",
+ "cy.add",
"cy.addListener",
- "cy.addListener",
- "cy.addListener",
- "cy.addListener",
"cy.animate",
"cy.animated",
"cy.animation",
"cy.attr",
"cy.attr",
"cy.attr",
+ "cy.attr",
"cy.autolock",
"cy.autolock",
"cy.autoungrabify",
@@ -36,20 +39,21 @@
"cy.autounselectify",
"cy.batch",
"cy.bind",
- "cy.bind",
- "cy.bind",
- "cy.bind",
"cy.boxSelectionEnabled",
"cy.boxSelectionEnabled",
"cy.center",
+ "cy.center",
"cy.centre",
+ "cy.centre",
"cy.clearQueue",
"cy.collection",
+ "cy.collection",
"cy.container",
"cy.createLayout",
"cy.data",
"cy.data",
"cy.data",
+ "cy.data",
"cy.delay",
"cy.delayAnimation",
"cy.destroy",
@@ -60,25 +64,18 @@
"cy.endBatch",
"cy.extent",
"cy.filter",
+ "cy.filter",
"cy.fit",
- "cy.forceRender",
+ "cy.fit",
"cy.getElementById",
- "cy.hasElementWithId",
"cy.height",
"cy.invalidateDimensions",
"cy.jpeg",
- "cy.jpeg",
- "cy.jpeg",
"cy.jpg",
- "cy.jpg",
- "cy.jpg",
"cy.json",
"cy.json",
"cy.layout",
"cy.listen",
- "cy.listen",
- "cy.listen",
- "cy.listen",
"cy.makeLayout",
"cy.maxZoom",
"cy.maxZoom",
@@ -87,51 +84,41 @@
"cy.mount",
"cy.nodes",
"cy.off",
- "cy.off",
- "cy.off",
"cy.on",
- "cy.on",
- "cy.on",
- "cy.on",
"cy.one",
- "cy.one",
- "cy.one",
- "cy.one",
"cy.pan",
"cy.pan",
"cy.panBy",
"cy.panningEnabled",
"cy.panningEnabled",
"cy.png",
- "cy.png",
- "cy.png",
"cy.pon",
"cy.promiseOn",
"cy.ready",
"cy.remove",
+ "cy.remove",
"cy.removeAllListeners",
"cy.removeAttr",
+ "cy.removeAttr",
"cy.removeData",
+ "cy.removeData",
"cy.removeListener",
- "cy.removeListener",
- "cy.removeListener",
"cy.removeScratch",
+ "cy.renderedExtent",
"cy.reset",
"cy.resize",
"cy.scratch",
"cy.scratch",
+ "cy.scratch",
"cy.selectionType",
"cy.selectionType",
"cy.startBatch",
"cy.stop",
"cy.style",
+ "cy.style",
"cy.trigger",
"cy.unbind",
- "cy.unbind",
- "cy.unbind",
"cy.unlisten",
- "cy.unlisten",
- "cy.unlisten",
"cy.unmount",
"cy.userPanningEnabled",
"cy.userPanningEnabled",
@@ -141,11 +128,18 @@
"cy.width",
"cy.zoom",
"cy.zoom",
+ "cy.zoom",
"cy.zoomingEnabled",
+ "cy.zoomingEnabled",
"edge.controlPoints",
"edge.isLoop",
"edge.isSimple",
"edge.midpoint",
+ "edge.renderedControlPoints",
+ "edge.renderedMidpoint",
+ "edge.renderedSegmentPoints",
+ "edge.renderedSourceEndpoint",
+ "edge.renderedTargetEndpoint",
"edge.segmentPoints",
"edge.source",
"edge.sourceEndpoint",
@@ -153,13 +147,20 @@
"edge.targetEndpoint",
"edges.codirectedEdges",
"edges.connectedNodes",
+ "edges.move",
"edges.parallelEdges",
"edges.sources",
"edges.targets",
"ele.active",
"ele.animated",
"ele.animation",
+ "ele.classes",
+ "ele.component",
"ele.cy",
+ "ele.data",
+ "ele.data",
+ "ele.data",
+ "ele.data",
"ele.delayAnimation",
"ele.effectiveOpacity",
"ele.group",
@@ -171,24 +172,25 @@
"ele.isEdge",
"ele.isNode",
"ele.json",
+ "ele.json",
"ele.numericStyle",
"ele.numericStyleUnits",
"ele.outerHeight",
"ele.outerWidth",
+ "ele.pannable",
"ele.removeScratch",
"ele.removed",
- "ele.renderedCss",
- "ele.renderedCss",
"ele.renderedHeight",
"ele.renderedOuterHeight",
"ele.renderedOuterWidth",
- "ele.renderedStyle",
- "ele.renderedStyle",
"ele.renderedWidth",
"ele.scratch",
"ele.scratch",
+ "ele.scratch",
"ele.selectable",
"ele.selected",
+ "ele.style",
+ "ele.style",
"ele.transparent",
"ele.visible",
"ele.width",
@@ -196,52 +198,58 @@
"eles.aStar",
"eles.abscomp",
"eles.absoluteComplement",
+ "eles.add",
+ "eles.add",
"eles.addClass",
"eles.addListener",
- "eles.addListener",
"eles.allAre",
"eles.allAreNeighbors",
"eles.allAreNeighbours",
+ "eles.and",
+ "eles.and",
"eles.animate",
"eles.anySame",
- "eles.attr",
- "eles.attr",
- "eles.attr",
+ "eles.bb",
+ "eles.bc",
"eles.bellmanFord",
"eles.betweennessCentrality",
"eles.bfs",
"eles.bind",
- "eles.bind",
"eles.boundingBox",
"eles.boundingbox",
"eles.breadthFirstSearch",
+ "eles.cc",
+ "eles.ccn",
+ "eles.className",
+ "eles.classNames",
"eles.classes",
- "eles.classes",
- "eles.classes",
"eles.clearQueue",
"eles.clone",
"eles.closedNeighborhood",
"eles.closenessCentrality",
+ "eles.closenessCentralityNormalised",
"eles.closenessCentralityNormalized",
"eles.complement",
"eles.components",
+ "eles.componentsOf",
"eles.contains",
"eles.copy",
"eles.createLayout",
"eles.css",
"eles.css",
- "eles.css",
- "eles.css",
- "eles.data",
- "eles.data",
- "eles.data",
+ "eles.dc",
+ "eles.dcn",
"eles.degreeCentrality",
+ "eles.degreeCentralityNormalised",
"eles.degreeCentralityNormalized",
"eles.delay",
"eles.depthFirstSearch",
"eles.deselect",
"eles.dfs",
"eles.diff",
+ "eles.diff",
+ "eles.difference",
+ "eles.difference",
"eles.dijkstra",
"eles.each",
"eles.edges",
@@ -250,16 +258,22 @@
"eles.eq",
"eles.every",
"eles.filter",
+ "eles.filter",
"eles.first",
"eles.flashClass",
"eles.floydWarshall",
"eles.forEach",
"eles.getElementById",
"eles.has",
+ "eles.hierholzer",
"eles.hopcroftTarjanBiconnected",
"eles.hopcroftTarjanBiconnectedComponents",
"eles.htb",
"eles.htbc",
+ "eles.intersect",
+ "eles.intersect",
+ "eles.intersection",
+ "eles.intersection",
"eles.is",
"eles.jsons",
"eles.kargerStein",
@@ -267,38 +281,43 @@
"eles.last",
"eles.layout",
"eles.listen",
- "eles.listen",
"eles.makeLayout",
"eles.map",
+ "eles.markovClustering",
"eles.max",
+ "eles.mcl",
"eles.merge",
+ "eles.merge",
"eles.min",
- "eles.move",
- "eles.move",
"eles.neighborhood",
"eles.nodes",
"eles.nonempty",
+ "eles.not",
+ "eles.not",
"eles.off",
"eles.on",
- "eles.on",
"eles.once",
- "eles.once",
- "eles.once",
"eles.one",
- "eles.one",
- "eles.one",
"eles.openNeighborhood",
+ "eles.or",
+ "eles.or",
"eles.pageRank",
+ "eles.panify",
"eles.pon",
"eles.promiseOn",
"eles.reduce",
+ "eles.relativeComplement",
+ "eles.relativeComplement",
"eles.remove",
"eles.removeAllListeners",
"eles.removeAttr",
+ "eles.removeAttr",
"eles.removeClass",
"eles.removeData",
+ "eles.removeData",
"eles.removeListener",
"eles.removeStyle",
+ "eles.removeStyle",
"eles.renderedBoundingBox",
"eles.renderedBoundingbox",
"eles.restore",
@@ -312,8 +331,12 @@
"eles.stop",
"eles.style",
"eles.style",
- "eles.style",
- "eles.style",
+ "eles.subtract",
+ "eles.subtract",
+ "eles.symdiff",
+ "eles.symdiff",
+ "eles.symmetricDifference",
+ "eles.symmetricDifference",
"eles.tarjanStronglyConnected",
"eles.tarjanStronglyConnectedComponents",
"eles.toArray",
@@ -322,28 +345,47 @@
"eles.tsc",
"eles.tscc",
"eles.unbind",
- "eles.undefined",
+ "eles.union",
+ "eles.union",
"eles.unlisten",
"eles.unmerge",
+ "eles.unmerge",
+ "eles.unpanify",
"eles.unselect",
"eles.unselectify",
- "event.isDefaultPrevented",
- "event.isImmediatePropagationStopped",
- "event.isPropagationStopped",
- "event.preventDefault",
- "event.stopImmediatePropagation",
- "event.stopPropagation",
+ "eles.xor",
+ "eles.xor",
+ "eles['!']",
+ "eles['!']",
+ "eles['&']",
+ "eles['&']",
+ "eles['(+)']",
+ "eles['(+)']",
+ "eles['(-)']",
+ "eles['(-)']",
+ "eles['+']",
+ "eles['+']",
+ "eles['-']",
+ "eles['-']",
+ "eles['.']",
+ "eles['.']",
+ "eles['\\\\']",
+ "eles['\\\\']",
+ "eles['^']",
+ "eles['^']",
+ "eles['n']",
+ "eles['n']",
+ "eles['u']",
+ "eles['u']",
+ "eles['|']",
+ "eles['|']",
"layout.addListener",
- "layout.addListener",
"layout.bind",
- "layout.bind",
+ "layout.emit",
"layout.listen",
- "layout.listen",
"layout.off",
"layout.on",
- "layout.on",
"layout.one",
- "layout.one",
"layout.pon",
"layout.promiseOn",
"layout.removeAllListeners",
@@ -380,24 +422,38 @@
"node.relativePoint",
"node.relativePoint",
"node.relativePoint",
+ "node.relativePoint",
"node.relativePosition",
"node.relativePosition",
"node.relativePosition",
+ "node.relativePosition",
"node.renderedPoint",
"node.renderedPoint",
"node.renderedPoint",
+ "node.renderedPoint",
"node.renderedPosition",
"node.renderedPosition",
"node.renderedPosition",
+ "node.renderedPosition",
+ "nodes.affinityPropagation",
"nodes.ancestors",
+ "nodes.ap",
"nodes.children",
"nodes.commonAncestors",
"nodes.connectedEdges",
"nodes.descendants",
"nodes.edgesTo",
+ "nodes.edgesTo",
"nodes.edgesWith",
+ "nodes.edgesWith",
+ "nodes.fcm",
+ "nodes.fuzzyCMeans",
"nodes.grabify",
+ "nodes.hca",
+ "nodes.hierarchicalClustering",
"nodes.incomers",
+ "nodes.kMeans",
+ "nodes.kMedoids",
"nodes.layoutPositions",
"nodes.leaves",
"nodes.lock",
@@ -408,13 +464,17 @@
"nodes.minIndegree",
"nodes.minOutdegree",
"nodes.modelPositions",
+ "nodes.modelPositions",
+ "nodes.move",
"nodes.nonorphans",
"nodes.orphans",
"nodes.outgoers",
"nodes.parent",
"nodes.parents",
"nodes.points",
+ "nodes.points",
"nodes.positions",
+ "nodes.positions",
"nodes.predecessors",
"nodes.roots",
"nodes.shift",
@@ -423,16 +483,5 @@
"nodes.successors",
"nodes.totalDegree",
"nodes.ungrabify",
- "nodes.unlock",
- "style.append",
- "style.clear",
- "style.fromJson",
- "style.fromString",
- "style.json",
- "style.resetToDefault",
- "style.selector",
- "style.style",
- "style.style",
- "style.update",
- "stylesheet.json"
+ "nodes.unlock"
]
|
And a similar process for style properties: --- ts-style.json
+++ docs-style.json
@@ -3,10 +3,15 @@
"active-bg-opacity",
"active-bg-size",
"arrow-scale",
+ "average",
"background-blacken",
"background-clip",
"background-color",
+ "background-fill",
"background-fit",
+ "background-gradient-direction",
+ "background-gradient-stop-colors",
+ "background-gradient-stop-positions",
"background-height",
"background-height-relative-to",
"background-image",
@@ -22,19 +27,24 @@
"background-repeat",
"background-width",
"background-width-relative-to",
- "backgroundColor",
+ "border-cap",
"border-color",
+ "border-dash-offset",
+ "border-dash-pattern",
+ "border-join",
"border-opacity",
+ "border-position",
"border-style",
"border-width",
"bounds-expansion",
"color",
- "content",
+ "compound-sizing-wrt-labels",
"control-point-distance",
"control-point-distances",
"control-point-step-size",
"control-point-weight",
"control-point-weights",
+ "corner-radius",
"curve-style",
"display",
"edge-distances",
@@ -59,26 +69,42 @@
"line-gradient-stop-positions",
"line-height",
"line-opacity",
+ "line-outline-color",
+ "line-outline-width",
"line-style",
"loop-direction",
"loop-sweep",
+ "max",
"mid-source-arrow-color",
"mid-source-arrow-fill",
"mid-source-arrow-shape",
+ "mid-source-arrow-width",
"mid-target-arrow-color",
"mid-target-arrow-fill",
"mid-target-arrow-shape",
+ "mid-target-arrow-width",
+ "min",
+ "min-height",
+ "min-height-bias-bottom",
+ "min-height-bias-top",
+ "min-width",
+ "min-width-bias-left",
+ "min-width-bias-right",
"min-zoomed-font-size",
"opacity",
+ "outline-color",
+ "outline-offset",
+ "outline-opacity",
+ "outline-style",
+ "outline-width",
"outside-texture-bg-color",
"outside-texture-bg-opacity",
"overlay-color",
"overlay-opacity",
"overlay-padding",
- "padding-bottom",
- "padding-left",
- "padding-right",
- "padding-top",
+ "overlay-shape",
+ "padding",
+ "padding-relative-to",
"pie-1-background-color",
"pie-1-background-opacity",
"pie-1-background-size",
@@ -131,7 +157,9 @@
"pie-i-background-opacity",
"pie-i-background-size",
"pie-size",
+ "radius-type",
"segment-distances",
+ "segment-radii",
"segment-weights",
"selection-box-border-color",
"selection-box-border-width",
@@ -142,6 +170,7 @@
"source-arrow-color",
"source-arrow-fill",
"source-arrow-shape",
+ "source-arrow-width",
"source-distance-from-node",
"source-endpoint",
"source-label",
@@ -152,6 +181,7 @@
"target-arrow-color",
"target-arrow-fill",
"target-arrow-shape",
+ "target-arrow-width",
"target-distance-from-node",
"target-endpoint",
"target-label",
@@ -160,6 +190,7 @@
"target-text-offset",
"target-text-rotation",
"taxi-direction",
+ "taxi-radius",
"taxi-turn",
"taxi-turn-min-distance",
"text-background-color",
@@ -189,6 +220,10 @@
"transition-duration",
"transition-property",
"transition-timing-function",
+ "underlay-color",
+ "underlay-opacity",
+ "underlay-padding",
+ "underlay-shape",
"visibility",
"width",
"z-compound-depth",
|
We plan to have improved, first-party Typescript support in 3.31.0, released in the new year. |
Followed up in #3306 |
PR up in #3308 |
For any of you that use or are thinking of using TypeScript to strengthen your JS coding there is s TS definition file project in the works.
Fabian-Schmidt (not me) is working on it at:
https://github.com/Fabian-Schmidt/DefinitelyTyped/tree/master/cytoscape
I use TypeScript so I'm excited to be able to use cytoscape.js with TypeScript.
Rick
The text was updated successfully, but these errors were encountered: