linePropertyGridComponent.tsx 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  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 { Line } from "babylonjs-gui";
  7. import { LineContainerComponent } from "../../../lineContainerComponent";
  8. import { FloatLineComponent } from "../../../lines/floatLineComponent";
  9. import { TextInputLineComponent } from "../../../lines/textInputLineComponent";
  10. interface ILinePropertyGridComponentProps {
  11. line: Line,
  12. lockObject: LockObject,
  13. onPropertyChangedObservable?: Observable<PropertyChangedEvent>
  14. }
  15. export class LinePropertyGridComponent extends React.Component<ILinePropertyGridComponentProps> {
  16. constructor(props: ILinePropertyGridComponentProps) {
  17. super(props);
  18. }
  19. onDashChange(value: string) {
  20. const line = this.props.line;
  21. const split = value.split(",");
  22. line.dash = [];
  23. split.forEach(v => {
  24. const int = parseInt(v);
  25. if (isNaN(int)) {
  26. return;
  27. }
  28. line.dash.push(int);
  29. });
  30. }
  31. render() {
  32. const line = this.props.line;
  33. return (
  34. <div className="pane">
  35. <CommonControlPropertyGridComponent lockObject={this.props.lockObject} control={line} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  36. <LineContainerComponent title="LINE">
  37. <FloatLineComponent lockObject={this.props.lockObject} label="Line width" target={line} propertyName="lineWidth" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  38. <TextInputLineComponent lockObject={this.props.lockObject} label="X1" target={line} propertyName="x1" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  39. <TextInputLineComponent lockObject={this.props.lockObject} label="Y1" target={line} propertyName="y1" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  40. <TextInputLineComponent lockObject={this.props.lockObject} label="X2" target={line} propertyName="x2" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  41. <TextInputLineComponent lockObject={this.props.lockObject} label="Y2" target={line} propertyName="y2" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  42. <TextInputLineComponent lockObject={this.props.lockObject} label="Dash pattern" target={line} value={line.dash.join(",")} onChange={newValue => this.onDashChange(newValue)} />
  43. </LineContainerComponent>
  44. </div>
  45. );
  46. }
  47. }