reflectionTextureNodeWidget.tsx 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. import * as React from "react";
  2. import { TextureLineComponent } from "../../../sharedComponents/textureLineComponent"
  3. import { Nullable } from 'babylonjs/types';
  4. import { GlobalState } from '../../../globalState';
  5. import { PortHelper } from '../portHelper';
  6. import { ReflectionTextureNodeModel } from './reflectionTextureNodeModel';
  7. /**
  8. * GenericNodeWidgetProps
  9. */
  10. export interface IReflectionTextureNodeWidgetProps {
  11. node: Nullable<ReflectionTextureNodeModel>;
  12. globalState: GlobalState;
  13. }
  14. /**
  15. * Used to display a node block for the node editor
  16. */
  17. export class ReflectionTextureNodeWidget extends React.Component<IReflectionTextureNodeWidgetProps> {
  18. /**
  19. * Creates a GenericNodeWidget
  20. * @param props
  21. */
  22. constructor(props: IReflectionTextureNodeWidgetProps) {
  23. super(props);
  24. this.state = {};
  25. }
  26. render() {
  27. // Input/Output ports
  28. var outputPorts = PortHelper.GenerateOutputPorts(this.props.node, false);
  29. var inputPorts = PortHelper.GenerateInputPorts(this.props.node);
  30. return (
  31. <div className={"diagramBlock texture-block"}>
  32. <div className="header">
  33. {this.props.node!.block!.name}
  34. </div>
  35. <div className="inputs">
  36. {inputPorts}
  37. </div>
  38. <div className="outputs">
  39. {outputPorts}
  40. </div>
  41. {
  42. this.props.node && this.props.node.texture &&
  43. <TextureLineComponent ref="textureView" width={140} height={140} texture={this.props.node.texture} hideChannelSelect={true} />
  44. }
  45. </div>
  46. );
  47. }
  48. }