checkboxPropertyGridComponent.tsx 1.7 KB

1234567891011121314151617181920212223242526272829303132333435
  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 { Checkbox } from "babylonjs-gui";
  7. import { LineContainerComponent } from "../../../lineContainerComponent";
  8. import { FloatLineComponent } from "../../../lines/floatLineComponent";
  9. import { CheckBoxLineComponent } from "../../../lines/checkBoxLineComponent";
  10. interface ICheckboxPropertyGridComponentProps {
  11. checkbox: Checkbox,
  12. lockObject: LockObject,
  13. onPropertyChangedObservable?: Observable<PropertyChangedEvent>
  14. }
  15. export class CheckboxPropertyGridComponent extends React.Component<ICheckboxPropertyGridComponentProps> {
  16. constructor(props: ICheckboxPropertyGridComponentProps) {
  17. super(props);
  18. }
  19. render() {
  20. const checkbox = this.props.checkbox;
  21. return (
  22. <div className="pane">
  23. <CommonControlPropertyGridComponent lockObject={this.props.lockObject} control={checkbox} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  24. <LineContainerComponent title="CHECKBOX">
  25. <FloatLineComponent lockObject={this.props.lockObject} label="Check size ratio" target={checkbox} propertyName="checkSizeRatio" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  26. <CheckBoxLineComponent label="Checked" target={checkbox} propertyName="isChecked" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  27. </LineContainerComponent>
  28. </div>
  29. );
  30. }
  31. }