123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198 |
- import { BlockTools } from '../blockTools';
- import { NodeMaterialBlockConnectionPointTypes } from 'babylonjs/Materials/Node/Enums/nodeMaterialBlockConnectionPointTypes';
- import { NodeMaterialConnectionPoint } from 'babylonjs/Materials/Node/nodeMaterialBlockConnectionPoint';
- import { GlobalState } from '../globalState';
- import { Nullable } from 'babylonjs/types';
- import { Observer } from 'babylonjs/Misc/observable';
- import { Vector2 } from 'babylonjs/Maths/math.vector';
- import { IDisplayManager } from './display/displayManager';
- import { GraphNode } from './graphNode';
- import { NodeLink } from './nodeLink';
- import { GraphFrame } from './graphFrame';
- import { FrameNodePort } from './frameNodePort';
- import { FramePortData } from './graphCanvas';
- export class NodePort {
- protected _element: HTMLDivElement;
- protected _img: HTMLImageElement;
- protected _globalState: GlobalState;
- protected _portLabelElement: Element;
- protected _onCandidateLinkMovedObserver: Nullable<Observer<Nullable<Vector2>>>;
- protected _onSelectionChangedObserver: Nullable<Observer<Nullable<GraphFrame | GraphNode | NodeLink | NodePort | FramePortData>>>;
- protected _exposedOnFrame: boolean;
- public isExposed = false;
- public delegatedPort: Nullable<FrameNodePort> = null;
- public get element(): HTMLDivElement {
- if (this.delegatedPort) {
- return this.delegatedPort.element;
- }
- return this._element;
- }
- public get portName(){
- let portName = this.connectionPoint.displayName || this.connectionPoint.name;
- if (this.connectionPoint.ownerBlock.isInput) {
- portName = this.node.name;
- }
- return portName
- }
- public set portName(newName: string){
- if(this._portLabelElement) {
- this.connectionPoint.displayName = newName;
- this._portLabelElement.innerHTML = newName;
- }
- }
- public get disabled() {
- if (!this.connectionPoint.isConnected) {
- return false;
- } else if (this._isConnectedToNodeOutsideOfFrame()) { //connected to outside node
- return true;
- } else {
- const link = this.node.getLinksForConnectionPoint(this.connectionPoint)
- if (link.length){
- if (link[0].nodeB === this.node) { // check if this node is the receiving
- return true;
- }
- }
- }
- return false;
- }
- public hasLabel(){
- return !!this._portLabelElement;
- }
- public get exposedOnFrame() {
- if(!!this.connectionPoint.isExposedOnFrame || this._isConnectedToNodeOutsideOfFrame()) {
- return true
- } return false;
- }
- public set exposedOnFrame(value: boolean) {
- if(this.disabled){
- return;
- }
- this.connectionPoint.isExposedOnFrame = value;
- }
-
- public get exposedPortPosition()
- {
- return this.connectionPoint.exposedPortPosition;
- }
- public set exposedPortPosition(value: number) {
- this.connectionPoint.exposedPortPosition = value;
- }
-
- private _isConnectedToNodeOutsideOfFrame() {
- const link = this.node.getLinksForConnectionPoint(this.connectionPoint)
- if (link.length){
- for(let i = 0; i < link.length; i++){
- if (link[i].nodeA.enclosingFrameId !== link[i].nodeB!.enclosingFrameId) {
- return true;
- }
- }
- }
- return false;
- }
- public refresh() {
- this._element.style.background = BlockTools.GetColorFromConnectionNodeType(this.connectionPoint.type);
- switch (this.connectionPoint.type) {
- case NodeMaterialBlockConnectionPointTypes.Float:
- case NodeMaterialBlockConnectionPointTypes.Int:
- this._img.src = "";
- break;
- case NodeMaterialBlockConnectionPointTypes.Vector2:
- this._img.src = "";
- break;
- case NodeMaterialBlockConnectionPointTypes.Vector3:
- case NodeMaterialBlockConnectionPointTypes.Color3:
- this._img.src = "";
- break;
- case NodeMaterialBlockConnectionPointTypes.Vector4:
- case NodeMaterialBlockConnectionPointTypes.Color4:
- this._img.src = "";
- break;
- case NodeMaterialBlockConnectionPointTypes.Matrix:
- this._img.src = "";
- break;
- case NodeMaterialBlockConnectionPointTypes.Object:
- this._img.src = "";
- break;
- }
- }
- public constructor(portContainer: HTMLElement, public connectionPoint: NodeMaterialConnectionPoint, public node: GraphNode, globalState: GlobalState) {
- this._element = portContainer.ownerDocument!.createElement("div");
- this._element.classList.add("port");
- portContainer.appendChild(this._element);
- this._globalState = globalState;
- this._img = portContainer.ownerDocument!.createElement("img");
- this._element.appendChild(this._img );
- // determine if node name is editable
- if (portContainer.children[0].className === 'port-label') {
- this._portLabelElement = portContainer.children[0];
- }
- (this._element as any).port = this;
- // Drag support
- this._element.ondragstart= () => false;
- this._onCandidateLinkMovedObserver = globalState.onCandidateLinkMoved.add(coords => {
- const rect = this._element.getBoundingClientRect();
- if (!coords || rect.left > coords.x || rect.right < coords.x || rect.top > coords.y || rect.bottom < coords.y) {
- this._element.classList.remove("selected");
- return;
- }
- this._element.classList.add("selected");
- this._globalState.onCandidatePortSelectedObservable.notifyObservers(this);
- });
- this._onSelectionChangedObserver = this._globalState.onSelectionChangedObservable.add((selection) => {
- if (selection === this) {
- this._img.classList.add("selected");
- } else {
- this._img.classList.remove("selected");
- }
- });
- this.refresh();
- }
- public dispose() {
- this._globalState.onCandidateLinkMoved.remove(this._onCandidateLinkMovedObserver);
- if (this._onSelectionChangedObserver) {
- this._globalState.onSelectionChangedObservable.remove(this._onSelectionChangedObserver);
- }
- }
- public static CreatePortElement(connectionPoint: NodeMaterialConnectionPoint, node: GraphNode, root: HTMLElement,
- displayManager: Nullable<IDisplayManager>, globalState: GlobalState) {
- let portContainer = root.ownerDocument!.createElement("div");
- let block = connectionPoint.ownerBlock;
- portContainer.classList.add("portLine");
- root.appendChild(portContainer);
- if (!displayManager || displayManager.shouldDisplayPortLabels(block)) {
- let portLabel = root.ownerDocument!.createElement("div");
- portLabel.classList.add("port-label");
- portLabel.innerHTML = connectionPoint.displayName || connectionPoint.name;
- portContainer.appendChild(portLabel);
- }
-
- return new NodePort(portContainer, connectionPoint, node, globalState);
- }
- }
|