sliderPropertyGridComponent.tsx 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  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 { LineContainerComponent } from "../../../lineContainerComponent";
  6. import { LockObject } from "../lockObject";
  7. import { Slider } from "babylonjs-gui/2D/controls/sliders/slider";
  8. import { FloatLineComponent } from "../../../lines/floatLineComponent";
  9. import { CheckBoxLineComponent } from "../../../lines/checkBoxLineComponent";
  10. import { TextInputLineComponent } from "../../../lines/textInputLineComponent";
  11. import { GlobalState } from '../../../../globalState';
  12. interface ISliderPropertyGridComponentProps {
  13. globalState: GlobalState;
  14. slider: Slider,
  15. lockObject: LockObject,
  16. onPropertyChangedObservable?: Observable<PropertyChangedEvent>
  17. }
  18. export class SliderPropertyGridComponent extends React.Component<ISliderPropertyGridComponentProps> {
  19. constructor(props: ISliderPropertyGridComponentProps) {
  20. super(props);
  21. }
  22. render() {
  23. const slider = this.props.slider;
  24. return (
  25. <div className="pane">
  26. <CommonControlPropertyGridComponent globalState={this.props.globalState} lockObject={this.props.lockObject} control={slider} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  27. <LineContainerComponent globalState={this.props.globalState} title="SLIDER">
  28. <TextInputLineComponent lockObject={this.props.lockObject} label="Border color" target={slider} propertyName="borderColor" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  29. <CheckBoxLineComponent label="Display thumb" target={slider} propertyName="displayThumb" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  30. <CheckBoxLineComponent label="Thumb circle" target={slider} propertyName="isThumbCircle" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  31. <CheckBoxLineComponent label="Vertical" target={slider} propertyName="isVertical" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  32. <CheckBoxLineComponent label="Thumb clamped" target={slider} propertyName="isThumbClamped" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  33. <TextInputLineComponent lockObject={this.props.lockObject} label="Bar offset" target={slider} propertyName="barOffset" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  34. <TextInputLineComponent lockObject={this.props.lockObject} label="Thumb width" target={slider} propertyName="thumbWidth" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  35. <FloatLineComponent lockObject={this.props.lockObject} label="Minimum" target={slider} propertyName="minimum" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  36. <FloatLineComponent lockObject={this.props.lockObject} label="Maximum" target={slider} propertyName="maximum" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  37. <FloatLineComponent lockObject={this.props.lockObject} label="Value" target={slider} propertyName="value" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  38. </LineContainerComponent>
  39. </div>
  40. );
  41. }
  42. }