123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- import * as React from "react";
- import { DefaultNodeModel } from './defaultNodeModel';
- import { DefaultPortModel } from './port/defaultPortModel';
- import { Nullable } from 'babylonjs/types';
- import { NodeMaterialConnectionPoint } from 'babylonjs/Materials/Node/nodeMaterialBlockConnectionPoint';
- import { NodeMaterialBlockConnectionPointTypes } from 'babylonjs/Materials/Node/nodeMaterialBlockConnectionPointTypes';
- import { DefaultPortWidget } from './port/defaultPortWidget';
- import { BlockTools } from '../../blockTools';
- 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;
- }
- static _GetPortStyle(type: NodeMaterialBlockConnectionPointTypes) {
- return {
- background: BlockTools.GetColorFromConnectionNodeType(type)
- };
- }
- public static GenerateOutputPorts(node: Nullable<DefaultNodeModel>, ignoreLabel: boolean) {
- if (!node) {
- return new Array<JSX.Element>();
- }
- let outputPorts = [];
- for (var key in node.ports) {
- let port = node.ports[key] as DefaultPortModel;
- if (port.position === "output") {
- let typeIndicator = this._GetPortTypeIndicator(port.connection!);
- let style = this._GetPortStyle(port.connection!.type);
- let isConnected = port.connection && port.connection.endpoints.length > 0;
- outputPorts.push(
- <div key={key} className="output-port">
- {
- !ignoreLabel &&
- <div className="output-port-label">
- {port.name}
- </div>
- }
- <div className="output-port-plug">
- <div className="output-port-border">
- </div>
- <DefaultPortWidget key={key} name={port.name} node={node} style={style} />
- {
- !isConnected &&
- <div className="output-port-connection">
- </div>
- }
- <div className="output-port-type">
- {
- typeIndicator
- }
- </div>
- </div>
- </div>
- );
- }
- }
- return outputPorts;
- }
- public static GenerateInputPorts(node: Nullable<DefaultNodeModel>, includeOnly?: string[]) {
- if (!node) {
- return new Array<JSX.Element>();
- }
- let inputPorts = [];
- for (var key in node.ports) {
- let port = node.ports[key] as DefaultPortModel;
- if (port.position === "input") {
- let typeIndicator = this._GetPortTypeIndicator(port.connection!);
- let style = this._GetPortStyle(port.connection!.type);
- let isConnected = port.connection && port.connection.endpoints.length > 0;
- if (!includeOnly || includeOnly.indexOf(port.name) !== -1) {
- inputPorts.push(
- <div key={key} className="input-port">
- <div className="input-port-plug">
- <div className="input-port-border">
- </div>
- <DefaultPortWidget key={key} name={port.name} node={node} style={style}/>
- {
- !isConnected &&
- <div className="output-port-connection">
- </div>
- }
- <div className="input-port-type">
- {
- typeIndicator
- }
- </div>
- </div>
- <div className="input-port-label">
- {port.name}
- </div>
- </div>
- );
- }
- }
- }
- return inputPorts;
- }
- }
|