scrollViewerPropertyGridComponent.tsx 3.0 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 { LockObject } from "../lockObject";
  6. import { ScrollViewer } from "babylonjs-gui";
  7. import { LineContainerComponent } from "../../../lineContainerComponent";
  8. import { FloatLineComponent } from "../../../lines/floatLineComponent";
  9. import { TextInputLineComponent } from "../../../lines/textInputLineComponent";
  10. interface IScrollViewerPropertyGridComponentProps {
  11. scrollViewer: ScrollViewer,
  12. lockObject: LockObject,
  13. onPropertyChangedObservable?: Observable<PropertyChangedEvent>
  14. }
  15. export class ScrollViewerPropertyGridComponent extends React.Component<IScrollViewerPropertyGridComponentProps> {
  16. constructor(props: IScrollViewerPropertyGridComponentProps) {
  17. super(props);
  18. }
  19. render() {
  20. const scrollViewer = this.props.scrollViewer;
  21. return (
  22. <div className="pane">
  23. <CommonControlPropertyGridComponent lockObject={this.props.lockObject} control={scrollViewer} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  24. <LineContainerComponent title="RECTANGLE">
  25. <FloatLineComponent lockObject={this.props.lockObject} label="Thickness" target={scrollViewer} propertyName="thickness" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  26. <FloatLineComponent lockObject={this.props.lockObject} label="Corner radius" target={scrollViewer} propertyName="cornerRadius" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  27. </LineContainerComponent>
  28. <LineContainerComponent title="SCROLLVIEWER">
  29. <FloatLineComponent lockObject={this.props.lockObject} label="Bar size" target={scrollViewer} propertyName="barSize" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  30. <TextInputLineComponent lockObject={this.props.lockObject} label="Bar color" target={scrollViewer} propertyName="barColor" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  31. <TextInputLineComponent lockObject={this.props.lockObject} label="Bar border color" target={scrollViewer} propertyName="barBorderColor" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  32. <TextInputLineComponent lockObject={this.props.lockObject} label="Bar background" target={scrollViewer} propertyName="barBackground" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  33. <FloatLineComponent lockObject={this.props.lockObject} label="Wheel precision" target={scrollViewer} propertyName="wheelPrecision" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  34. </LineContainerComponent>
  35. </div>
  36. );
  37. }
  38. }