updated for 2.0.0 release
This commit is contained in:
		
							
								
								
									
										165
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										165
									
								
								README.md
									
									
									
									
									
								
							| @@ -2,41 +2,148 @@ | |||||||
| Module for creating smart graphs | Module for creating smart graphs | ||||||
|  |  | ||||||
| ## Example | ## Example | ||||||
| ```html |  | ||||||
| <section id='graph'> | ### JavaScript | ||||||
| </section> |  | ||||||
| ``` |  | ||||||
| ```js | ```js | ||||||
| import("/js/modules/graph.mjs").then((graph) => { | import("/js/modules/graph.mjs").then((graph) => { | ||||||
|     // Imported the graph.mjs module |   // Imported the graph.mjs module | ||||||
|  |  | ||||||
|     // Initializing an instance of the graph.mjs |   // Initializing the graph instance | ||||||
|     const instance = new graph.default(document.getElementById('graph')); |   const instance = new graph.core(document.getElementById('graph')); | ||||||
|      |      | ||||||
|     // Initializing node for the graph |   // Writing settings of the graph instance | ||||||
|     const bebra = instance.write({ |   instance.living = 3000; | ||||||
|       title: 'bebra', |   instance.camera = true; | ||||||
|       description: 'i am a fat juicy smelly bebra', |   instance.operate = true; | ||||||
|       link: 'https://bebra.mirzaev.sexy' |  | ||||||
|     }); |  | ||||||
|      |      | ||||||
|     // Initializing node for the graph |   // Initializing and registering nodes | ||||||
|     const root = instance.write({ |   const genesis = instance.node(new graph.node(document.getElementById('genesis'))); | ||||||
|       title: 'root node' |   const food = instance.node(new graph.node(document.getElementById('food'))); | ||||||
|     }); |   const tofu = instance.node(new graph.node(document.getElementById('tofu'))); | ||||||
|  |   const broccoli = instance.node(new graph.node(document.getElementById('broccoli'))); | ||||||
|  |   const wtf = instance.node(new graph.node(document.getElementById('wtf'))); | ||||||
|  |   const bebra = instance.node(new graph.node(document.getElementById('bebra'))); | ||||||
|  |   const feet = instance.node(new graph.node(document.getElementById('feet'))); | ||||||
|  |   const anarchy = instance.node(new graph.node(document.getElementById('anarchy'))); | ||||||
|      |      | ||||||
|     // Initializing node for the graph |   // Writing settings for every node | ||||||
|     const anarchy = instance.write({ |   instance.nodes.forEach((node) => { node.variables.get("inputs").type = "deg" }); | ||||||
|       title: 'anarchy', |  | ||||||
|     }); |  | ||||||
|      |      | ||||||
|     // Connectiong the bebra node to the root node |   // Initializing and registering edges | ||||||
|     core.connect(bebra, root); |   instance.edge(new graph.edge(feet, bebra)); | ||||||
|  |   instance.edge(new graph.edge(bebra, genesis)); | ||||||
|     // Connectiong the anarchy node to the root node |   instance.edge(new graph.edge(anarchy, genesis)); | ||||||
|     core.connect(anarchy, root); |   instance.edge(new graph.edge(food, genesis)); | ||||||
|  |   instance.edge(new graph.edge(tofu, food)); | ||||||
|     // Initializing the feet node and connect to the bebra node |   instance.edge(new graph.edge(broccoli, food)); | ||||||
|     core.connect(instance.write({ title: 'feet' }, bebra); |   instance.edge(new graph.edge(wtf, tofu)); | ||||||
|  |   instance.edge(new graph.edge(wtf, broccoli)); | ||||||
| }); | }); | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | ### HTML | ||||||
|  | ```html | ||||||
|  | <section id='graph'> | ||||||
|  |   <article id="genesis" class="node unselectable"><a>genesis</a></article> | ||||||
|  |   <article id="food" class="node unselectable"><a>food</a></article> | ||||||
|  |   <article id="tofu" class="node unselectable"><a>tofu</a></article> | ||||||
|  |   <article id="broccoli" class="node unselectable"><a>broccoli</a></article> | ||||||
|  |   <article id="wtf" class="node unselectable"><a>tofu with broccoli</a></article> | ||||||
|  |   <article id="bebra" class="node unselectable"><a>bebra</a></article> | ||||||
|  |   <article id="feet" class="node unselectable"><a>feet</a></article> | ||||||
|  |   <article id="anarchy" class="node unselectable"><a>anarchy</a></article> | ||||||
|  | </section> | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### CSS | ||||||
|  | ```css | ||||||
|  | @keyframes node-movement { | ||||||
|  |   0% { | ||||||
|  |     left: var(--graph-node-from-left); | ||||||
|  |     top: var(--graph-node-from-top); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   100% { | ||||||
|  |     left: var(--graph-node-to-left); | ||||||
|  |     top: var(--graph-node-to-top); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .unselectable { | ||||||
|  |   -webkit-touch-callout: none; | ||||||
|  |   -webkit-user-select: none; | ||||||
|  |   -khtml-user-select: none; | ||||||
|  |   -moz-user-select: none; | ||||||
|  |   -ms-user-select: none; | ||||||
|  |   user-select: none; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | body { | ||||||
|  |   height: 100vh; | ||||||
|  |   margin: 0; | ||||||
|  |   overflow: hidden; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | body:active { | ||||||
|  |   cursor: move; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | section#graph { | ||||||
|  |   left: var(--graph-shell-left); | ||||||
|  |   top: var(--graph-shell-top); | ||||||
|  |   width: 100vw; | ||||||
|  |   height: 100vh; | ||||||
|  |   position: absolute; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | article.node { | ||||||
|  |   z-index: calc(500 + var(--graph-node-layer, 0) - var(--graph-node-inputs, 0)); | ||||||
|  |   left: var(--graph-node-from-left, var(--graph-node-left)); | ||||||
|  |   top: var(--graph-node-from-top, var(--graph-node-top)); | ||||||
|  |   width: var(--graph-node-augmented, 100px); | ||||||
|  |   height: var(--graph-node-augmented, 100px); | ||||||
|  |   position: absolute; | ||||||
|  |   display: flex; | ||||||
|  |   cursor: grab; | ||||||
|  |   border-radius: 100%; | ||||||
|  |   background-color: #33dd6d; | ||||||
|  |   filter: hue-rotate(calc(0deg + var(--graph-node-inputs) * -15)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | article.node.movement { | ||||||
|  |   animation-name: node-movement; | ||||||
|  |   animation-fill-mode: forwards; | ||||||
|  |   animation-duration: 0.6s; | ||||||
|  | /*   animation-duration: 5.5s; */ | ||||||
|  |   animation-timing-function: cubic-bezier(0, 1, 1, 1); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | article.node:active { | ||||||
|  |   cursor: grabbing; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | article.node > a:first-of-type { | ||||||
|  |   margin: auto; | ||||||
|  |   text-align: center; | ||||||
|  |   text-decoration: unset; | ||||||
|  |   font-weight: bold; | ||||||
|  |   cursor: pointer; | ||||||
|  |   color: black; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | svg.edge { | ||||||
|  |   z-index: -500; | ||||||
|  |   position: absolute; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | svg.edge > line { | ||||||
|  |   stroke: #816262; | ||||||
|  |   stroke-width: 8px; | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### Result | ||||||
|  | <br><br> | ||||||
|  | [Try it on CodePen](https://codepen.io/mirzaev-sexy/pen/Rwyxprz) | ||||||
		Reference in New Issue
	
	Block a user