inputTextPropertyGridComponent.tsx 4.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  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 { InputText } from "babylonjs-gui/2D/controls/inputText";
  6. import { LineContainerComponent } from "../../../../../sharedUiComponents/lines/lineContainerComponent";
  7. import { TextInputLineComponent } from "../../../../../sharedUiComponents/lines/textInputLineComponent";
  8. import { SliderLineComponent } from "../../../../../sharedUiComponents/lines/sliderLineComponent";
  9. import { CheckBoxLineComponent } from "../../../../../sharedUiComponents/lines/checkBoxLineComponent";
  10. import { FloatLineComponent } from "../../../../../sharedUiComponents/lines/floatLineComponent";
  11. import { LockObject } from "../../../../../sharedUiComponents/tabs/propertyGrids/lockObject";
  12. import { GlobalState } from '../../../../globalState';
  13. interface IInputTextPropertyGridComponentProps {
  14. globalState: GlobalState;
  15. inputText: InputText;
  16. lockObject: LockObject;
  17. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  18. }
  19. export class InputTextPropertyGridComponent extends React.Component<IInputTextPropertyGridComponentProps> {
  20. constructor(props: IInputTextPropertyGridComponentProps) {
  21. super(props);
  22. }
  23. render() {
  24. const inputText = this.props.inputText;
  25. return (
  26. <div className="pane">
  27. <CommonControlPropertyGridComponent globalState={this.props.globalState} lockObject={this.props.lockObject} control={inputText} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  28. <LineContainerComponent title="INPUTTEXT">
  29. <TextInputLineComponent lockObject={this.props.lockObject} label="Text" target={inputText} propertyName="text" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  30. <TextInputLineComponent lockObject={this.props.lockObject} label="Prompt" target={inputText} propertyName="promptMessage" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  31. <TextInputLineComponent lockObject={this.props.lockObject} label="Max width" target={inputText} propertyName="maxWidth" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  32. <TextInputLineComponent lockObject={this.props.lockObject} label="Highlight color" target={inputText} propertyName="textHighlightColor" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  33. <SliderLineComponent label="Highligher opacity" minimum={0} maximum={1} step={0.01} target={inputText} propertyName="highligherOpacity" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  34. <CheckBoxLineComponent label="On focus select all" target={inputText} propertyName="onFocusSelectAll" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  35. <TextInputLineComponent lockObject={this.props.lockObject} label="Focused background" target={inputText} propertyName="focusedBackground" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  36. <TextInputLineComponent lockObject={this.props.lockObject} label="Max width" target={inputText} propertyName="maxWidth" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  37. <TextInputLineComponent lockObject={this.props.lockObject} label="Margin" target={inputText} propertyName="margin" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  38. <CheckBoxLineComponent label="Auto stretch width" target={inputText} propertyName="autoStretchWidth" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  39. <FloatLineComponent lockObject={this.props.lockObject} label="Thickness" target={inputText} propertyName="thickness" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  40. <TextInputLineComponent lockObject={this.props.lockObject} label="Placeholder text" target={inputText} propertyName="placeholderText" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  41. <TextInputLineComponent lockObject={this.props.lockObject} label="Placeholder color" target={inputText} propertyName="placeholderColor" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  42. </LineContainerComponent>
  43. </div>
  44. );
  45. }
  46. }