|
|
@@ -3,9 +3,31 @@ import { PortWidget } from "storm-react-diagrams";
|
|
|
import { DefaultNodeModel } from './defaultNodeModel';
|
|
|
import { DefaultPortModel } from './defaultPortModel';
|
|
|
import { Nullable } from 'babylonjs/types';
|
|
|
+import { NodeMaterialConnectionPoint } from 'babylonjs/Materials/Node/nodeMaterialBlockConnectionPoint';
|
|
|
+import { NodeMaterialBlockConnectionPointTypes } from 'babylonjs/Materials/Node/nodeMaterialBlockConnectionPointTypes';
|
|
|
|
|
|
|
|
|
export class PortHelper {
|
|
|
+ private static _GetPortTypeIndicator(connection: NodeMaterialConnectionPoint): Nullable<JSX.Element> {
|
|
|
+ switch (connection.type) {
|
|
|
+ case NodeMaterialBlockConnectionPointTypes.Float:
|
|
|
+ case NodeMaterialBlockConnectionPointTypes.Int:
|
|
|
+ return <img src=""></img>;
|
|
|
+ case NodeMaterialBlockConnectionPointTypes.Vector2:
|
|
|
+ return <img src=""></img>;
|
|
|
+ case NodeMaterialBlockConnectionPointTypes.Vector3:
|
|
|
+ case NodeMaterialBlockConnectionPointTypes.Color3:
|
|
|
+ return <img src=""></img>;
|
|
|
+ case NodeMaterialBlockConnectionPointTypes.Vector4:
|
|
|
+ case NodeMaterialBlockConnectionPointTypes.Color4:
|
|
|
+ return <img src=""></img>;
|
|
|
+ case NodeMaterialBlockConnectionPointTypes.Matrix:
|
|
|
+ return <img src=""></img>;
|
|
|
+ }
|
|
|
+
|
|
|
+ return null;
|
|
|
+ }
|
|
|
+
|
|
|
public static GenerateOutputPorts(node: Nullable<DefaultNodeModel>, ignoreLabel: boolean) {
|
|
|
if (!node) {
|
|
|
return new Array<JSX.Element>();
|
|
|
@@ -14,6 +36,8 @@ export class PortHelper {
|
|
|
for (var key in node.ports) {
|
|
|
let port = node.ports[key] as DefaultPortModel;
|
|
|
if (port.position === "output") {
|
|
|
+ let typeIndicator = this._GetPortTypeIndicator(port.connection!);
|
|
|
+
|
|
|
outputPorts.push(
|
|
|
<div key={key} className="output-port">
|
|
|
{
|
|
|
@@ -24,6 +48,11 @@ export class PortHelper {
|
|
|
}
|
|
|
<div className="output-port-plug">
|
|
|
<PortWidget key={key} name={port.name} node={node} className={port.connection && port.connection.endpoints.length > 0 ? "connected" : ""} />
|
|
|
+ <div className="output-port-type">
|
|
|
+ {
|
|
|
+ typeIndicator
|
|
|
+ }
|
|
|
+ </div>
|
|
|
</div>
|
|
|
</div>
|
|
|
);
|
|
|
@@ -40,12 +69,19 @@ export class PortHelper {
|
|
|
let inputPorts = [];
|
|
|
for (var key in node.ports) {
|
|
|
let port = node.ports[key] as DefaultPortModel;
|
|
|
- if (port.position === "input") {
|
|
|
+ if (port.position === "input") {
|
|
|
+ let typeIndicator = this._GetPortTypeIndicator(port.connection!);
|
|
|
+
|
|
|
if (!includeOnly || includeOnly.indexOf(port.name) !== -1) {
|
|
|
inputPorts.push(
|
|
|
<div key={key} className="input-port">
|
|
|
<div className="input-port-plug">
|
|
|
<PortWidget key={key} name={port.name} node={node} className={port.connection && port.connection.connectedPoint ? "connected" : ""} />
|
|
|
+ <div className="input-port-type">
|
|
|
+ {
|
|
|
+ typeIndicator
|
|
|
+ }
|
|
|
+ </div>
|
|
|
</div>
|
|
|
<div className="input-port-label">
|
|
|
{port.name}
|