imageBasedSliderPropertyGridComponent.tsx 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. import * as React from "react";
  2. import { Observable } from "babylonjs";
  3. import { PropertyChangedEvent } from "../../../../propertyChangedEvent";
  4. import { CommonControlPropertyGridComponent } from "./commonControlPropertyGridComponent";
  5. import { LineContainerComponent } from "../../../lineContainerComponent";
  6. import { LockObject } from "../lockObject";
  7. import { ImageBasedSlider } from "babylonjs-gui";
  8. import { FloatLineComponent } from "../../../lines/floatLineComponent";
  9. import { CheckBoxLineComponent } from "../../../lines/checkBoxLineComponent";
  10. import { TextInputLineComponent } from "../../../lines/textInputLineComponent";
  11. interface IImageBasedSliderPropertyGridComponentProps {
  12. imageBasedSlider: ImageBasedSlider,
  13. lockObject: LockObject,
  14. onPropertyChangedObservable?: Observable<PropertyChangedEvent>
  15. }
  16. export class ImageBasedSliderPropertyGridComponent extends React.Component<IImageBasedSliderPropertyGridComponentProps> {
  17. constructor(props: IImageBasedSliderPropertyGridComponentProps) {
  18. super(props);
  19. }
  20. render() {
  21. const imageBasedSlider = this.props.imageBasedSlider;
  22. return (
  23. <div className="pane">
  24. <CommonControlPropertyGridComponent lockObject={this.props.lockObject} control={imageBasedSlider} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  25. <LineContainerComponent title="IMAGE BASED SLIDER">
  26. <CheckBoxLineComponent label="Display thumb" target={imageBasedSlider} propertyName="displayThumb" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  27. <CheckBoxLineComponent label="Vertical" target={imageBasedSlider} propertyName="isVertical" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  28. <CheckBoxLineComponent label="Thumb clamped" target={imageBasedSlider} propertyName="isThumbClamped" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  29. <TextInputLineComponent lockObject={this.props.lockObject} label="Bar offset" target={imageBasedSlider} propertyName="barOffset" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  30. <TextInputLineComponent lockObject={this.props.lockObject} label="Thumb width" target={imageBasedSlider} propertyName="thumbWidth" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  31. <FloatLineComponent lockObject={this.props.lockObject} label="Minimum" target={imageBasedSlider} propertyName="minimum" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  32. <FloatLineComponent lockObject={this.props.lockObject} label="Maximum" target={imageBasedSlider} propertyName="maximum" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  33. <FloatLineComponent lockObject={this.props.lockObject} label="Value" target={imageBasedSlider} propertyName="value" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  34. </LineContainerComponent>
  35. </div>
  36. );
  37. }
  38. }