babylon.guiEditor.module.d.ts 89 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434
  1. /// <reference types="react" />
  2. declare module "babylonjs-gui-editor/components/log/logComponent" {
  3. import * as React from "react";
  4. import { GlobalState } from "babylonjs-gui-editor/globalState";
  5. interface ILogComponentProps {
  6. globalState: GlobalState;
  7. }
  8. export class LogEntry {
  9. message: string;
  10. isError: boolean;
  11. constructor(message: string, isError: boolean);
  12. }
  13. export class LogComponent extends React.Component<ILogComponentProps, {
  14. logs: LogEntry[];
  15. }> {
  16. constructor(props: ILogComponentProps);
  17. componentDidMount(): void;
  18. componentDidUpdate(): void;
  19. render(): JSX.Element;
  20. }
  21. }
  22. declare module "babylonjs-gui-editor/diagram/workbench" {
  23. import * as React from "react";
  24. import { GlobalState } from "babylonjs-gui-editor/globalState";
  25. import { GUINode } from "babylonjs-gui-editor/diagram/guiNode";
  26. import { Control } from 'babylonjs-gui/2D/controls/control';
  27. export interface IWorkbenchComponentProps {
  28. globalState: GlobalState;
  29. }
  30. export type FramePortData = {};
  31. export const isFramePortData: (variableToCheck: any) => variableToCheck is FramePortData;
  32. export class WorkbenchComponent extends React.Component<IWorkbenchComponentProps> {
  33. private readonly MinZoom;
  34. private readonly MaxZoom;
  35. private _hostCanvas;
  36. private _gridCanvas;
  37. private _selectionContainer;
  38. private _frameContainer;
  39. private _svgCanvas;
  40. private _rootContainer;
  41. private _guiNodes;
  42. private _mouseStartPointX;
  43. private _mouseStartPointY;
  44. private _selectionStartX;
  45. private _selectionStartY;
  46. private _x;
  47. private _y;
  48. private _zoom;
  49. private _selectedGuiNodes;
  50. private _gridSize;
  51. private _selectionBox;
  52. private _frameCandidate;
  53. private _altKeyIsPressed;
  54. private _ctrlKeyIsPressed;
  55. private _oldY;
  56. _frameIsMoving: boolean;
  57. _isLoading: boolean;
  58. isOverGUINode: boolean;
  59. get gridSize(): number;
  60. set gridSize(value: number);
  61. get globalState(): GlobalState;
  62. get nodes(): GUINode[];
  63. get zoom(): number;
  64. set zoom(value: number);
  65. get x(): number;
  66. set x(value: number);
  67. get y(): number;
  68. set y(value: number);
  69. get selectedGuiNodes(): GUINode[];
  70. get canvasContainer(): HTMLDivElement;
  71. get hostCanvas(): HTMLDivElement;
  72. get svgCanvas(): HTMLElement;
  73. get selectionContainer(): HTMLDivElement;
  74. get frameContainer(): HTMLDivElement;
  75. constructor(props: IWorkbenchComponentProps);
  76. getGridPosition(position: number, useCeil?: boolean): number;
  77. getGridPositionCeil(position: number): number;
  78. updateTransform(): void;
  79. onKeyUp(): void;
  80. findNodeFromGuiElement(guiControl: Control): GUINode;
  81. reset(): void;
  82. appendBlock(guiElement: Control): GUINode;
  83. distributeGraph(): void;
  84. componentDidMount(): void;
  85. onMove(evt: React.PointerEvent): void;
  86. onDown(evt: React.PointerEvent<HTMLElement>): void;
  87. onUp(evt: React.PointerEvent): void;
  88. onWheel(evt: React.WheelEvent): void;
  89. zoomToFit(): void;
  90. createGUICanvas(): void;
  91. updateGUIs(): void;
  92. render(): JSX.Element;
  93. }
  94. }
  95. declare module "babylonjs-gui-editor/diagram/properties/propertyComponentProps" {
  96. import { Control } from "babylonjs-gui/2D/controls/control";
  97. import { GlobalState } from "babylonjs-gui-editor/globalState";
  98. export interface IPropertyComponentProps {
  99. globalState: GlobalState;
  100. guiControl: Control;
  101. }
  102. }
  103. declare module "babylonjs-gui-editor/sharedComponents/lineContainerComponent" {
  104. import * as React from "react";
  105. interface ILineContainerComponentProps {
  106. title: string;
  107. children: any[] | any;
  108. closed?: boolean;
  109. }
  110. export class LineContainerComponent extends React.Component<ILineContainerComponentProps, {
  111. isExpanded: boolean;
  112. }> {
  113. constructor(props: ILineContainerComponentProps);
  114. switchExpandedState(): void;
  115. renderHeader(): JSX.Element;
  116. render(): JSX.Element;
  117. }
  118. }
  119. declare module "babylonjs-gui-editor/sharedUiComponents/propertyChangedEvent" {
  120. export class PropertyChangedEvent {
  121. object: any;
  122. property: string;
  123. value: any;
  124. initialValue: any;
  125. allowNullValue?: boolean;
  126. }
  127. }
  128. declare module "babylonjs-gui-editor/sharedUiComponents/lines/checkBoxLineComponent" {
  129. import * as React from "react";
  130. import { Observable } from "babylonjs/Misc/observable";
  131. import { PropertyChangedEvent } from "babylonjs-gui-editor/sharedUiComponents/propertyChangedEvent";
  132. export interface ICheckBoxLineComponentProps {
  133. label: string;
  134. target?: any;
  135. propertyName?: string;
  136. isSelected?: () => boolean;
  137. onSelect?: (value: boolean) => void;
  138. onValueChanged?: () => void;
  139. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  140. disabled?: boolean;
  141. }
  142. export class CheckBoxLineComponent extends React.Component<ICheckBoxLineComponentProps, {
  143. isSelected: boolean;
  144. isDisabled?: boolean;
  145. }> {
  146. private static _UniqueIdSeed;
  147. private _uniqueId;
  148. private _localChange;
  149. constructor(props: ICheckBoxLineComponentProps);
  150. shouldComponentUpdate(nextProps: ICheckBoxLineComponentProps, nextState: {
  151. isSelected: boolean;
  152. isDisabled: boolean;
  153. }): boolean;
  154. onChange(): void;
  155. render(): JSX.Element;
  156. }
  157. }
  158. declare module "babylonjs-gui-editor/sharedComponents/propertyChangedEvent" {
  159. export class PropertyChangedEvent {
  160. object: any;
  161. property: string;
  162. value: any;
  163. initialValue: any;
  164. }
  165. }
  166. declare module "babylonjs-gui-editor/sharedComponents/floatLineComponent" {
  167. import * as React from "react";
  168. import { Observable } from "babylonjs/Misc/observable";
  169. import { PropertyChangedEvent } from "babylonjs-gui-editor/sharedComponents/propertyChangedEvent";
  170. import { GlobalState } from "babylonjs-gui-editor/globalState";
  171. interface IFloatLineComponentProps {
  172. label: string;
  173. target: any;
  174. propertyName: string;
  175. onChange?: (newValue: number) => void;
  176. isInteger?: boolean;
  177. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  178. additionalClass?: string;
  179. step?: string;
  180. digits?: number;
  181. globalState: GlobalState;
  182. min?: number;
  183. max?: number;
  184. smallUI?: boolean;
  185. onEnter?: (newValue: number) => void;
  186. }
  187. export class FloatLineComponent extends React.Component<IFloatLineComponentProps, {
  188. value: string;
  189. }> {
  190. private _localChange;
  191. private _store;
  192. private _regExp;
  193. private _digits;
  194. constructor(props: IFloatLineComponentProps);
  195. shouldComponentUpdate(nextProps: IFloatLineComponentProps, nextState: {
  196. value: string;
  197. }): boolean;
  198. raiseOnPropertyChanged(newValue: number, previousValue: number): void;
  199. updateValue(valueString: string): void;
  200. render(): JSX.Element;
  201. }
  202. }
  203. declare module "babylonjs-gui-editor/sharedComponents/sliderLineComponent" {
  204. import * as React from "react";
  205. import { Observable } from "babylonjs/Misc/observable";
  206. import { PropertyChangedEvent } from "babylonjs-gui-editor/sharedComponents/propertyChangedEvent";
  207. import { GlobalState } from "babylonjs-gui-editor/globalState";
  208. interface ISliderLineComponentProps {
  209. label: string;
  210. target?: any;
  211. propertyName?: string;
  212. minimum: number;
  213. maximum: number;
  214. step: number;
  215. directValue?: number;
  216. useEuler?: boolean;
  217. onChange?: (value: number) => void;
  218. onInput?: (value: number) => void;
  219. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  220. decimalCount?: number;
  221. globalState: GlobalState;
  222. }
  223. export class SliderLineComponent extends React.Component<ISliderLineComponentProps, {
  224. value: number;
  225. }> {
  226. private _localChange;
  227. constructor(props: ISliderLineComponentProps);
  228. shouldComponentUpdate(nextProps: ISliderLineComponentProps, nextState: {
  229. value: number;
  230. }): boolean;
  231. onChange(newValueString: any): void;
  232. onInput(newValueString: any): void;
  233. prepareDataToRead(value: number): number;
  234. render(): JSX.Element;
  235. }
  236. }
  237. declare module "babylonjs-gui-editor/diagram/properties/genericNodePropertyComponent" {
  238. import * as React from "react";
  239. import { IPropertyComponentProps } from "babylonjs-gui-editor/diagram/properties/propertyComponentProps";
  240. export class GenericPropertyComponent extends React.Component<IPropertyComponentProps> {
  241. constructor(props: IPropertyComponentProps);
  242. render(): JSX.Element;
  243. }
  244. export class GeneralPropertyTabComponent extends React.Component<IPropertyComponentProps> {
  245. constructor(props: IPropertyComponentProps);
  246. render(): JSX.Element;
  247. }
  248. export class GenericPropertyTabComponent extends React.Component<IPropertyComponentProps> {
  249. constructor(props: IPropertyComponentProps);
  250. forceRebuild(notifiers?: {
  251. "rebuild"?: boolean;
  252. "update"?: boolean;
  253. }): void;
  254. render(): JSX.Element;
  255. }
  256. }
  257. declare module "babylonjs-gui-editor/sharedComponents/numericInputComponent" {
  258. import * as React from "react";
  259. import { GlobalState } from "babylonjs-gui-editor/globalState";
  260. interface INumericInputComponentProps {
  261. label: string;
  262. value: number;
  263. step?: number;
  264. onChange: (value: number) => void;
  265. globalState: GlobalState;
  266. }
  267. export class NumericInputComponent extends React.Component<INumericInputComponentProps, {
  268. value: string;
  269. }> {
  270. static defaultProps: {
  271. step: number;
  272. };
  273. private _localChange;
  274. constructor(props: INumericInputComponentProps);
  275. shouldComponentUpdate(nextProps: INumericInputComponentProps, nextState: {
  276. value: string;
  277. }): boolean;
  278. updateValue(evt: any): void;
  279. render(): JSX.Element;
  280. }
  281. }
  282. declare module "babylonjs-gui-editor/sharedUiComponents/lines/textLineComponent" {
  283. import * as React from "react";
  284. interface ITextLineComponentProps {
  285. label?: string;
  286. value?: string;
  287. color?: string;
  288. underline?: boolean;
  289. onLink?: () => void;
  290. url?: string;
  291. ignoreValue?: boolean;
  292. additionalClass?: string;
  293. }
  294. export class TextLineComponent extends React.Component<ITextLineComponentProps> {
  295. constructor(props: ITextLineComponentProps);
  296. onLink(): void;
  297. renderContent(): JSX.Element | null;
  298. render(): JSX.Element;
  299. }
  300. }
  301. declare module "babylonjs-gui-editor/diagram/properties/sliderGuiPropertyComponent" {
  302. import * as React from "react";
  303. import { IPropertyComponentProps } from "babylonjs-gui-editor/diagram/properties/propertyComponentProps";
  304. export class SliderPropertyTabComponent extends React.Component<IPropertyComponentProps> {
  305. constructor(props: IPropertyComponentProps);
  306. private _slider;
  307. render(): JSX.Element;
  308. }
  309. }
  310. declare module "babylonjs-gui-editor/diagram/propertyLedger" {
  311. import { ComponentClass } from 'react';
  312. import { IPropertyComponentProps } from "babylonjs-gui-editor/diagram/properties/propertyComponentProps";
  313. export class PropertyGuiLedger {
  314. static RegisteredControls: {
  315. [key: string]: ComponentClass<IPropertyComponentProps>;
  316. };
  317. }
  318. }
  319. declare module "babylonjs-gui-editor/diagram/guiNode" {
  320. import { GlobalState } from "babylonjs-gui-editor/globalState";
  321. import { Nullable } from 'babylonjs/types';
  322. import { Control } from 'babylonjs-gui/2D/controls/control';
  323. import { Vector2 } from 'babylonjs/Maths/math.vector';
  324. export class GUINode {
  325. guiControl: Control;
  326. private _x;
  327. private _y;
  328. private _gridAlignedX;
  329. private _gridAlignedY;
  330. private _globalState;
  331. private _onSelectionChangedObserver;
  332. private _onSelectionBoxMovedObserver;
  333. private _onUpdateRequiredObserver;
  334. private _ownerCanvas;
  335. private _isSelected;
  336. private _isVisible;
  337. private _enclosingFrameId;
  338. get isVisible(): boolean;
  339. set isVisible(value: boolean);
  340. get gridAlignedX(): number;
  341. get gridAlignedY(): number;
  342. get x(): number;
  343. set x(value: number);
  344. get y(): number;
  345. set y(value: number);
  346. get width(): number;
  347. get height(): number;
  348. get id(): number;
  349. get name(): string | undefined;
  350. get isSelected(): boolean;
  351. get enclosingFrameId(): number;
  352. set enclosingFrameId(value: number);
  353. set isSelected(value: boolean);
  354. constructor(globalState: GlobalState, guiControl: Control);
  355. cleanAccumulation(useCeil?: boolean): void;
  356. clicked: boolean;
  357. _onMove(evt: Vector2, startPos: Vector2): boolean;
  358. renderProperties(): Nullable<JSX.Element>;
  359. updateVisual(): void;
  360. dispose(): void;
  361. }
  362. }
  363. declare module "babylonjs-gui-editor/globalState" {
  364. import { Nullable } from "babylonjs/types";
  365. import { Observable } from "babylonjs/Misc/observable";
  366. import { LogEntry } from "babylonjs-gui-editor/components/log/logComponent";
  367. import { Color4 } from "babylonjs/Maths/math.color";
  368. import { GUINode } from "babylonjs-gui-editor/diagram/guiNode";
  369. import { WorkbenchComponent } from "babylonjs-gui-editor/diagram/workbench";
  370. import { AdvancedDynamicTexture } from "babylonjs-gui/2D/advancedDynamicTexture";
  371. export class GlobalState {
  372. guiTexture: AdvancedDynamicTexture;
  373. hostElement: HTMLElement;
  374. hostDocument: HTMLDocument;
  375. hostWindow: Window;
  376. onSelectionChangedObservable: Observable<Nullable<GUINode>>;
  377. onRebuildRequiredObservable: Observable<void>;
  378. onBuiltObservable: Observable<void>;
  379. onResetRequiredObservable: Observable<void>;
  380. onUpdateRequiredObservable: Observable<void>;
  381. onReOrganizedRequiredObservable: Observable<void>;
  382. onLogRequiredObservable: Observable<LogEntry>;
  383. onErrorMessageDialogRequiredObservable: Observable<string>;
  384. onIsLoadingChanged: Observable<boolean>;
  385. onSelectionBoxMoved: Observable<DOMRect | ClientRect>;
  386. onGuiNodeRemovalObservable: Observable<GUINode>;
  387. backgroundColor: Color4;
  388. blockKeyboardEvents: boolean;
  389. controlCamera: boolean;
  390. workbench: WorkbenchComponent;
  391. storeEditorData: (serializationObject: any) => void;
  392. customSave?: {
  393. label: string;
  394. action: (data: string) => Promise<void>;
  395. };
  396. constructor();
  397. }
  398. }
  399. declare module "babylonjs-gui-editor/sharedUiComponents/lines/draggableLineComponent" {
  400. import * as React from "react";
  401. export interface IButtonLineComponentProps {
  402. data: string;
  403. tooltip: string;
  404. }
  405. export class DraggableLineComponent extends React.Component<IButtonLineComponentProps> {
  406. constructor(props: IButtonLineComponentProps);
  407. render(): JSX.Element;
  408. }
  409. }
  410. declare module "babylonjs-gui-editor/components/guiList/guiListComponent" {
  411. import * as React from "react";
  412. import { GlobalState } from "babylonjs-gui-editor/globalState";
  413. interface IGuiListComponentProps {
  414. globalState: GlobalState;
  415. }
  416. export class GuiListComponent extends React.Component<IGuiListComponentProps, {
  417. filter: string;
  418. }> {
  419. private _onResetRequiredObserver;
  420. private static _Tooltips;
  421. constructor(props: IGuiListComponentProps);
  422. componentWillUnmount(): void;
  423. filterContent(filter: string): void;
  424. render(): JSX.Element;
  425. }
  426. }
  427. declare module "babylonjs-gui-editor/sharedUiComponents/lines/buttonLineComponent" {
  428. import * as React from "react";
  429. export interface IButtonLineComponentProps {
  430. label: string;
  431. onClick: () => void;
  432. }
  433. export class ButtonLineComponent extends React.Component<IButtonLineComponentProps> {
  434. constructor(props: IButtonLineComponentProps);
  435. render(): JSX.Element;
  436. }
  437. }
  438. declare module "babylonjs-gui-editor/sharedUiComponents/lines/fileButtonLineComponent" {
  439. import * as React from "react";
  440. interface IFileButtonLineComponentProps {
  441. label: string;
  442. onClick: (file: File) => void;
  443. accept: string;
  444. }
  445. export class FileButtonLineComponent extends React.Component<IFileButtonLineComponentProps> {
  446. private static _IDGenerator;
  447. private _id;
  448. private uploadInputRef;
  449. constructor(props: IFileButtonLineComponentProps);
  450. onChange(evt: any): void;
  451. render(): JSX.Element;
  452. }
  453. }
  454. declare module "babylonjs-gui-editor/serializationTools" {
  455. import { GlobalState } from "babylonjs-gui-editor/globalState";
  456. export class SerializationTools {
  457. static Deserialize(serializationObject: any, globalState: GlobalState): void;
  458. }
  459. }
  460. declare module "babylonjs-gui-editor/components/propertyTab/propertyTabComponent" {
  461. import * as React from "react";
  462. import { GlobalState } from "babylonjs-gui-editor/globalState";
  463. import { Nullable } from 'babylonjs/types';
  464. import { GUINode } from "babylonjs-gui-editor/diagram/guiNode";
  465. interface IPropertyTabComponentProps {
  466. globalState: GlobalState;
  467. }
  468. interface IPropertyTabComponentState {
  469. currentNode: Nullable<GUINode>;
  470. }
  471. export class PropertyTabComponent extends React.Component<IPropertyTabComponentProps, IPropertyTabComponentState> {
  472. private _onBuiltObserver;
  473. constructor(props: IPropertyTabComponentProps);
  474. componentDidMount(): void;
  475. componentWillUnmount(): void;
  476. load(file: File): void;
  477. loadFrame(file: File): void;
  478. save(): void;
  479. customSave(): void;
  480. saveToSnippetServer(): void;
  481. loadFromSnippet(): void;
  482. render(): JSX.Element;
  483. }
  484. }
  485. declare module "babylonjs-gui-editor/portal" {
  486. import * as React from "react";
  487. import { GlobalState } from "babylonjs-gui-editor/globalState";
  488. interface IPortalProps {
  489. globalState: GlobalState;
  490. }
  491. export class Portal extends React.Component<IPortalProps> {
  492. render(): React.ReactPortal;
  493. }
  494. }
  495. declare module "babylonjs-gui-editor/guiNodeTools" {
  496. import { Checkbox } from "babylonjs-gui/2D/controls/checkbox";
  497. import { ColorPicker } from "babylonjs-gui/2D/controls/colorpicker";
  498. import { Ellipse } from "babylonjs-gui/2D/controls/ellipse";
  499. import { Line } from "babylonjs-gui/2D/controls/line";
  500. import { Rectangle } from "babylonjs-gui/2D/controls/rectangle";
  501. import { Slider } from "babylonjs-gui/2D/controls/sliders/slider";
  502. import { TextBlock } from "babylonjs-gui/2D/controls/textBlock";
  503. export class GUINodeTools {
  504. static CreateControlFromString(data: string): Slider | Checkbox | ColorPicker | Ellipse | Rectangle | Line | TextBlock;
  505. }
  506. }
  507. declare module "babylonjs-gui-editor/nodeLocationInfo" {
  508. export interface INodeLocationInfo {
  509. blockId: number;
  510. x: number;
  511. y: number;
  512. }
  513. export interface IFrameData {
  514. x: number;
  515. y: number;
  516. width: number;
  517. height: number;
  518. color: number[];
  519. name: string;
  520. isCollapsed: boolean;
  521. blocks: number[];
  522. comments: string;
  523. }
  524. export interface IEditorData {
  525. locations: INodeLocationInfo[];
  526. x: number;
  527. y: number;
  528. zoom: number;
  529. frames?: IFrameData[];
  530. map?: {
  531. [key: number]: number;
  532. };
  533. }
  534. }
  535. declare module "babylonjs-gui-editor/sharedComponents/messageDialog" {
  536. import * as React from "react";
  537. import { GlobalState } from "babylonjs-gui-editor/globalState";
  538. interface IMessageDialogComponentProps {
  539. globalState: GlobalState;
  540. }
  541. export class MessageDialogComponent extends React.Component<IMessageDialogComponentProps, {
  542. message: string;
  543. isError: boolean;
  544. }> {
  545. constructor(props: IMessageDialogComponentProps);
  546. render(): JSX.Element | null;
  547. }
  548. }
  549. declare module "babylonjs-gui-editor/workbenchEditor" {
  550. import * as React from "react";
  551. import { GlobalState } from "babylonjs-gui-editor/globalState";
  552. import { Nullable } from "babylonjs/types";
  553. import { IEditorData } from "babylonjs-gui-editor/nodeLocationInfo";
  554. import { GUINode } from "babylonjs-gui-editor/diagram/guiNode";
  555. import { Control } from "babylonjs-gui/2D/controls/control";
  556. interface IGraphEditorProps {
  557. globalState: GlobalState;
  558. }
  559. interface IGraphEditorState {
  560. showPreviewPopUp: boolean;
  561. }
  562. export class WorkbenchEditor extends React.Component<IGraphEditorProps, IGraphEditorState> {
  563. private _workbenchCanvas;
  564. private _startX;
  565. private _moveInProgress;
  566. private _leftWidth;
  567. private _rightWidth;
  568. private _blocks;
  569. private _onWidgetKeyUpPointer;
  570. private _popUpWindow;
  571. /**
  572. * Creates a node and recursivly creates its parent nodes from it's input
  573. * @param block
  574. */
  575. createNodeFromObject(block: Control, recursion?: boolean): Nullable<GUINode>;
  576. componentDidMount(): void;
  577. componentWillUnmount(): void;
  578. constructor(props: IGraphEditorProps);
  579. pasteSelection(copiedNodes: GUINode[], currentX: number, currentY: number, selectNew?: boolean): GUINode[];
  580. zoomToFit(): void;
  581. showWaitScreen(): void;
  582. hideWaitScreen(): void;
  583. reOrganize(editorData?: Nullable<IEditorData>, isImportingAFrame?: boolean): void;
  584. onPointerDown(evt: React.PointerEvent<HTMLDivElement>): void;
  585. onPointerUp(evt: React.PointerEvent<HTMLDivElement>): void;
  586. resizeColumns(evt: React.PointerEvent<HTMLDivElement>, forLeft?: boolean): void;
  587. buildColumnLayout(): string;
  588. emitNewBlock(event: React.DragEvent<HTMLDivElement>): void;
  589. handlePopUp: () => void;
  590. handleClosingPopUp: () => void;
  591. createPopupWindow: (title: string, windowVariableName: string, width?: number, height?: number) => Window | null;
  592. copyStyles: (sourceDoc: HTMLDocument, targetDoc: HTMLDocument) => void;
  593. fixPopUpStyles: (document: Document) => void;
  594. render(): JSX.Element;
  595. }
  596. }
  597. declare module "babylonjs-gui-editor/sharedUiComponents/lines/popup" {
  598. export class Popup {
  599. static CreatePopup(title: string, windowVariableName: string, width?: number, height?: number): HTMLDivElement | null;
  600. private static _CopyStyles;
  601. }
  602. }
  603. declare module "babylonjs-gui-editor/guiEditor" {
  604. import { Observable } from "babylonjs/Misc/observable";
  605. /**
  606. * Interface used to specify creation options for the gui editor
  607. */
  608. export interface IGUIEditorOptions {
  609. hostElement?: HTMLElement;
  610. customSave?: {
  611. label: string;
  612. action: (data: string) => Promise<void>;
  613. };
  614. customLoadObservable?: Observable<any>;
  615. }
  616. /**
  617. * Class used to create a gui editor
  618. */
  619. export class GUIEditor {
  620. private static _CurrentState;
  621. /**
  622. * Show the gui editor
  623. * @param options defines the options to use to configure the gui editor
  624. */
  625. static Show(options: IGUIEditorOptions): void;
  626. }
  627. }
  628. declare module "babylonjs-gui-editor/index" {
  629. export * from "babylonjs-gui-editor/guiEditor";
  630. }
  631. declare module "babylonjs-gui-editor/legacy/legacy" {
  632. export * from "babylonjs-gui-editor/index";
  633. }
  634. declare module "babylonjs-gui-editor/sharedComponents/lineWithFileButtonComponent" {
  635. import * as React from "react";
  636. interface ILineWithFileButtonComponentProps {
  637. title: string;
  638. closed?: boolean;
  639. label: string;
  640. iconImage: any;
  641. onIconClick: (file: File) => void;
  642. accept: string;
  643. uploadName?: string;
  644. }
  645. export class LineWithFileButtonComponent extends React.Component<ILineWithFileButtonComponentProps, {
  646. isExpanded: boolean;
  647. }> {
  648. private uploadRef;
  649. constructor(props: ILineWithFileButtonComponentProps);
  650. onChange(evt: any): void;
  651. switchExpandedState(): void;
  652. render(): JSX.Element;
  653. }
  654. }
  655. declare module "babylonjs-gui-editor/sharedComponents/textInputLineComponent" {
  656. import * as React from "react";
  657. import { Observable } from "babylonjs/Misc/observable";
  658. import { PropertyChangedEvent } from "babylonjs-gui-editor/sharedComponents/propertyChangedEvent";
  659. import { GlobalState } from "babylonjs-gui-editor/globalState";
  660. interface ITextInputLineComponentProps {
  661. label: string;
  662. globalState: GlobalState;
  663. target?: any;
  664. propertyName?: string;
  665. value?: string;
  666. multilines?: boolean;
  667. onChange?: (value: string) => void;
  668. validator?: (value: string) => boolean;
  669. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  670. }
  671. export class TextInputLineComponent extends React.Component<ITextInputLineComponentProps, {
  672. value: string;
  673. }> {
  674. private _localChange;
  675. constructor(props: ITextInputLineComponentProps);
  676. shouldComponentUpdate(nextProps: ITextInputLineComponentProps, nextState: {
  677. value: string;
  678. }): boolean;
  679. raiseOnPropertyChanged(newValue: string, previousValue: string): void;
  680. updateValue(value: string, raisePropertyChanged: boolean): void;
  681. render(): JSX.Element;
  682. }
  683. }
  684. declare module "babylonjs-gui-editor/sharedUiComponents/colorPicker/colorComponentEntry" {
  685. import * as React from "react";
  686. export interface IColorComponentEntryProps {
  687. value: number;
  688. label: string;
  689. max?: number;
  690. min?: number;
  691. onChange: (value: number) => void;
  692. }
  693. export class ColorComponentEntry extends React.Component<IColorComponentEntryProps> {
  694. constructor(props: IColorComponentEntryProps);
  695. updateValue(valueString: string): void;
  696. render(): JSX.Element;
  697. }
  698. }
  699. declare module "babylonjs-gui-editor/sharedUiComponents/colorPicker/hexColor" {
  700. import * as React from "react";
  701. export interface IHexColorProps {
  702. value: string;
  703. expectedLength: number;
  704. onChange: (value: string) => void;
  705. }
  706. export class HexColor extends React.Component<IHexColorProps, {
  707. hex: string;
  708. }> {
  709. constructor(props: IHexColorProps);
  710. shouldComponentUpdate(nextProps: IHexColorProps, nextState: {
  711. hex: string;
  712. }): boolean;
  713. updateHexValue(valueString: string): void;
  714. render(): JSX.Element;
  715. }
  716. }
  717. declare module "babylonjs-gui-editor/sharedUiComponents/colorPicker/colorPicker" {
  718. import * as React from "react";
  719. import { Color3, Color4 } from "babylonjs/Maths/math.color";
  720. /**
  721. * Interface used to specify creation options for color picker
  722. */
  723. export interface IColorPickerProps {
  724. color: Color3 | Color4;
  725. debugMode?: boolean;
  726. onColorChanged?: (color: Color3 | Color4) => void;
  727. }
  728. /**
  729. * Interface used to specify creation options for color picker
  730. */
  731. export interface IColorPickerState {
  732. color: Color3;
  733. alpha: number;
  734. }
  735. /**
  736. * Class used to create a color picker
  737. */
  738. export class ColorPicker extends React.Component<IColorPickerProps, IColorPickerState> {
  739. private _saturationRef;
  740. private _hueRef;
  741. private _isSaturationPointerDown;
  742. private _isHuePointerDown;
  743. constructor(props: IColorPickerProps);
  744. onSaturationPointerDown(evt: React.PointerEvent<HTMLDivElement>): void;
  745. onSaturationPointerUp(evt: React.PointerEvent<HTMLDivElement>): void;
  746. onSaturationPointerMove(evt: React.PointerEvent<HTMLDivElement>): void;
  747. onHuePointerDown(evt: React.PointerEvent<HTMLDivElement>): void;
  748. onHuePointerUp(evt: React.PointerEvent<HTMLDivElement>): void;
  749. onHuePointerMove(evt: React.PointerEvent<HTMLDivElement>): void;
  750. private _evaluateSaturation;
  751. private _evaluateHue;
  752. componentDidUpdate(): void;
  753. raiseOnColorChanged(): void;
  754. render(): JSX.Element;
  755. }
  756. }
  757. declare module "babylonjs-gui-editor/sharedUiComponents/lines/booleanLineComponent" {
  758. import * as React from "react";
  759. export interface IBooleanLineComponentProps {
  760. label: string;
  761. value: boolean;
  762. }
  763. export class BooleanLineComponent extends React.Component<IBooleanLineComponentProps> {
  764. constructor(props: IBooleanLineComponentProps);
  765. render(): JSX.Element;
  766. }
  767. }
  768. declare module "babylonjs-gui-editor/sharedUiComponents/lines/numericInputComponent" {
  769. import * as React from "react";
  770. interface INumericInputComponentProps {
  771. label: string;
  772. value: number;
  773. step?: number;
  774. onChange: (value: number) => void;
  775. precision?: number;
  776. }
  777. export class NumericInputComponent extends React.Component<INumericInputComponentProps, {
  778. value: string;
  779. }> {
  780. static defaultProps: {
  781. step: number;
  782. };
  783. private _localChange;
  784. constructor(props: INumericInputComponentProps);
  785. shouldComponentUpdate(nextProps: INumericInputComponentProps, nextState: {
  786. value: string;
  787. }): boolean;
  788. updateValue(evt: any): void;
  789. onBlur(): void;
  790. render(): JSX.Element;
  791. }
  792. }
  793. declare module "babylonjs-gui-editor/sharedUiComponents/lines/colorPickerComponent" {
  794. import * as React from "react";
  795. import { Color4, Color3 } from 'babylonjs/Maths/math.color';
  796. export interface IColorPickerComponentProps {
  797. value: Color4 | Color3;
  798. onColorChanged: (newOne: string) => void;
  799. }
  800. interface IColorPickerComponentState {
  801. pickerEnabled: boolean;
  802. color: Color3 | Color4;
  803. hex: string;
  804. }
  805. export class ColorPickerLineComponent extends React.Component<IColorPickerComponentProps, IColorPickerComponentState> {
  806. private _floatRef;
  807. private _floatHostRef;
  808. constructor(props: IColorPickerComponentProps);
  809. syncPositions(): void;
  810. shouldComponentUpdate(nextProps: IColorPickerComponentProps, nextState: IColorPickerComponentState): boolean;
  811. componentDidUpdate(): void;
  812. componentDidMount(): void;
  813. render(): JSX.Element;
  814. }
  815. }
  816. declare module "babylonjs-gui-editor/sharedUiComponents/lines/color3LineComponent" {
  817. import * as React from "react";
  818. import { Observable } from "babylonjs/Misc/observable";
  819. import { PropertyChangedEvent } from "babylonjs-gui-editor/sharedUiComponents/propertyChangedEvent";
  820. import { Color3 } from 'babylonjs/Maths/math.color';
  821. export interface IColor3LineComponentProps {
  822. label: string;
  823. target: any;
  824. propertyName: string;
  825. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  826. isLinear?: boolean;
  827. }
  828. export class Color3LineComponent extends React.Component<IColor3LineComponentProps, {
  829. isExpanded: boolean;
  830. color: Color3;
  831. }> {
  832. private _localChange;
  833. constructor(props: IColor3LineComponentProps);
  834. shouldComponentUpdate(nextProps: IColor3LineComponentProps, nextState: {
  835. color: Color3;
  836. }): boolean;
  837. setPropertyValue(newColor: Color3): void;
  838. onChange(newValue: string): void;
  839. switchExpandState(): void;
  840. raiseOnPropertyChanged(previousValue: Color3): void;
  841. updateStateR(value: number): void;
  842. updateStateG(value: number): void;
  843. updateStateB(value: number): void;
  844. copyToClipboard(): void;
  845. render(): JSX.Element;
  846. }
  847. }
  848. declare module "babylonjs-gui-editor/sharedUiComponents/lines/color4LineComponent" {
  849. import * as React from "react";
  850. import { Observable } from "babylonjs/Misc/observable";
  851. import { Color4 } from "babylonjs/Maths/math.color";
  852. import { PropertyChangedEvent } from "babylonjs-gui-editor/sharedUiComponents/propertyChangedEvent";
  853. export interface IColor4LineComponentProps {
  854. label: string;
  855. target: any;
  856. propertyName: string;
  857. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  858. onChange?: () => void;
  859. isLinear?: boolean;
  860. }
  861. export class Color4LineComponent extends React.Component<IColor4LineComponentProps, {
  862. isExpanded: boolean;
  863. color: Color4;
  864. }> {
  865. private _localChange;
  866. constructor(props: IColor4LineComponentProps);
  867. shouldComponentUpdate(nextProps: IColor4LineComponentProps, nextState: {
  868. color: Color4;
  869. }): boolean;
  870. setPropertyValue(newColor: Color4): void;
  871. onChange(newValue: string): void;
  872. switchExpandState(): void;
  873. raiseOnPropertyChanged(previousValue: Color4): void;
  874. updateStateR(value: number): void;
  875. updateStateG(value: number): void;
  876. updateStateB(value: number): void;
  877. updateStateA(value: number): void;
  878. copyToClipboard(): void;
  879. render(): JSX.Element;
  880. }
  881. }
  882. declare module "babylonjs-gui-editor/sharedUiComponents/lines/fileMultipleButtonLineComponent" {
  883. import * as React from "react";
  884. interface IFileMultipleButtonLineComponentProps {
  885. label: string;
  886. onClick: (event: any) => void;
  887. accept: string;
  888. }
  889. export class FileMultipleButtonLineComponent extends React.Component<IFileMultipleButtonLineComponentProps> {
  890. private static _IDGenerator;
  891. private _id;
  892. private uploadInputRef;
  893. constructor(props: IFileMultipleButtonLineComponentProps);
  894. onChange(evt: any): void;
  895. render(): JSX.Element;
  896. }
  897. }
  898. declare module "babylonjs-gui-editor/sharedUiComponents/tabs/propertyGrids/lockObject" {
  899. /**
  900. * Class used to provide lock mechanism
  901. */
  902. export class LockObject {
  903. /**
  904. * Gets or set if the lock is engaged
  905. */
  906. lock: boolean;
  907. }
  908. }
  909. declare module "babylonjs-gui-editor/sharedUiComponents/lines/sliderLineComponent" {
  910. import * as React from "react";
  911. import { Observable } from "babylonjs/Misc/observable";
  912. import { PropertyChangedEvent } from "babylonjs-gui-editor/sharedUiComponents/propertyChangedEvent";
  913. interface ISliderLineComponentProps {
  914. label: string;
  915. target?: any;
  916. propertyName?: string;
  917. minimum: number;
  918. maximum: number;
  919. step: number;
  920. directValue?: number;
  921. useEuler?: boolean;
  922. onChange?: (value: number) => void;
  923. onInput?: (value: number) => void;
  924. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  925. decimalCount?: number;
  926. margin?: boolean;
  927. }
  928. export class SliderLineComponent extends React.Component<ISliderLineComponentProps, {
  929. value: number;
  930. }> {
  931. private _localChange;
  932. constructor(props: ISliderLineComponentProps);
  933. shouldComponentUpdate(nextProps: ISliderLineComponentProps, nextState: {
  934. value: number;
  935. }): boolean;
  936. onChange(newValueString: any): void;
  937. onInput(newValueString: any): void;
  938. prepareDataToRead(value: number): number;
  939. render(): JSX.Element;
  940. }
  941. }
  942. declare module "babylonjs-gui-editor/sharedUiComponents/lines/floatLineComponent" {
  943. import * as React from "react";
  944. import { Observable } from "babylonjs/Misc/observable";
  945. import { PropertyChangedEvent } from "babylonjs-gui-editor/sharedUiComponents/propertyChangedEvent";
  946. import { LockObject } from "babylonjs-gui-editor/sharedUiComponents/tabs/propertyGrids/lockObject";
  947. interface IFloatLineComponentProps {
  948. label: string;
  949. target: any;
  950. propertyName: string;
  951. lockObject?: LockObject;
  952. onChange?: (newValue: number) => void;
  953. isInteger?: boolean;
  954. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  955. additionalClass?: string;
  956. step?: string;
  957. digits?: number;
  958. useEuler?: boolean;
  959. min?: number;
  960. max?: number;
  961. smallUI?: boolean;
  962. onEnter?: (newValue: number) => void;
  963. }
  964. export class FloatLineComponent extends React.Component<IFloatLineComponentProps, {
  965. value: string;
  966. }> {
  967. private _localChange;
  968. private _store;
  969. constructor(props: IFloatLineComponentProps);
  970. componentWillUnmount(): void;
  971. shouldComponentUpdate(nextProps: IFloatLineComponentProps, nextState: {
  972. value: string;
  973. }): boolean;
  974. raiseOnPropertyChanged(newValue: number, previousValue: number): void;
  975. updateValue(valueString: string): void;
  976. lock(): void;
  977. unlock(): void;
  978. render(): JSX.Element;
  979. }
  980. }
  981. declare module "babylonjs-gui-editor/sharedUiComponents/lines/hexLineComponent" {
  982. import * as React from "react";
  983. import { Observable } from "babylonjs/Misc/observable";
  984. import { PropertyChangedEvent } from "babylonjs-gui-editor/sharedUiComponents/propertyChangedEvent";
  985. import { LockObject } from "babylonjs-gui-editor/sharedUiComponents/tabs/propertyGrids/lockObject";
  986. interface IHexLineComponentProps {
  987. label: string;
  988. target: any;
  989. propertyName: string;
  990. lockObject?: LockObject;
  991. onChange?: (newValue: number) => void;
  992. isInteger?: boolean;
  993. replaySourceReplacement?: string;
  994. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  995. additionalClass?: string;
  996. step?: string;
  997. digits?: number;
  998. useEuler?: boolean;
  999. min?: number;
  1000. }
  1001. export class HexLineComponent extends React.Component<IHexLineComponentProps, {
  1002. value: string;
  1003. }> {
  1004. private _localChange;
  1005. private _store;
  1006. private _propertyChange;
  1007. constructor(props: IHexLineComponentProps);
  1008. componentWillUnmount(): void;
  1009. shouldComponentUpdate(nextProps: IHexLineComponentProps, nextState: {
  1010. value: string;
  1011. }): boolean;
  1012. raiseOnPropertyChanged(newValue: number, previousValue: number): void;
  1013. convertToHexString(valueString: string): string;
  1014. updateValue(valueString: string, raisePropertyChanged: boolean): void;
  1015. lock(): void;
  1016. unlock(): void;
  1017. render(): JSX.Element;
  1018. }
  1019. }
  1020. declare module "babylonjs-gui-editor/sharedUiComponents/lines/iconButtonLineComponent" {
  1021. import * as React from 'react';
  1022. export interface IIconButtonLineComponentProps {
  1023. icon: string;
  1024. onClick: () => void;
  1025. tooltip: string;
  1026. active?: boolean;
  1027. }
  1028. export class IconButtonLineComponent extends React.Component<IIconButtonLineComponentProps> {
  1029. constructor(props: IIconButtonLineComponentProps);
  1030. render(): JSX.Element;
  1031. }
  1032. }
  1033. declare module "babylonjs-gui-editor/sharedUiComponents/lines/indentedTextLineComponent" {
  1034. import * as React from "react";
  1035. interface IIndentedTextLineComponentProps {
  1036. value?: string;
  1037. color?: string;
  1038. underline?: boolean;
  1039. onLink?: () => void;
  1040. url?: string;
  1041. additionalClass?: string;
  1042. }
  1043. export class IndentedTextLineComponent extends React.Component<IIndentedTextLineComponentProps> {
  1044. constructor(props: IIndentedTextLineComponentProps);
  1045. onLink(): void;
  1046. renderContent(): JSX.Element;
  1047. render(): JSX.Element;
  1048. }
  1049. }
  1050. declare module "babylonjs-gui-editor/sharedUiComponents/lines/linkButtonComponent" {
  1051. import * as React from "react";
  1052. interface ILinkButtonComponentProps {
  1053. label: string;
  1054. buttonLabel: string;
  1055. url?: string;
  1056. onClick: () => void;
  1057. onIconClick?: () => void;
  1058. }
  1059. export class LinkButtonComponent extends React.Component<ILinkButtonComponentProps> {
  1060. constructor(props: ILinkButtonComponentProps);
  1061. onLink(): void;
  1062. render(): JSX.Element;
  1063. }
  1064. }
  1065. declare module "babylonjs-gui-editor/sharedUiComponents/lines/messageLineComponent" {
  1066. import * as React from "react";
  1067. interface IMessageLineComponentProps {
  1068. text: string;
  1069. color?: string;
  1070. }
  1071. export class MessageLineComponent extends React.Component<IMessageLineComponentProps> {
  1072. constructor(props: IMessageLineComponentProps);
  1073. render(): JSX.Element;
  1074. }
  1075. }
  1076. declare module "babylonjs-gui-editor/sharedUiComponents/lines/optionsLineComponent" {
  1077. import * as React from "react";
  1078. import { Observable } from "babylonjs/Misc/observable";
  1079. import { PropertyChangedEvent } from "babylonjs-gui-editor/sharedUiComponents/propertyChangedEvent";
  1080. export const Null_Value: number;
  1081. export class ListLineOption {
  1082. label: string;
  1083. value: number;
  1084. selected?: boolean;
  1085. }
  1086. export interface IOptionsLineComponentProps {
  1087. label: string;
  1088. target: any;
  1089. propertyName: string;
  1090. options: ListLineOption[];
  1091. noDirectUpdate?: boolean;
  1092. onSelect?: (value: number) => void;
  1093. extractValue?: () => number;
  1094. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1095. allowNullValue?: boolean;
  1096. }
  1097. export class OptionsLineComponent extends React.Component<IOptionsLineComponentProps, {
  1098. value: number;
  1099. }> {
  1100. private _localChange;
  1101. private remapValueIn;
  1102. private remapValueOut;
  1103. constructor(props: IOptionsLineComponentProps);
  1104. shouldComponentUpdate(nextProps: IOptionsLineComponentProps, nextState: {
  1105. value: number;
  1106. }): boolean;
  1107. raiseOnPropertyChanged(newValue: number, previousValue: number): void;
  1108. updateValue(valueString: string): void;
  1109. render(): JSX.Element;
  1110. }
  1111. }
  1112. declare module "babylonjs-gui-editor/sharedUiComponents/lines/radioLineComponent" {
  1113. import * as React from "react";
  1114. import { Observable } from "babylonjs/Misc/observable";
  1115. interface IRadioButtonLineComponentProps {
  1116. onSelectionChangedObservable: Observable<RadioButtonLineComponent>;
  1117. label: string;
  1118. isSelected: () => boolean;
  1119. onSelect: () => void;
  1120. }
  1121. export class RadioButtonLineComponent extends React.Component<IRadioButtonLineComponentProps, {
  1122. isSelected: boolean;
  1123. }> {
  1124. private _onSelectionChangedObserver;
  1125. constructor(props: IRadioButtonLineComponentProps);
  1126. componentDidMount(): void;
  1127. componentWillUnmount(): void;
  1128. onChange(): void;
  1129. render(): JSX.Element;
  1130. }
  1131. }
  1132. declare module "babylonjs-gui-editor/sharedUiComponents/lines/textInputLineComponent" {
  1133. import * as React from "react";
  1134. import { Observable } from "babylonjs/Misc/observable";
  1135. import { PropertyChangedEvent } from "babylonjs-gui-editor/sharedUiComponents/propertyChangedEvent";
  1136. import { LockObject } from "babylonjs-gui-editor/sharedUiComponents/tabs/propertyGrids/lockObject";
  1137. interface ITextInputLineComponentProps {
  1138. label: string;
  1139. lockObject: LockObject;
  1140. target?: any;
  1141. propertyName?: string;
  1142. value?: string;
  1143. onChange?: (value: string) => void;
  1144. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1145. }
  1146. export class TextInputLineComponent extends React.Component<ITextInputLineComponentProps, {
  1147. value: string;
  1148. }> {
  1149. private _localChange;
  1150. constructor(props: ITextInputLineComponentProps);
  1151. componentWillUnmount(): void;
  1152. shouldComponentUpdate(nextProps: ITextInputLineComponentProps, nextState: {
  1153. value: string;
  1154. }): boolean;
  1155. raiseOnPropertyChanged(newValue: string, previousValue: string): void;
  1156. updateValue(value: string): void;
  1157. render(): JSX.Element;
  1158. }
  1159. }
  1160. declare module "babylonjs-gui-editor/sharedUiComponents/lines/valueLineComponent" {
  1161. import * as React from "react";
  1162. interface IValueLineComponentProps {
  1163. label: string;
  1164. value: number;
  1165. color?: string;
  1166. fractionDigits?: number;
  1167. units?: string;
  1168. }
  1169. export class ValueLineComponent extends React.Component<IValueLineComponentProps> {
  1170. constructor(props: IValueLineComponentProps);
  1171. render(): JSX.Element;
  1172. }
  1173. }
  1174. declare module "babylonjs-gui-editor/sharedUiComponents/lines/vector2LineComponent" {
  1175. import * as React from "react";
  1176. import { Vector2 } from "babylonjs/Maths/math.vector";
  1177. import { Observable } from "babylonjs/Misc/observable";
  1178. import { PropertyChangedEvent } from "babylonjs-gui-editor/sharedUiComponents/propertyChangedEvent";
  1179. interface IVector2LineComponentProps {
  1180. label: string;
  1181. target: any;
  1182. propertyName: string;
  1183. step?: number;
  1184. onChange?: (newvalue: Vector2) => void;
  1185. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1186. }
  1187. export class Vector2LineComponent extends React.Component<IVector2LineComponentProps, {
  1188. isExpanded: boolean;
  1189. value: Vector2;
  1190. }> {
  1191. static defaultProps: {
  1192. step: number;
  1193. };
  1194. private _localChange;
  1195. constructor(props: IVector2LineComponentProps);
  1196. shouldComponentUpdate(nextProps: IVector2LineComponentProps, nextState: {
  1197. isExpanded: boolean;
  1198. value: Vector2;
  1199. }): boolean;
  1200. switchExpandState(): void;
  1201. raiseOnPropertyChanged(previousValue: Vector2): void;
  1202. updateStateX(value: number): void;
  1203. updateStateY(value: number): void;
  1204. render(): JSX.Element;
  1205. }
  1206. }
  1207. declare module "babylonjs-gui-editor/sharedUiComponents/lines/vector3LineComponent" {
  1208. import * as React from "react";
  1209. import { Vector3 } from "babylonjs/Maths/math.vector";
  1210. import { Observable } from "babylonjs/Misc/observable";
  1211. import { PropertyChangedEvent } from "babylonjs-gui-editor/sharedUiComponents/propertyChangedEvent";
  1212. interface IVector3LineComponentProps {
  1213. label: string;
  1214. target: any;
  1215. propertyName: string;
  1216. step?: number;
  1217. onChange?: (newvalue: Vector3) => void;
  1218. useEuler?: boolean;
  1219. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1220. noSlider?: boolean;
  1221. }
  1222. export class Vector3LineComponent extends React.Component<IVector3LineComponentProps, {
  1223. isExpanded: boolean;
  1224. value: Vector3;
  1225. }> {
  1226. static defaultProps: {
  1227. step: number;
  1228. };
  1229. private _localChange;
  1230. constructor(props: IVector3LineComponentProps);
  1231. getCurrentValue(): any;
  1232. shouldComponentUpdate(nextProps: IVector3LineComponentProps, nextState: {
  1233. isExpanded: boolean;
  1234. value: Vector3;
  1235. }): boolean;
  1236. switchExpandState(): void;
  1237. raiseOnPropertyChanged(previousValue: Vector3): void;
  1238. updateVector3(): void;
  1239. updateStateX(value: number): void;
  1240. updateStateY(value: number): void;
  1241. updateStateZ(value: number): void;
  1242. render(): JSX.Element;
  1243. }
  1244. }
  1245. declare module "babylonjs-gui-editor/sharedUiComponents/lines/vector4LineComponent" {
  1246. import * as React from "react";
  1247. import { Vector4 } from "babylonjs/Maths/math.vector";
  1248. import { Observable } from "babylonjs/Misc/observable";
  1249. import { PropertyChangedEvent } from "babylonjs-gui-editor/sharedUiComponents/propertyChangedEvent";
  1250. interface IVector4LineComponentProps {
  1251. label: string;
  1252. target: any;
  1253. propertyName: string;
  1254. step?: number;
  1255. onChange?: (newvalue: Vector4) => void;
  1256. useEuler?: boolean;
  1257. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1258. }
  1259. export class Vector4LineComponent extends React.Component<IVector4LineComponentProps, {
  1260. isExpanded: boolean;
  1261. value: Vector4;
  1262. }> {
  1263. static defaultProps: {
  1264. step: number;
  1265. };
  1266. private _localChange;
  1267. constructor(props: IVector4LineComponentProps);
  1268. getCurrentValue(): any;
  1269. shouldComponentUpdate(nextProps: IVector4LineComponentProps, nextState: {
  1270. isExpanded: boolean;
  1271. value: Vector4;
  1272. }): boolean;
  1273. switchExpandState(): void;
  1274. raiseOnPropertyChanged(previousValue: Vector4): void;
  1275. updateVector4(): void;
  1276. updateStateX(value: number): void;
  1277. updateStateY(value: number): void;
  1278. updateStateZ(value: number): void;
  1279. updateStateW(value: number): void;
  1280. render(): JSX.Element;
  1281. }
  1282. }
  1283. declare module "babylonjs-gui-editor" {
  1284. export * from "babylonjs-gui-editor/legacy/legacy";
  1285. }
  1286. /// <reference types="react" />
  1287. declare module GUIEDITOR {
  1288. interface ILogComponentProps {
  1289. globalState: GlobalState;
  1290. }
  1291. export class LogEntry {
  1292. message: string;
  1293. isError: boolean;
  1294. constructor(message: string, isError: boolean);
  1295. }
  1296. export class LogComponent extends React.Component<ILogComponentProps, {
  1297. logs: LogEntry[];
  1298. }> {
  1299. constructor(props: ILogComponentProps);
  1300. componentDidMount(): void;
  1301. componentDidUpdate(): void;
  1302. render(): JSX.Element;
  1303. }
  1304. }
  1305. declare module GUIEDITOR {
  1306. export interface IWorkbenchComponentProps {
  1307. globalState: GlobalState;
  1308. }
  1309. export type FramePortData = {};
  1310. export const isFramePortData: (variableToCheck: any) => variableToCheck is FramePortData;
  1311. export class WorkbenchComponent extends React.Component<IWorkbenchComponentProps> {
  1312. private readonly MinZoom;
  1313. private readonly MaxZoom;
  1314. private _hostCanvas;
  1315. private _gridCanvas;
  1316. private _selectionContainer;
  1317. private _frameContainer;
  1318. private _svgCanvas;
  1319. private _rootContainer;
  1320. private _guiNodes;
  1321. private _mouseStartPointX;
  1322. private _mouseStartPointY;
  1323. private _selectionStartX;
  1324. private _selectionStartY;
  1325. private _x;
  1326. private _y;
  1327. private _zoom;
  1328. private _selectedGuiNodes;
  1329. private _gridSize;
  1330. private _selectionBox;
  1331. private _frameCandidate;
  1332. private _altKeyIsPressed;
  1333. private _ctrlKeyIsPressed;
  1334. private _oldY;
  1335. _frameIsMoving: boolean;
  1336. _isLoading: boolean;
  1337. isOverGUINode: boolean;
  1338. get gridSize(): number;
  1339. set gridSize(value: number);
  1340. get globalState(): GlobalState;
  1341. get nodes(): GUINode[];
  1342. get zoom(): number;
  1343. set zoom(value: number);
  1344. get x(): number;
  1345. set x(value: number);
  1346. get y(): number;
  1347. set y(value: number);
  1348. get selectedGuiNodes(): GUINode[];
  1349. get canvasContainer(): HTMLDivElement;
  1350. get hostCanvas(): HTMLDivElement;
  1351. get svgCanvas(): HTMLElement;
  1352. get selectionContainer(): HTMLDivElement;
  1353. get frameContainer(): HTMLDivElement;
  1354. constructor(props: IWorkbenchComponentProps);
  1355. getGridPosition(position: number, useCeil?: boolean): number;
  1356. getGridPositionCeil(position: number): number;
  1357. updateTransform(): void;
  1358. onKeyUp(): void;
  1359. findNodeFromGuiElement(guiControl: Control): GUINode;
  1360. reset(): void;
  1361. appendBlock(guiElement: Control): GUINode;
  1362. distributeGraph(): void;
  1363. componentDidMount(): void;
  1364. onMove(evt: React.PointerEvent): void;
  1365. onDown(evt: React.PointerEvent<HTMLElement>): void;
  1366. onUp(evt: React.PointerEvent): void;
  1367. onWheel(evt: React.WheelEvent): void;
  1368. zoomToFit(): void;
  1369. createGUICanvas(): void;
  1370. updateGUIs(): void;
  1371. render(): JSX.Element;
  1372. }
  1373. }
  1374. declare module GUIEDITOR {
  1375. export interface IPropertyComponentProps {
  1376. globalState: GlobalState;
  1377. guiControl: Control;
  1378. }
  1379. }
  1380. declare module GUIEDITOR {
  1381. interface ILineContainerComponentProps {
  1382. title: string;
  1383. children: any[] | any;
  1384. closed?: boolean;
  1385. }
  1386. export class LineContainerComponent extends React.Component<ILineContainerComponentProps, {
  1387. isExpanded: boolean;
  1388. }> {
  1389. constructor(props: ILineContainerComponentProps);
  1390. switchExpandedState(): void;
  1391. renderHeader(): JSX.Element;
  1392. render(): JSX.Element;
  1393. }
  1394. }
  1395. declare module GUIEDITOR {
  1396. export class PropertyChangedEvent {
  1397. object: any;
  1398. property: string;
  1399. value: any;
  1400. initialValue: any;
  1401. allowNullValue?: boolean;
  1402. }
  1403. }
  1404. declare module GUIEDITOR {
  1405. export interface ICheckBoxLineComponentProps {
  1406. label: string;
  1407. target?: any;
  1408. propertyName?: string;
  1409. isSelected?: () => boolean;
  1410. onSelect?: (value: boolean) => void;
  1411. onValueChanged?: () => void;
  1412. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  1413. disabled?: boolean;
  1414. }
  1415. export class CheckBoxLineComponent extends React.Component<ICheckBoxLineComponentProps, {
  1416. isSelected: boolean;
  1417. isDisabled?: boolean;
  1418. }> {
  1419. private static _UniqueIdSeed;
  1420. private _uniqueId;
  1421. private _localChange;
  1422. constructor(props: ICheckBoxLineComponentProps);
  1423. shouldComponentUpdate(nextProps: ICheckBoxLineComponentProps, nextState: {
  1424. isSelected: boolean;
  1425. isDisabled: boolean;
  1426. }): boolean;
  1427. onChange(): void;
  1428. render(): JSX.Element;
  1429. }
  1430. }
  1431. declare module GUIEDITOR {
  1432. export class PropertyChangedEvent {
  1433. object: any;
  1434. property: string;
  1435. value: any;
  1436. initialValue: any;
  1437. }
  1438. }
  1439. declare module GUIEDITOR {
  1440. interface IFloatLineComponentProps {
  1441. label: string;
  1442. target: any;
  1443. propertyName: string;
  1444. onChange?: (newValue: number) => void;
  1445. isInteger?: boolean;
  1446. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  1447. additionalClass?: string;
  1448. step?: string;
  1449. digits?: number;
  1450. globalState: GlobalState;
  1451. min?: number;
  1452. max?: number;
  1453. smallUI?: boolean;
  1454. onEnter?: (newValue: number) => void;
  1455. }
  1456. export class FloatLineComponent extends React.Component<IFloatLineComponentProps, {
  1457. value: string;
  1458. }> {
  1459. private _localChange;
  1460. private _store;
  1461. private _regExp;
  1462. private _digits;
  1463. constructor(props: IFloatLineComponentProps);
  1464. shouldComponentUpdate(nextProps: IFloatLineComponentProps, nextState: {
  1465. value: string;
  1466. }): boolean;
  1467. raiseOnPropertyChanged(newValue: number, previousValue: number): void;
  1468. updateValue(valueString: string): void;
  1469. render(): JSX.Element;
  1470. }
  1471. }
  1472. declare module GUIEDITOR {
  1473. interface ISliderLineComponentProps {
  1474. label: string;
  1475. target?: any;
  1476. propertyName?: string;
  1477. minimum: number;
  1478. maximum: number;
  1479. step: number;
  1480. directValue?: number;
  1481. useEuler?: boolean;
  1482. onChange?: (value: number) => void;
  1483. onInput?: (value: number) => void;
  1484. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  1485. decimalCount?: number;
  1486. globalState: GlobalState;
  1487. }
  1488. export class SliderLineComponent extends React.Component<ISliderLineComponentProps, {
  1489. value: number;
  1490. }> {
  1491. private _localChange;
  1492. constructor(props: ISliderLineComponentProps);
  1493. shouldComponentUpdate(nextProps: ISliderLineComponentProps, nextState: {
  1494. value: number;
  1495. }): boolean;
  1496. onChange(newValueString: any): void;
  1497. onInput(newValueString: any): void;
  1498. prepareDataToRead(value: number): number;
  1499. render(): JSX.Element;
  1500. }
  1501. }
  1502. declare module GUIEDITOR {
  1503. export class GenericPropertyComponent extends React.Component<IPropertyComponentProps> {
  1504. constructor(props: IPropertyComponentProps);
  1505. render(): JSX.Element;
  1506. }
  1507. export class GeneralPropertyTabComponent extends React.Component<IPropertyComponentProps> {
  1508. constructor(props: IPropertyComponentProps);
  1509. render(): JSX.Element;
  1510. }
  1511. export class GenericPropertyTabComponent extends React.Component<IPropertyComponentProps> {
  1512. constructor(props: IPropertyComponentProps);
  1513. forceRebuild(notifiers?: {
  1514. "rebuild"?: boolean;
  1515. "update"?: boolean;
  1516. }): void;
  1517. render(): JSX.Element;
  1518. }
  1519. }
  1520. declare module GUIEDITOR {
  1521. interface INumericInputComponentProps {
  1522. label: string;
  1523. value: number;
  1524. step?: number;
  1525. onChange: (value: number) => void;
  1526. globalState: GlobalState;
  1527. }
  1528. export class NumericInputComponent extends React.Component<INumericInputComponentProps, {
  1529. value: string;
  1530. }> {
  1531. static defaultProps: {
  1532. step: number;
  1533. };
  1534. private _localChange;
  1535. constructor(props: INumericInputComponentProps);
  1536. shouldComponentUpdate(nextProps: INumericInputComponentProps, nextState: {
  1537. value: string;
  1538. }): boolean;
  1539. updateValue(evt: any): void;
  1540. render(): JSX.Element;
  1541. }
  1542. }
  1543. declare module GUIEDITOR {
  1544. interface ITextLineComponentProps {
  1545. label?: string;
  1546. value?: string;
  1547. color?: string;
  1548. underline?: boolean;
  1549. onLink?: () => void;
  1550. url?: string;
  1551. ignoreValue?: boolean;
  1552. additionalClass?: string;
  1553. }
  1554. export class TextLineComponent extends React.Component<ITextLineComponentProps> {
  1555. constructor(props: ITextLineComponentProps);
  1556. onLink(): void;
  1557. renderContent(): JSX.Element | null;
  1558. render(): JSX.Element;
  1559. }
  1560. }
  1561. declare module GUIEDITOR {
  1562. export class SliderPropertyTabComponent extends React.Component<IPropertyComponentProps> {
  1563. constructor(props: IPropertyComponentProps);
  1564. private _slider;
  1565. render(): JSX.Element;
  1566. }
  1567. }
  1568. declare module GUIEDITOR {
  1569. export class PropertyGuiLedger {
  1570. static RegisteredControls: {
  1571. [key: string]: React.ComponentClass<IPropertyComponentProps>;
  1572. };
  1573. }
  1574. }
  1575. declare module GUIEDITOR {
  1576. export class GUINode {
  1577. guiControl: Control;
  1578. private _x;
  1579. private _y;
  1580. private _gridAlignedX;
  1581. private _gridAlignedY;
  1582. private _globalState;
  1583. private _onSelectionChangedObserver;
  1584. private _onSelectionBoxMovedObserver;
  1585. private _onUpdateRequiredObserver;
  1586. private _ownerCanvas;
  1587. private _isSelected;
  1588. private _isVisible;
  1589. private _enclosingFrameId;
  1590. get isVisible(): boolean;
  1591. set isVisible(value: boolean);
  1592. get gridAlignedX(): number;
  1593. get gridAlignedY(): number;
  1594. get x(): number;
  1595. set x(value: number);
  1596. get y(): number;
  1597. set y(value: number);
  1598. get width(): number;
  1599. get height(): number;
  1600. get id(): number;
  1601. get name(): string | undefined;
  1602. get isSelected(): boolean;
  1603. get enclosingFrameId(): number;
  1604. set enclosingFrameId(value: number);
  1605. set isSelected(value: boolean);
  1606. constructor(globalState: GlobalState, guiControl: Control);
  1607. cleanAccumulation(useCeil?: boolean): void;
  1608. clicked: boolean;
  1609. _onMove(evt: BABYLON.Vector2, startPos: BABYLON.Vector2): boolean;
  1610. renderProperties(): BABYLON.Nullable<JSX.Element>;
  1611. updateVisual(): void;
  1612. dispose(): void;
  1613. }
  1614. }
  1615. declare module GUIEDITOR {
  1616. export class GlobalState {
  1617. guiTexture: AdvancedDynamicTexture;
  1618. hostElement: HTMLElement;
  1619. hostDocument: HTMLDocument;
  1620. hostWindow: Window;
  1621. onSelectionChangedObservable: BABYLON.Observable<BABYLON.Nullable<GUINode>>;
  1622. onRebuildRequiredObservable: BABYLON.Observable<void>;
  1623. onBuiltObservable: BABYLON.Observable<void>;
  1624. onResetRequiredObservable: BABYLON.Observable<void>;
  1625. onUpdateRequiredObservable: BABYLON.Observable<void>;
  1626. onReOrganizedRequiredObservable: BABYLON.Observable<void>;
  1627. onLogRequiredObservable: BABYLON.Observable<LogEntry>;
  1628. onErrorMessageDialogRequiredObservable: BABYLON.Observable<string>;
  1629. onIsLoadingChanged: BABYLON.Observable<boolean>;
  1630. onSelectionBoxMoved: BABYLON.Observable<DOMRect | ClientRect>;
  1631. onGuiNodeRemovalObservable: BABYLON.Observable<GUINode>;
  1632. backgroundColor: BABYLON.Color4;
  1633. blockKeyboardEvents: boolean;
  1634. controlCamera: boolean;
  1635. workbench: WorkbenchComponent;
  1636. storeEditorData: (serializationObject: any) => void;
  1637. customSave?: {
  1638. label: string;
  1639. action: (data: string) => Promise<void>;
  1640. };
  1641. constructor();
  1642. }
  1643. }
  1644. declare module GUIEDITOR {
  1645. export interface IButtonLineComponentProps {
  1646. data: string;
  1647. tooltip: string;
  1648. }
  1649. export class DraggableLineComponent extends React.Component<IButtonLineComponentProps> {
  1650. constructor(props: IButtonLineComponentProps);
  1651. render(): JSX.Element;
  1652. }
  1653. }
  1654. declare module GUIEDITOR {
  1655. interface IGuiListComponentProps {
  1656. globalState: GlobalState;
  1657. }
  1658. export class GuiListComponent extends React.Component<IGuiListComponentProps, {
  1659. filter: string;
  1660. }> {
  1661. private _onResetRequiredObserver;
  1662. private static _Tooltips;
  1663. constructor(props: IGuiListComponentProps);
  1664. componentWillUnmount(): void;
  1665. filterContent(filter: string): void;
  1666. render(): JSX.Element;
  1667. }
  1668. }
  1669. declare module GUIEDITOR {
  1670. export interface IButtonLineComponentProps {
  1671. label: string;
  1672. onClick: () => void;
  1673. }
  1674. export class ButtonLineComponent extends React.Component<IButtonLineComponentProps> {
  1675. constructor(props: IButtonLineComponentProps);
  1676. render(): JSX.Element;
  1677. }
  1678. }
  1679. declare module GUIEDITOR {
  1680. interface IFileButtonLineComponentProps {
  1681. label: string;
  1682. onClick: (file: File) => void;
  1683. accept: string;
  1684. }
  1685. export class FileButtonLineComponent extends React.Component<IFileButtonLineComponentProps> {
  1686. private static _IDGenerator;
  1687. private _id;
  1688. private uploadInputRef;
  1689. constructor(props: IFileButtonLineComponentProps);
  1690. onChange(evt: any): void;
  1691. render(): JSX.Element;
  1692. }
  1693. }
  1694. declare module GUIEDITOR {
  1695. export class SerializationTools {
  1696. static Deserialize(serializationObject: any, globalState: GlobalState): void;
  1697. }
  1698. }
  1699. declare module GUIEDITOR {
  1700. interface IPropertyTabComponentProps {
  1701. globalState: GlobalState;
  1702. }
  1703. interface IPropertyTabComponentState {
  1704. currentNode: BABYLON.Nullable<GUINode>;
  1705. }
  1706. export class PropertyTabComponent extends React.Component<IPropertyTabComponentProps, IPropertyTabComponentState> {
  1707. private _onBuiltObserver;
  1708. constructor(props: IPropertyTabComponentProps);
  1709. componentDidMount(): void;
  1710. componentWillUnmount(): void;
  1711. load(file: File): void;
  1712. loadFrame(file: File): void;
  1713. save(): void;
  1714. customSave(): void;
  1715. saveToSnippetServer(): void;
  1716. loadFromSnippet(): void;
  1717. render(): JSX.Element;
  1718. }
  1719. }
  1720. declare module GUIEDITOR {
  1721. interface IPortalProps {
  1722. globalState: GlobalState;
  1723. }
  1724. export class Portal extends React.Component<IPortalProps> {
  1725. render(): React.ReactPortal;
  1726. }
  1727. }
  1728. declare module GUIEDITOR {
  1729. export class GUINodeTools {
  1730. static CreateControlFromString(data: string): Slider | Checkbox | ColorPicker | Ellipse | Rectangle | Line | TextBlock;
  1731. }
  1732. }
  1733. declare module GUIEDITOR {
  1734. export interface INodeLocationInfo {
  1735. blockId: number;
  1736. x: number;
  1737. y: number;
  1738. }
  1739. export interface IFrameData {
  1740. x: number;
  1741. y: number;
  1742. width: number;
  1743. height: number;
  1744. color: number[];
  1745. name: string;
  1746. isCollapsed: boolean;
  1747. blocks: number[];
  1748. comments: string;
  1749. }
  1750. export interface IEditorData {
  1751. locations: INodeLocationInfo[];
  1752. x: number;
  1753. y: number;
  1754. zoom: number;
  1755. frames?: IFrameData[];
  1756. map?: {
  1757. [key: number]: number;
  1758. };
  1759. }
  1760. }
  1761. declare module GUIEDITOR {
  1762. interface IMessageDialogComponentProps {
  1763. globalState: GlobalState;
  1764. }
  1765. export class MessageDialogComponent extends React.Component<IMessageDialogComponentProps, {
  1766. message: string;
  1767. isError: boolean;
  1768. }> {
  1769. constructor(props: IMessageDialogComponentProps);
  1770. render(): JSX.Element | null;
  1771. }
  1772. }
  1773. declare module GUIEDITOR {
  1774. interface IGraphEditorProps {
  1775. globalState: GlobalState;
  1776. }
  1777. interface IGraphEditorState {
  1778. showPreviewPopUp: boolean;
  1779. }
  1780. export class WorkbenchEditor extends React.Component<IGraphEditorProps, IGraphEditorState> {
  1781. private _workbenchCanvas;
  1782. private _startX;
  1783. private _moveInProgress;
  1784. private _leftWidth;
  1785. private _rightWidth;
  1786. private _blocks;
  1787. private _onWidgetKeyUpPointer;
  1788. private _popUpWindow;
  1789. /**
  1790. * Creates a node and recursivly creates its parent nodes from it's input
  1791. * @param block
  1792. */
  1793. createNodeFromObject(block: Control, recursion?: boolean): BABYLON.Nullable<GUINode>;
  1794. componentDidMount(): void;
  1795. componentWillUnmount(): void;
  1796. constructor(props: IGraphEditorProps);
  1797. pasteSelection(copiedNodes: GUINode[], currentX: number, currentY: number, selectNew?: boolean): GUINode[];
  1798. zoomToFit(): void;
  1799. showWaitScreen(): void;
  1800. hideWaitScreen(): void;
  1801. reOrganize(editorData?: BABYLON.Nullable<IEditorData>, isImportingAFrame?: boolean): void;
  1802. onPointerDown(evt: React.PointerEvent<HTMLDivElement>): void;
  1803. onPointerUp(evt: React.PointerEvent<HTMLDivElement>): void;
  1804. resizeColumns(evt: React.PointerEvent<HTMLDivElement>, forLeft?: boolean): void;
  1805. buildColumnLayout(): string;
  1806. emitNewBlock(event: React.DragEvent<HTMLDivElement>): void;
  1807. handlePopUp: () => void;
  1808. handleClosingPopUp: () => void;
  1809. createPopupWindow: (title: string, windowVariableName: string, width?: number, height?: number) => Window | null;
  1810. copyStyles: (sourceDoc: HTMLDocument, targetDoc: HTMLDocument) => void;
  1811. fixPopUpStyles: (document: Document) => void;
  1812. render(): JSX.Element;
  1813. }
  1814. }
  1815. declare module GUIEDITOR {
  1816. export class Popup {
  1817. static CreatePopup(title: string, windowVariableName: string, width?: number, height?: number): HTMLDivElement | null;
  1818. private static _CopyStyles;
  1819. }
  1820. }
  1821. declare module GUIEDITOR {
  1822. /**
  1823. * Interface used to specify creation options for the gui editor
  1824. */
  1825. export interface IGUIEditorOptions {
  1826. hostElement?: HTMLElement;
  1827. customSave?: {
  1828. label: string;
  1829. action: (data: string) => Promise<void>;
  1830. };
  1831. customLoadObservable?: BABYLON.Observable<any>;
  1832. }
  1833. /**
  1834. * Class used to create a gui editor
  1835. */
  1836. export class GUIEditor {
  1837. private static _CurrentState;
  1838. /**
  1839. * Show the gui editor
  1840. * @param options defines the options to use to configure the gui editor
  1841. */
  1842. static Show(options: IGUIEditorOptions): void;
  1843. }
  1844. }
  1845. declare module GUIEDITOR {
  1846. interface ILineWithFileButtonComponentProps {
  1847. title: string;
  1848. closed?: boolean;
  1849. label: string;
  1850. iconImage: any;
  1851. onIconClick: (file: File) => void;
  1852. accept: string;
  1853. uploadName?: string;
  1854. }
  1855. export class LineWithFileButtonComponent extends React.Component<ILineWithFileButtonComponentProps, {
  1856. isExpanded: boolean;
  1857. }> {
  1858. private uploadRef;
  1859. constructor(props: ILineWithFileButtonComponentProps);
  1860. onChange(evt: any): void;
  1861. switchExpandedState(): void;
  1862. render(): JSX.Element;
  1863. }
  1864. }
  1865. declare module GUIEDITOR {
  1866. interface ITextInputLineComponentProps {
  1867. label: string;
  1868. globalState: GlobalState;
  1869. target?: any;
  1870. propertyName?: string;
  1871. value?: string;
  1872. multilines?: boolean;
  1873. onChange?: (value: string) => void;
  1874. validator?: (value: string) => boolean;
  1875. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  1876. }
  1877. export class TextInputLineComponent extends React.Component<ITextInputLineComponentProps, {
  1878. value: string;
  1879. }> {
  1880. private _localChange;
  1881. constructor(props: ITextInputLineComponentProps);
  1882. shouldComponentUpdate(nextProps: ITextInputLineComponentProps, nextState: {
  1883. value: string;
  1884. }): boolean;
  1885. raiseOnPropertyChanged(newValue: string, previousValue: string): void;
  1886. updateValue(value: string, raisePropertyChanged: boolean): void;
  1887. render(): JSX.Element;
  1888. }
  1889. }
  1890. declare module GUIEDITOR {
  1891. export interface IColorComponentEntryProps {
  1892. value: number;
  1893. label: string;
  1894. max?: number;
  1895. min?: number;
  1896. onChange: (value: number) => void;
  1897. }
  1898. export class ColorComponentEntry extends React.Component<IColorComponentEntryProps> {
  1899. constructor(props: IColorComponentEntryProps);
  1900. updateValue(valueString: string): void;
  1901. render(): JSX.Element;
  1902. }
  1903. }
  1904. declare module GUIEDITOR {
  1905. export interface IHexColorProps {
  1906. value: string;
  1907. expectedLength: number;
  1908. onChange: (value: string) => void;
  1909. }
  1910. export class HexColor extends React.Component<IHexColorProps, {
  1911. hex: string;
  1912. }> {
  1913. constructor(props: IHexColorProps);
  1914. shouldComponentUpdate(nextProps: IHexColorProps, nextState: {
  1915. hex: string;
  1916. }): boolean;
  1917. updateHexValue(valueString: string): void;
  1918. render(): JSX.Element;
  1919. }
  1920. }
  1921. declare module GUIEDITOR {
  1922. /**
  1923. * Interface used to specify creation options for color picker
  1924. */
  1925. export interface IColorPickerProps {
  1926. color: BABYLON.Color3 | BABYLON.Color4;
  1927. debugMode?: boolean;
  1928. onColorChanged?: (color: BABYLON.Color3 | BABYLON.Color4) => void;
  1929. }
  1930. /**
  1931. * Interface used to specify creation options for color picker
  1932. */
  1933. export interface IColorPickerState {
  1934. color: BABYLON.Color3;
  1935. alpha: number;
  1936. }
  1937. /**
  1938. * Class used to create a color picker
  1939. */
  1940. export class ColorPicker extends React.Component<IColorPickerProps, IColorPickerState> {
  1941. private _saturationRef;
  1942. private _hueRef;
  1943. private _isSaturationPointerDown;
  1944. private _isHuePointerDown;
  1945. constructor(props: IColorPickerProps);
  1946. onSaturationPointerDown(evt: React.PointerEvent<HTMLDivElement>): void;
  1947. onSaturationPointerUp(evt: React.PointerEvent<HTMLDivElement>): void;
  1948. onSaturationPointerMove(evt: React.PointerEvent<HTMLDivElement>): void;
  1949. onHuePointerDown(evt: React.PointerEvent<HTMLDivElement>): void;
  1950. onHuePointerUp(evt: React.PointerEvent<HTMLDivElement>): void;
  1951. onHuePointerMove(evt: React.PointerEvent<HTMLDivElement>): void;
  1952. private _evaluateSaturation;
  1953. private _evaluateHue;
  1954. componentDidUpdate(): void;
  1955. raiseOnColorChanged(): void;
  1956. render(): JSX.Element;
  1957. }
  1958. }
  1959. declare module GUIEDITOR {
  1960. export interface IBooleanLineComponentProps {
  1961. label: string;
  1962. value: boolean;
  1963. }
  1964. export class BooleanLineComponent extends React.Component<IBooleanLineComponentProps> {
  1965. constructor(props: IBooleanLineComponentProps);
  1966. render(): JSX.Element;
  1967. }
  1968. }
  1969. declare module GUIEDITOR {
  1970. interface INumericInputComponentProps {
  1971. label: string;
  1972. value: number;
  1973. step?: number;
  1974. onChange: (value: number) => void;
  1975. precision?: number;
  1976. }
  1977. export class NumericInputComponent extends React.Component<INumericInputComponentProps, {
  1978. value: string;
  1979. }> {
  1980. static defaultProps: {
  1981. step: number;
  1982. };
  1983. private _localChange;
  1984. constructor(props: INumericInputComponentProps);
  1985. shouldComponentUpdate(nextProps: INumericInputComponentProps, nextState: {
  1986. value: string;
  1987. }): boolean;
  1988. updateValue(evt: any): void;
  1989. onBlur(): void;
  1990. render(): JSX.Element;
  1991. }
  1992. }
  1993. declare module GUIEDITOR {
  1994. export interface IColorPickerComponentProps {
  1995. value: BABYLON.Color4 | BABYLON.Color3;
  1996. onColorChanged: (newOne: string) => void;
  1997. }
  1998. interface IColorPickerComponentState {
  1999. pickerEnabled: boolean;
  2000. color: BABYLON.Color3 | BABYLON.Color4;
  2001. hex: string;
  2002. }
  2003. export class ColorPickerLineComponent extends React.Component<IColorPickerComponentProps, IColorPickerComponentState> {
  2004. private _floatRef;
  2005. private _floatHostRef;
  2006. constructor(props: IColorPickerComponentProps);
  2007. syncPositions(): void;
  2008. shouldComponentUpdate(nextProps: IColorPickerComponentProps, nextState: IColorPickerComponentState): boolean;
  2009. componentDidUpdate(): void;
  2010. componentDidMount(): void;
  2011. render(): JSX.Element;
  2012. }
  2013. }
  2014. declare module GUIEDITOR {
  2015. export interface IColor3LineComponentProps {
  2016. label: string;
  2017. target: any;
  2018. propertyName: string;
  2019. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2020. isLinear?: boolean;
  2021. }
  2022. export class Color3LineComponent extends React.Component<IColor3LineComponentProps, {
  2023. isExpanded: boolean;
  2024. color: BABYLON.Color3;
  2025. }> {
  2026. private _localChange;
  2027. constructor(props: IColor3LineComponentProps);
  2028. shouldComponentUpdate(nextProps: IColor3LineComponentProps, nextState: {
  2029. color: BABYLON.Color3;
  2030. }): boolean;
  2031. setPropertyValue(newColor: BABYLON.Color3): void;
  2032. onChange(newValue: string): void;
  2033. switchExpandState(): void;
  2034. raiseOnPropertyChanged(previousValue: BABYLON.Color3): void;
  2035. updateStateR(value: number): void;
  2036. updateStateG(value: number): void;
  2037. updateStateB(value: number): void;
  2038. copyToClipboard(): void;
  2039. render(): JSX.Element;
  2040. }
  2041. }
  2042. declare module GUIEDITOR {
  2043. export interface IColor4LineComponentProps {
  2044. label: string;
  2045. target: any;
  2046. propertyName: string;
  2047. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2048. onChange?: () => void;
  2049. isLinear?: boolean;
  2050. }
  2051. export class Color4LineComponent extends React.Component<IColor4LineComponentProps, {
  2052. isExpanded: boolean;
  2053. color: BABYLON.Color4;
  2054. }> {
  2055. private _localChange;
  2056. constructor(props: IColor4LineComponentProps);
  2057. shouldComponentUpdate(nextProps: IColor4LineComponentProps, nextState: {
  2058. color: BABYLON.Color4;
  2059. }): boolean;
  2060. setPropertyValue(newColor: BABYLON.Color4): void;
  2061. onChange(newValue: string): void;
  2062. switchExpandState(): void;
  2063. raiseOnPropertyChanged(previousValue: BABYLON.Color4): void;
  2064. updateStateR(value: number): void;
  2065. updateStateG(value: number): void;
  2066. updateStateB(value: number): void;
  2067. updateStateA(value: number): void;
  2068. copyToClipboard(): void;
  2069. render(): JSX.Element;
  2070. }
  2071. }
  2072. declare module GUIEDITOR {
  2073. interface IFileMultipleButtonLineComponentProps {
  2074. label: string;
  2075. onClick: (event: any) => void;
  2076. accept: string;
  2077. }
  2078. export class FileMultipleButtonLineComponent extends React.Component<IFileMultipleButtonLineComponentProps> {
  2079. private static _IDGenerator;
  2080. private _id;
  2081. private uploadInputRef;
  2082. constructor(props: IFileMultipleButtonLineComponentProps);
  2083. onChange(evt: any): void;
  2084. render(): JSX.Element;
  2085. }
  2086. }
  2087. declare module GUIEDITOR {
  2088. /**
  2089. * Class used to provide lock mechanism
  2090. */
  2091. export class LockObject {
  2092. /**
  2093. * Gets or set if the lock is engaged
  2094. */
  2095. lock: boolean;
  2096. }
  2097. }
  2098. declare module GUIEDITOR {
  2099. interface ISliderLineComponentProps {
  2100. label: string;
  2101. target?: any;
  2102. propertyName?: string;
  2103. minimum: number;
  2104. maximum: number;
  2105. step: number;
  2106. directValue?: number;
  2107. useEuler?: boolean;
  2108. onChange?: (value: number) => void;
  2109. onInput?: (value: number) => void;
  2110. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2111. decimalCount?: number;
  2112. margin?: boolean;
  2113. }
  2114. export class SliderLineComponent extends React.Component<ISliderLineComponentProps, {
  2115. value: number;
  2116. }> {
  2117. private _localChange;
  2118. constructor(props: ISliderLineComponentProps);
  2119. shouldComponentUpdate(nextProps: ISliderLineComponentProps, nextState: {
  2120. value: number;
  2121. }): boolean;
  2122. onChange(newValueString: any): void;
  2123. onInput(newValueString: any): void;
  2124. prepareDataToRead(value: number): number;
  2125. render(): JSX.Element;
  2126. }
  2127. }
  2128. declare module GUIEDITOR {
  2129. interface IFloatLineComponentProps {
  2130. label: string;
  2131. target: any;
  2132. propertyName: string;
  2133. lockObject?: LockObject;
  2134. onChange?: (newValue: number) => void;
  2135. isInteger?: boolean;
  2136. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2137. additionalClass?: string;
  2138. step?: string;
  2139. digits?: number;
  2140. useEuler?: boolean;
  2141. min?: number;
  2142. max?: number;
  2143. smallUI?: boolean;
  2144. onEnter?: (newValue: number) => void;
  2145. }
  2146. export class FloatLineComponent extends React.Component<IFloatLineComponentProps, {
  2147. value: string;
  2148. }> {
  2149. private _localChange;
  2150. private _store;
  2151. constructor(props: IFloatLineComponentProps);
  2152. componentWillUnmount(): void;
  2153. shouldComponentUpdate(nextProps: IFloatLineComponentProps, nextState: {
  2154. value: string;
  2155. }): boolean;
  2156. raiseOnPropertyChanged(newValue: number, previousValue: number): void;
  2157. updateValue(valueString: string): void;
  2158. lock(): void;
  2159. unlock(): void;
  2160. render(): JSX.Element;
  2161. }
  2162. }
  2163. declare module GUIEDITOR {
  2164. interface IHexLineComponentProps {
  2165. label: string;
  2166. target: any;
  2167. propertyName: string;
  2168. lockObject?: LockObject;
  2169. onChange?: (newValue: number) => void;
  2170. isInteger?: boolean;
  2171. replaySourceReplacement?: string;
  2172. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2173. additionalClass?: string;
  2174. step?: string;
  2175. digits?: number;
  2176. useEuler?: boolean;
  2177. min?: number;
  2178. }
  2179. export class HexLineComponent extends React.Component<IHexLineComponentProps, {
  2180. value: string;
  2181. }> {
  2182. private _localChange;
  2183. private _store;
  2184. private _propertyChange;
  2185. constructor(props: IHexLineComponentProps);
  2186. componentWillUnmount(): void;
  2187. shouldComponentUpdate(nextProps: IHexLineComponentProps, nextState: {
  2188. value: string;
  2189. }): boolean;
  2190. raiseOnPropertyChanged(newValue: number, previousValue: number): void;
  2191. convertToHexString(valueString: string): string;
  2192. updateValue(valueString: string, raisePropertyChanged: boolean): void;
  2193. lock(): void;
  2194. unlock(): void;
  2195. render(): JSX.Element;
  2196. }
  2197. }
  2198. declare module GUIEDITOR {
  2199. export interface IIconButtonLineComponentProps {
  2200. icon: string;
  2201. onClick: () => void;
  2202. tooltip: string;
  2203. active?: boolean;
  2204. }
  2205. export class IconButtonLineComponent extends React.Component<IIconButtonLineComponentProps> {
  2206. constructor(props: IIconButtonLineComponentProps);
  2207. render(): JSX.Element;
  2208. }
  2209. }
  2210. declare module GUIEDITOR {
  2211. interface IIndentedTextLineComponentProps {
  2212. value?: string;
  2213. color?: string;
  2214. underline?: boolean;
  2215. onLink?: () => void;
  2216. url?: string;
  2217. additionalClass?: string;
  2218. }
  2219. export class IndentedTextLineComponent extends React.Component<IIndentedTextLineComponentProps> {
  2220. constructor(props: IIndentedTextLineComponentProps);
  2221. onLink(): void;
  2222. renderContent(): JSX.Element;
  2223. render(): JSX.Element;
  2224. }
  2225. }
  2226. declare module GUIEDITOR {
  2227. interface ILinkButtonComponentProps {
  2228. label: string;
  2229. buttonLabel: string;
  2230. url?: string;
  2231. onClick: () => void;
  2232. onIconClick?: () => void;
  2233. }
  2234. export class LinkButtonComponent extends React.Component<ILinkButtonComponentProps> {
  2235. constructor(props: ILinkButtonComponentProps);
  2236. onLink(): void;
  2237. render(): JSX.Element;
  2238. }
  2239. }
  2240. declare module GUIEDITOR {
  2241. interface IMessageLineComponentProps {
  2242. text: string;
  2243. color?: string;
  2244. }
  2245. export class MessageLineComponent extends React.Component<IMessageLineComponentProps> {
  2246. constructor(props: IMessageLineComponentProps);
  2247. render(): JSX.Element;
  2248. }
  2249. }
  2250. declare module GUIEDITOR {
  2251. export const Null_Value: number;
  2252. export class ListLineOption {
  2253. label: string;
  2254. value: number;
  2255. selected?: boolean;
  2256. }
  2257. export interface IOptionsLineComponentProps {
  2258. label: string;
  2259. target: any;
  2260. propertyName: string;
  2261. options: ListLineOption[];
  2262. noDirectUpdate?: boolean;
  2263. onSelect?: (value: number) => void;
  2264. extractValue?: () => number;
  2265. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2266. allowNullValue?: boolean;
  2267. }
  2268. export class OptionsLineComponent extends React.Component<IOptionsLineComponentProps, {
  2269. value: number;
  2270. }> {
  2271. private _localChange;
  2272. private remapValueIn;
  2273. private remapValueOut;
  2274. constructor(props: IOptionsLineComponentProps);
  2275. shouldComponentUpdate(nextProps: IOptionsLineComponentProps, nextState: {
  2276. value: number;
  2277. }): boolean;
  2278. raiseOnPropertyChanged(newValue: number, previousValue: number): void;
  2279. updateValue(valueString: string): void;
  2280. render(): JSX.Element;
  2281. }
  2282. }
  2283. declare module GUIEDITOR {
  2284. interface IRadioButtonLineComponentProps {
  2285. onSelectionChangedObservable: BABYLON.Observable<RadioButtonLineComponent>;
  2286. label: string;
  2287. isSelected: () => boolean;
  2288. onSelect: () => void;
  2289. }
  2290. export class RadioButtonLineComponent extends React.Component<IRadioButtonLineComponentProps, {
  2291. isSelected: boolean;
  2292. }> {
  2293. private _onSelectionChangedObserver;
  2294. constructor(props: IRadioButtonLineComponentProps);
  2295. componentDidMount(): void;
  2296. componentWillUnmount(): void;
  2297. onChange(): void;
  2298. render(): JSX.Element;
  2299. }
  2300. }
  2301. declare module GUIEDITOR {
  2302. interface ITextInputLineComponentProps {
  2303. label: string;
  2304. lockObject: LockObject;
  2305. target?: any;
  2306. propertyName?: string;
  2307. value?: string;
  2308. onChange?: (value: string) => void;
  2309. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2310. }
  2311. export class TextInputLineComponent extends React.Component<ITextInputLineComponentProps, {
  2312. value: string;
  2313. }> {
  2314. private _localChange;
  2315. constructor(props: ITextInputLineComponentProps);
  2316. componentWillUnmount(): void;
  2317. shouldComponentUpdate(nextProps: ITextInputLineComponentProps, nextState: {
  2318. value: string;
  2319. }): boolean;
  2320. raiseOnPropertyChanged(newValue: string, previousValue: string): void;
  2321. updateValue(value: string): void;
  2322. render(): JSX.Element;
  2323. }
  2324. }
  2325. declare module GUIEDITOR {
  2326. interface IValueLineComponentProps {
  2327. label: string;
  2328. value: number;
  2329. color?: string;
  2330. fractionDigits?: number;
  2331. units?: string;
  2332. }
  2333. export class ValueLineComponent extends React.Component<IValueLineComponentProps> {
  2334. constructor(props: IValueLineComponentProps);
  2335. render(): JSX.Element;
  2336. }
  2337. }
  2338. declare module GUIEDITOR {
  2339. interface IVector2LineComponentProps {
  2340. label: string;
  2341. target: any;
  2342. propertyName: string;
  2343. step?: number;
  2344. onChange?: (newvalue: BABYLON.Vector2) => void;
  2345. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2346. }
  2347. export class Vector2LineComponent extends React.Component<IVector2LineComponentProps, {
  2348. isExpanded: boolean;
  2349. value: BABYLON.Vector2;
  2350. }> {
  2351. static defaultProps: {
  2352. step: number;
  2353. };
  2354. private _localChange;
  2355. constructor(props: IVector2LineComponentProps);
  2356. shouldComponentUpdate(nextProps: IVector2LineComponentProps, nextState: {
  2357. isExpanded: boolean;
  2358. value: BABYLON.Vector2;
  2359. }): boolean;
  2360. switchExpandState(): void;
  2361. raiseOnPropertyChanged(previousValue: BABYLON.Vector2): void;
  2362. updateStateX(value: number): void;
  2363. updateStateY(value: number): void;
  2364. render(): JSX.Element;
  2365. }
  2366. }
  2367. declare module GUIEDITOR {
  2368. interface IVector3LineComponentProps {
  2369. label: string;
  2370. target: any;
  2371. propertyName: string;
  2372. step?: number;
  2373. onChange?: (newvalue: BABYLON.Vector3) => void;
  2374. useEuler?: boolean;
  2375. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2376. noSlider?: boolean;
  2377. }
  2378. export class Vector3LineComponent extends React.Component<IVector3LineComponentProps, {
  2379. isExpanded: boolean;
  2380. value: BABYLON.Vector3;
  2381. }> {
  2382. static defaultProps: {
  2383. step: number;
  2384. };
  2385. private _localChange;
  2386. constructor(props: IVector3LineComponentProps);
  2387. getCurrentValue(): any;
  2388. shouldComponentUpdate(nextProps: IVector3LineComponentProps, nextState: {
  2389. isExpanded: boolean;
  2390. value: BABYLON.Vector3;
  2391. }): boolean;
  2392. switchExpandState(): void;
  2393. raiseOnPropertyChanged(previousValue: BABYLON.Vector3): void;
  2394. updateVector3(): void;
  2395. updateStateX(value: number): void;
  2396. updateStateY(value: number): void;
  2397. updateStateZ(value: number): void;
  2398. render(): JSX.Element;
  2399. }
  2400. }
  2401. declare module GUIEDITOR {
  2402. interface IVector4LineComponentProps {
  2403. label: string;
  2404. target: any;
  2405. propertyName: string;
  2406. step?: number;
  2407. onChange?: (newvalue: BABYLON.Vector4) => void;
  2408. useEuler?: boolean;
  2409. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2410. }
  2411. export class Vector4LineComponent extends React.Component<IVector4LineComponentProps, {
  2412. isExpanded: boolean;
  2413. value: BABYLON.Vector4;
  2414. }> {
  2415. static defaultProps: {
  2416. step: number;
  2417. };
  2418. private _localChange;
  2419. constructor(props: IVector4LineComponentProps);
  2420. getCurrentValue(): any;
  2421. shouldComponentUpdate(nextProps: IVector4LineComponentProps, nextState: {
  2422. isExpanded: boolean;
  2423. value: BABYLON.Vector4;
  2424. }): boolean;
  2425. switchExpandState(): void;
  2426. raiseOnPropertyChanged(previousValue: BABYLON.Vector4): void;
  2427. updateVector4(): void;
  2428. updateStateX(value: number): void;
  2429. updateStateY(value: number): void;
  2430. updateStateZ(value: number): void;
  2431. updateStateW(value: number): void;
  2432. render(): JSX.Element;
  2433. }
  2434. }