stackPanelPropertyGridComponent.tsx 1.9 KB

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