scrollViewerPropertyGridComponent.tsx 3.1 KB

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