radioButtonPropertyGridComponent.tsx 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738
  1. import * as React from "react";
  2. import { Observable } from "babylonjs/Misc/observable";
  3. import { PropertyChangedEvent } from "../../../propertyChangedEvent";
  4. import { CommonControlPropertyGridComponent } from "../../../tabs/propertyGrids/gui/commonControlPropertyGridComponent";
  5. import { LockObject } from "../../../tabs/propertyGrids/lockObject";
  6. import { RadioButton } from "babylonjs-gui/2D/controls/radioButton";
  7. import { LineContainerComponent } from "../../../lines/lineContainerComponent";
  8. import { FloatLineComponent } from "../../../lines/floatLineComponent";
  9. import { TextInputLineComponent } from "../../../lines/textInputLineComponent";
  10. import { CheckBoxLineComponent } from "../../../lines/checkBoxLineComponent";
  11. interface IRadioButtonPropertyGridComponentProps {
  12. radioButton: RadioButton,
  13. lockObject: LockObject,
  14. onPropertyChangedObservable?: Observable<PropertyChangedEvent>
  15. }
  16. export class RadioButtonPropertyGridComponent extends React.Component<IRadioButtonPropertyGridComponentProps> {
  17. constructor(props: IRadioButtonPropertyGridComponentProps) {
  18. super(props);
  19. }
  20. render() {
  21. const radioButton = this.props.radioButton;
  22. return (
  23. <div className="pane">
  24. <CommonControlPropertyGridComponent lockObject={this.props.lockObject} control={radioButton} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  25. <LineContainerComponent title="RADIO BUTTON">
  26. <FloatLineComponent lockObject={this.props.lockObject} label="Thickness" target={radioButton} propertyName="thickness" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  27. <FloatLineComponent lockObject={this.props.lockObject} label="Check size ratio" target={radioButton} propertyName="checkSizeRatio" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  28. <TextInputLineComponent lockObject={this.props.lockObject} label="Group" target={radioButton} propertyName="group" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  29. <CheckBoxLineComponent label="Checked" target={radioButton} propertyName="isChecked" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  30. </LineContainerComponent>
  31. </div>
  32. );
  33. }
  34. }