stackPanelPropertyGridComponent.tsx 1.6 KB

12345678910111213141516171819202122232425262728293031323334
  1. import * as React from "react";
  2. import { Observable } from "babylonjs";
  3. import { PropertyChangedEvent } from "../../../../propertyChangedEvent";
  4. import { CommonControlPropertyGridComponent } from "./commonControlPropertyGridComponent";
  5. import { LockObject } from "../lockObject";
  6. import { StackPanel } from "babylonjs-gui";
  7. import { LineContainerComponent } from "../../../lineContainerComponent";
  8. import { CheckBoxLineComponent } from "../../../lines/checkBoxLineComponent";
  9. interface IStackPanelPropertyGridComponentProps {
  10. stackPanel: StackPanel,
  11. lockObject: LockObject,
  12. onPropertyChangedObservable?: Observable<PropertyChangedEvent>
  13. }
  14. export class StackPanelPropertyGridComponent extends React.Component<IStackPanelPropertyGridComponentProps> {
  15. constructor(props: IStackPanelPropertyGridComponentProps) {
  16. super(props);
  17. }
  18. render() {
  19. const stackPanel = this.props.stackPanel;
  20. return (
  21. <div className="pane">
  22. <CommonControlPropertyGridComponent lockObject={this.props.lockObject} control={stackPanel} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  23. <LineContainerComponent title="STACKPANEL">
  24. <CheckBoxLineComponent label="Clip children" target={stackPanel} propertyName="clipChildren" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  25. <CheckBoxLineComponent label="Vertical" target={stackPanel} propertyName="isVertical" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  26. </LineContainerComponent>
  27. </div>
  28. );
  29. }
  30. }