postProcessPropertyGridComponent.tsx 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. import * as React from "react";
  2. import { Observable } from "babylonjs/Misc/observable";
  3. import { PostProcess } from "babylonjs/PostProcesses/postProcess";
  4. import { PropertyChangedEvent } from "../../../../propertyChangedEvent";
  5. import { LockObject } from "../../../../../sharedUiComponents/tabs/propertyGrids/lockObject";
  6. import { CommonPostProcessPropertyGridComponent } from './commonPostProcessPropertyGridComponent';
  7. import { GlobalState } from '../../../../globalState';
  8. import { LineContainerComponent } from '../../../../../sharedUiComponents/lines/lineContainerComponent';
  9. import { ButtonLineComponent } from '../../../../../sharedUiComponents/lines/buttonLineComponent';
  10. interface IPostProcessPropertyGridComponentProps {
  11. globalState: GlobalState;
  12. postProcess: PostProcess,
  13. lockObject: LockObject,
  14. onPropertyChangedObservable?: Observable<PropertyChangedEvent>
  15. }
  16. export class PostProcessPropertyGridComponent extends React.Component<IPostProcessPropertyGridComponentProps> {
  17. constructor(props: IPostProcessPropertyGridComponentProps) {
  18. super(props);
  19. }
  20. edit() {
  21. const postProcess = this.props.postProcess;
  22. postProcess.nodeMaterialSource!.edit();
  23. }
  24. render() {
  25. const postProcess = this.props.postProcess;
  26. return (
  27. <div className="pane">
  28. <CommonPostProcessPropertyGridComponent globalState={this.props.globalState} lockObject={this.props.lockObject} postProcess={postProcess} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  29. {
  30. postProcess.nodeMaterialSource &&
  31. <LineContainerComponent title="CONFIGURATION">
  32. <ButtonLineComponent label="Node Material Editor" onClick={() => this.edit()} />
  33. </LineContainerComponent>
  34. }
  35. </div>
  36. );
  37. }
  38. }