babylon.inspector.module.d.ts 133 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161
  1. /// <reference types="react" />
  2. declare module "babylonjs-inspector/components/propertyChangedEvent" {
  3. export class PropertyChangedEvent {
  4. object: any;
  5. property: string;
  6. value: any;
  7. initialValue: any;
  8. }
  9. }
  10. declare module "babylonjs-inspector/components/globalState" {
  11. import { GLTFFileLoader, IGLTFLoaderExtension } from "babylonjs-loaders/glTF/index";
  12. import { IGLTFValidationResults } from "babylonjs-gltf2interface";
  13. import { Nullable } from "babylonjs/types";
  14. import { Observable, Observer } from "babylonjs/Misc/observable";
  15. import { ISceneLoaderPlugin, ISceneLoaderPluginAsync } from "babylonjs/Loading/sceneLoader";
  16. import { Scene } from "babylonjs/scene";
  17. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  18. export class GlobalState {
  19. onSelectionChangedObservable: Observable<string>;
  20. onPropertyChangedObservable: Observable<PropertyChangedEvent>;
  21. onInspectorClosedObservable: Observable<Scene>;
  22. onTabChangedObservable: Observable<number>;
  23. onPluginActivatedObserver: Nullable<Observer<ISceneLoaderPlugin | ISceneLoaderPluginAsync>>;
  24. validationResults: IGLTFValidationResults;
  25. onValidationResultsUpdatedObservable: Observable<IGLTFValidationResults>;
  26. onExtensionLoadedObservable: Observable<IGLTFLoaderExtension>;
  27. glTFLoaderExtensionDefaults: {
  28. [name: string]: {
  29. [key: string]: any;
  30. };
  31. };
  32. glTFLoaderDefaults: {
  33. [key: string]: any;
  34. };
  35. blockMutationUpdates: boolean;
  36. prepareGLTFPlugin(loader: GLTFFileLoader): void;
  37. }
  38. }
  39. declare module "babylonjs-inspector/components/actionTabs/paneComponent" {
  40. import * as React from "react";
  41. import { Observable } from "babylonjs/Misc/observable";
  42. import { Scene } from "babylonjs/scene";
  43. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  44. import { GlobalState } from "babylonjs-inspector/components/globalState";
  45. export interface IPaneComponentProps {
  46. title: string;
  47. scene: Scene;
  48. selectedEntity?: any;
  49. onSelectionChangedObservable?: Observable<any>;
  50. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  51. globalState: GlobalState;
  52. }
  53. export class PaneComponent extends React.Component<IPaneComponentProps, {
  54. tag: any;
  55. }> {
  56. constructor(props: IPaneComponentProps);
  57. render(): JSX.Element | null;
  58. }
  59. }
  60. declare module "babylonjs-inspector/components/actionTabs/tabsComponent" {
  61. import * as React from "react";
  62. import { PaneComponent } from "babylonjs-inspector/components/actionTabs/paneComponent";
  63. interface ITabsComponentProps {
  64. children: any[];
  65. selectedIndex: number;
  66. onSelectedIndexChange: (value: number) => void;
  67. }
  68. export class TabsComponent extends React.Component<ITabsComponentProps> {
  69. constructor(props: ITabsComponentProps);
  70. onSelect(index: number): void;
  71. renderLabel(child: PaneComponent, index: number): JSX.Element;
  72. render(): JSX.Element;
  73. }
  74. }
  75. declare module "babylonjs-inspector/components/actionTabs/lines/textLineComponent" {
  76. import * as React from "react";
  77. interface ITextLineComponentProps {
  78. label: string;
  79. value: string;
  80. color?: string;
  81. underline?: boolean;
  82. onLink?: () => void;
  83. }
  84. export class TextLineComponent extends React.Component<ITextLineComponentProps> {
  85. constructor(props: ITextLineComponentProps);
  86. onLink(): void;
  87. renderContent(): JSX.Element;
  88. render(): JSX.Element;
  89. }
  90. }
  91. declare module "babylonjs-inspector/components/actionTabs/lineContainerComponent" {
  92. import * as React from "react";
  93. interface ILineContainerComponentProps {
  94. title: string;
  95. children: any[] | any;
  96. closed?: boolean;
  97. }
  98. export class LineContainerComponent extends React.Component<ILineContainerComponentProps, {
  99. isExpanded: boolean;
  100. }> {
  101. private static _InMemoryStorage;
  102. constructor(props: ILineContainerComponentProps);
  103. switchExpandedState(): void;
  104. renderHeader(): JSX.Element;
  105. render(): JSX.Element;
  106. }
  107. }
  108. declare module "babylonjs-inspector/components/actionTabs/lines/valueLineComponent" {
  109. import * as React from "react";
  110. interface IValueLineComponentProps {
  111. label: string;
  112. value: number;
  113. color?: string;
  114. fractionDigits?: number;
  115. units?: string;
  116. }
  117. export class ValueLineComponent extends React.Component<IValueLineComponentProps> {
  118. constructor(props: IValueLineComponentProps);
  119. render(): JSX.Element;
  120. }
  121. }
  122. declare module "babylonjs-inspector/components/actionTabs/lines/booleanLineComponent" {
  123. import * as React from "react";
  124. export interface IBooleanLineComponentProps {
  125. label: string;
  126. value: boolean;
  127. }
  128. export class BooleanLineComponent extends React.Component<IBooleanLineComponentProps> {
  129. constructor(props: IBooleanLineComponentProps);
  130. render(): JSX.Element;
  131. }
  132. }
  133. declare module "babylonjs-inspector/components/actionTabs/tabs/statisticsTabComponent" {
  134. import { PaneComponent, IPaneComponentProps } from "babylonjs-inspector/components/actionTabs/paneComponent";
  135. export class StatisticsTabComponent extends PaneComponent {
  136. private _sceneInstrumentation;
  137. private _engineInstrumentation;
  138. private _timerIntervalId;
  139. constructor(props: IPaneComponentProps);
  140. componentWillMount(): void;
  141. componentWillUnmount(): void;
  142. render(): JSX.Element | null;
  143. }
  144. }
  145. declare module "babylonjs-inspector/components/actionTabs/lines/checkBoxLineComponent" {
  146. import * as React from "react";
  147. import { Observable } from "babylonjs/Misc/observable";
  148. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  149. export interface ICheckBoxLineComponentProps {
  150. label: string;
  151. target?: any;
  152. propertyName?: string;
  153. isSelected?: () => boolean;
  154. onSelect?: (value: boolean) => void;
  155. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  156. }
  157. export class CheckBoxLineComponent extends React.Component<ICheckBoxLineComponentProps, {
  158. isSelected: boolean;
  159. }> {
  160. private static _UniqueIdSeed;
  161. private _uniqueId;
  162. private _localChange;
  163. constructor(props: ICheckBoxLineComponentProps);
  164. shouldComponentUpdate(nextProps: ICheckBoxLineComponentProps, nextState: {
  165. isSelected: boolean;
  166. }): boolean;
  167. onChange(): void;
  168. render(): JSX.Element;
  169. }
  170. }
  171. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/renderGridPropertyGridComponent" {
  172. import * as React from "react";
  173. import { Scene } from "babylonjs/scene";
  174. interface IRenderGridPropertyGridComponentProps {
  175. scene: Scene;
  176. }
  177. export class RenderGridPropertyGridComponent extends React.Component<IRenderGridPropertyGridComponentProps, {
  178. isEnabled: boolean;
  179. }> {
  180. private _gridMesh;
  181. constructor(props: IRenderGridPropertyGridComponentProps);
  182. componentWillMount(): void;
  183. addOrRemoveGrid(): void;
  184. render(): JSX.Element;
  185. }
  186. }
  187. declare module "babylonjs-inspector/components/actionTabs/tabs/debugTabComponent" {
  188. import { PaneComponent, IPaneComponentProps } from "babylonjs-inspector/components/actionTabs/paneComponent";
  189. export class DebugTabComponent extends PaneComponent {
  190. private _skeletonViewersEnabled;
  191. private _physicsViewersEnabled;
  192. private _skeletonViewers;
  193. constructor(props: IPaneComponentProps);
  194. componentWillMount(): void;
  195. componentWillUnmount(): void;
  196. switchSkeletonViewers(): void;
  197. switchPhysicsViewers(): void;
  198. render(): JSX.Element | null;
  199. }
  200. }
  201. declare module "babylonjs-inspector/components/actionTabs/lines/sliderLineComponent" {
  202. import * as React from "react";
  203. import { Observable } from "babylonjs/Misc/observable";
  204. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  205. interface ISliderLineComponentProps {
  206. label: string;
  207. target?: any;
  208. propertyName?: string;
  209. minimum: number;
  210. maximum: number;
  211. step: number;
  212. directValue?: number;
  213. onChange?: (value: number) => void;
  214. onInput?: (value: number) => void;
  215. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  216. }
  217. export class SliderLineComponent extends React.Component<ISliderLineComponentProps, {
  218. value: number;
  219. }> {
  220. private _localChange;
  221. constructor(props: ISliderLineComponentProps);
  222. shouldComponentUpdate(nextProps: ISliderLineComponentProps, nextState: {
  223. value: number;
  224. }): boolean;
  225. onChange(newValueString: any): void;
  226. onInput(newValueString: any): void;
  227. render(): JSX.Element;
  228. }
  229. }
  230. declare module "babylonjs-inspector/components/actionTabs/lines/optionsLineComponent" {
  231. import * as React from "react";
  232. import { Observable } from "babylonjs/Misc/observable";
  233. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  234. class ListLineOption {
  235. label: string;
  236. value: number;
  237. }
  238. interface IOptionsLineComponentProps {
  239. label: string;
  240. target: any;
  241. propertyName: string;
  242. options: ListLineOption[];
  243. noDirectUpdate?: boolean;
  244. onSelect?: (value: number) => void;
  245. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  246. }
  247. export class OptionsLineComponent extends React.Component<IOptionsLineComponentProps, {
  248. value: number;
  249. }> {
  250. private _localChange;
  251. constructor(props: IOptionsLineComponentProps);
  252. shouldComponentUpdate(nextProps: IOptionsLineComponentProps, nextState: {
  253. value: number;
  254. }): boolean;
  255. raiseOnPropertyChanged(newValue: number, previousValue: number): void;
  256. updateValue(valueString: string): void;
  257. render(): JSX.Element;
  258. }
  259. }
  260. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject" {
  261. /**
  262. * Class used to provide lock mechanism
  263. */
  264. export class LockObject {
  265. /**
  266. * Gets or set if the lock is engaged
  267. */
  268. lock: boolean;
  269. }
  270. }
  271. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/materials/commonMaterialPropertyGridComponent" {
  272. import * as React from "react";
  273. import { Observable } from "babylonjs/Misc/observable";
  274. import { Material } from "babylonjs/Materials/material";
  275. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  276. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  277. interface ICommonMaterialPropertyGridComponentProps {
  278. material: Material;
  279. lockObject: LockObject;
  280. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  281. }
  282. export class CommonMaterialPropertyGridComponent extends React.Component<ICommonMaterialPropertyGridComponentProps> {
  283. constructor(props: ICommonMaterialPropertyGridComponentProps);
  284. render(): JSX.Element;
  285. }
  286. }
  287. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/materials/materialPropertyGridComponent" {
  288. import * as React from "react";
  289. import { Observable } from "babylonjs/Misc/observable";
  290. import { Material } from "babylonjs/Materials/material";
  291. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  292. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  293. interface IMaterialPropertyGridComponentProps {
  294. material: Material;
  295. lockObject: LockObject;
  296. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  297. }
  298. export class MaterialPropertyGridComponent extends React.Component<IMaterialPropertyGridComponentProps> {
  299. constructor(props: IMaterialPropertyGridComponentProps);
  300. render(): JSX.Element;
  301. }
  302. }
  303. declare module "babylonjs-inspector/components/actionTabs/lines/numericInputComponent" {
  304. import * as React from "react";
  305. interface INumericInputComponentProps {
  306. label: string;
  307. value: number;
  308. onChange: (value: number) => void;
  309. }
  310. export class NumericInputComponent extends React.Component<INumericInputComponentProps, {
  311. value: string;
  312. }> {
  313. private _localChange;
  314. constructor(props: INumericInputComponentProps);
  315. shouldComponentUpdate(nextProps: INumericInputComponentProps, nextState: {
  316. value: string;
  317. }): boolean;
  318. updateValue(evt: any): void;
  319. render(): JSX.Element;
  320. }
  321. }
  322. declare module "babylonjs-inspector/components/actionTabs/lines/color3LineComponent" {
  323. import * as React from "react";
  324. import { Observable } from "babylonjs/Misc/observable";
  325. import { Color3 } from "babylonjs/Maths/math";
  326. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  327. export interface IColor3LineComponentProps {
  328. label: string;
  329. target: any;
  330. propertyName: string;
  331. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  332. }
  333. export class Color3LineComponent extends React.Component<IColor3LineComponentProps, {
  334. isExpanded: boolean;
  335. color: Color3;
  336. }> {
  337. private _localChange;
  338. constructor(props: IColor3LineComponentProps);
  339. shouldComponentUpdate(nextProps: IColor3LineComponentProps, nextState: {
  340. color: Color3;
  341. }): boolean;
  342. onChange(newValue: string): void;
  343. switchExpandState(): void;
  344. raiseOnPropertyChanged(previousValue: Color3): void;
  345. updateStateR(value: number): void;
  346. updateStateG(value: number): void;
  347. updateStateB(value: number): void;
  348. copyToClipboard(): void;
  349. render(): JSX.Element;
  350. }
  351. }
  352. declare module "babylonjs-inspector/components/actionTabs/lines/textureLinkLineComponent" {
  353. import * as React from "react";
  354. import { Nullable } from "babylonjs/types";
  355. import { Observable } from "babylonjs/Misc/observable";
  356. import { BaseTexture } from "babylonjs/Materials/Textures/baseTexture";
  357. import { Material } from "babylonjs/Materials/material";
  358. export interface ITextureLinkLineComponentProps {
  359. label: string;
  360. texture: Nullable<BaseTexture>;
  361. material?: Material;
  362. onSelectionChangedObservable?: Observable<any>;
  363. onDebugSelectionChangeObservable?: Observable<BaseTexture>;
  364. }
  365. export class TextureLinkLineComponent extends React.Component<ITextureLinkLineComponentProps, {
  366. isDebugSelected: boolean;
  367. }> {
  368. private _onDebugSelectionChangeObserver;
  369. constructor(props: ITextureLinkLineComponentProps);
  370. componentWillMount(): void;
  371. componentWillUnmount(): void;
  372. debugTexture(): void;
  373. onLink(): void;
  374. render(): JSX.Element | null;
  375. }
  376. }
  377. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/materials/standardMaterialPropertyGridComponent" {
  378. import * as React from "react";
  379. import { Observable } from "babylonjs/Misc/observable";
  380. import { StandardMaterial } from "babylonjs/Materials/standardMaterial";
  381. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  382. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  383. interface IStandardMaterialPropertyGridComponentProps {
  384. material: StandardMaterial;
  385. lockObject: LockObject;
  386. onSelectionChangedObservable?: Observable<any>;
  387. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  388. }
  389. export class StandardMaterialPropertyGridComponent extends React.Component<IStandardMaterialPropertyGridComponentProps> {
  390. constructor(props: IStandardMaterialPropertyGridComponentProps);
  391. renderTextures(): JSX.Element | null;
  392. render(): JSX.Element;
  393. }
  394. }
  395. declare module "babylonjs-inspector/components/actionTabs/lines/textureLineComponent" {
  396. import * as React from "react";
  397. import { BaseTexture } from "babylonjs/Materials/Textures/baseTexture";
  398. import { GlobalState } from "babylonjs-inspector/components/globalState";
  399. interface ITextureLineComponentProps {
  400. texture: BaseTexture;
  401. width: number;
  402. height: number;
  403. globalState: GlobalState;
  404. }
  405. export class TextureLineComponent extends React.Component<ITextureLineComponentProps, {
  406. displayRed: boolean;
  407. displayGreen: boolean;
  408. displayBlue: boolean;
  409. displayAlpha: boolean;
  410. face: number;
  411. }> {
  412. constructor(props: ITextureLineComponentProps);
  413. shouldComponentUpdate(nextProps: ITextureLineComponentProps, nextState: {
  414. displayRed: boolean;
  415. displayGreen: boolean;
  416. displayBlue: boolean;
  417. displayAlpha: boolean;
  418. face: number;
  419. }): boolean;
  420. componentDidMount(): void;
  421. componentDidUpdate(): void;
  422. updatePreview(): void;
  423. render(): JSX.Element;
  424. }
  425. }
  426. declare module "babylonjs-inspector/components/actionTabs/lines/floatLineComponent" {
  427. import * as React from "react";
  428. import { Observable } from "babylonjs/Misc/observable";
  429. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  430. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  431. interface IFloatLineComponentProps {
  432. label: string;
  433. target: any;
  434. propertyName: string;
  435. lockObject?: LockObject;
  436. onChange?: (newValue: number) => void;
  437. isInteger?: boolean;
  438. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  439. additionalClass?: string;
  440. }
  441. export class FloatLineComponent extends React.Component<IFloatLineComponentProps, {
  442. value: string;
  443. }> {
  444. private _localChange;
  445. private _store;
  446. constructor(props: IFloatLineComponentProps);
  447. componentWillUnmount(): void;
  448. shouldComponentUpdate(nextProps: IFloatLineComponentProps, nextState: {
  449. value: string;
  450. }): boolean;
  451. raiseOnPropertyChanged(newValue: number, previousValue: number): void;
  452. updateValue(valueString: string): void;
  453. lock(): void;
  454. unlock(): void;
  455. render(): JSX.Element;
  456. }
  457. }
  458. declare module "babylonjs-inspector/components/actionTabs/lines/fileButtonLineComponent" {
  459. import * as React from "react";
  460. interface IFileButtonLineComponentProps {
  461. label: string;
  462. onClick: (file: File) => void;
  463. accept: string;
  464. }
  465. export class FileButtonLineComponent extends React.Component<IFileButtonLineComponentProps> {
  466. constructor(props: IFileButtonLineComponentProps);
  467. onChange(evt: any): void;
  468. render(): JSX.Element;
  469. }
  470. }
  471. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/materials/texturePropertyGridComponent" {
  472. import * as React from "react";
  473. import { Observable } from "babylonjs/Misc/observable";
  474. import { BaseTexture } from "babylonjs/Materials/Textures/baseTexture";
  475. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  476. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  477. import { GlobalState } from "babylonjs-inspector/components/globalState";
  478. interface ITexturePropertyGridComponentProps {
  479. texture: BaseTexture;
  480. lockObject: LockObject;
  481. globalState: GlobalState;
  482. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  483. }
  484. export class TexturePropertyGridComponent extends React.Component<ITexturePropertyGridComponentProps> {
  485. private _adtInstrumentation;
  486. constructor(props: ITexturePropertyGridComponentProps);
  487. componentWillMount(): void;
  488. componentWillUnmount(): void;
  489. updateTexture(file: File): void;
  490. render(): JSX.Element;
  491. }
  492. }
  493. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/materials/pbrMaterialPropertyGridComponent" {
  494. import * as React from "react";
  495. import { Observable } from "babylonjs/Misc/observable";
  496. import { PBRMaterial } from "babylonjs/Materials/PBR/pbrMaterial";
  497. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  498. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  499. interface IPBRMaterialPropertyGridComponentProps {
  500. material: PBRMaterial;
  501. lockObject: LockObject;
  502. onSelectionChangedObservable?: Observable<any>;
  503. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  504. }
  505. export class PBRMaterialPropertyGridComponent extends React.Component<IPBRMaterialPropertyGridComponentProps> {
  506. constructor(props: IPBRMaterialPropertyGridComponentProps);
  507. renderTextures(): JSX.Element | null;
  508. render(): JSX.Element;
  509. }
  510. }
  511. declare module "babylonjs-inspector/components/actionTabs/lines/radioLineComponent" {
  512. import * as React from "react";
  513. import { Observable } from "babylonjs/Misc/observable";
  514. interface IRadioButtonLineComponentProps {
  515. onSelectionChangedObservable: Observable<RadioButtonLineComponent>;
  516. label: string;
  517. isSelected: () => boolean;
  518. onSelect: () => void;
  519. }
  520. export class RadioButtonLineComponent extends React.Component<IRadioButtonLineComponentProps, {
  521. isSelected: boolean;
  522. }> {
  523. private _onSelectionChangedObserver;
  524. constructor(props: IRadioButtonLineComponentProps);
  525. componentWillMount(): void;
  526. componentWillUnmount(): void;
  527. onChange(): void;
  528. render(): JSX.Element;
  529. }
  530. }
  531. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/fogPropertyGridComponent" {
  532. import * as React from "react";
  533. import { Observable } from "babylonjs/Misc/observable";
  534. import { Scene } from "babylonjs/scene";
  535. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  536. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  537. interface IFogPropertyGridComponentProps {
  538. scene: Scene;
  539. lockObject: LockObject;
  540. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  541. }
  542. export class FogPropertyGridComponent extends React.Component<IFogPropertyGridComponentProps, {
  543. mode: number;
  544. }> {
  545. constructor(props: IFogPropertyGridComponentProps);
  546. render(): JSX.Element;
  547. }
  548. }
  549. declare module "babylonjs-inspector/components/actionTabs/lines/vector3LineComponent" {
  550. import * as React from "react";
  551. import { Vector3 } from "babylonjs/Maths/math";
  552. import { Observable } from "babylonjs/Misc/observable";
  553. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  554. interface IVector3LineComponentProps {
  555. label: string;
  556. target: any;
  557. propertyName: string;
  558. onChange?: (newvalue: Vector3) => void;
  559. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  560. }
  561. export class Vector3LineComponent extends React.Component<IVector3LineComponentProps, {
  562. isExpanded: boolean;
  563. value: Vector3;
  564. }> {
  565. private _localChange;
  566. constructor(props: IVector3LineComponentProps);
  567. shouldComponentUpdate(nextProps: IVector3LineComponentProps, nextState: {
  568. isExpanded: boolean;
  569. value: Vector3;
  570. }): boolean;
  571. switchExpandState(): void;
  572. raiseOnPropertyChanged(previousValue: Vector3): void;
  573. updateStateX(value: number): void;
  574. updateStateY(value: number): void;
  575. updateStateZ(value: number): void;
  576. render(): JSX.Element;
  577. }
  578. }
  579. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/scenePropertyGridComponent" {
  580. import * as React from "react";
  581. import { Observable } from "babylonjs/Misc/observable";
  582. import { Vector3 } from "babylonjs/Maths/math";
  583. import { Scene } from "babylonjs/scene";
  584. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  585. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  586. interface IScenePropertyGridComponentProps {
  587. scene: Scene;
  588. lockObject: LockObject;
  589. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  590. onSelectionChangedObservable?: Observable<any>;
  591. }
  592. export class ScenePropertyGridComponent extends React.Component<IScenePropertyGridComponentProps> {
  593. private _storedEnvironmentTexture;
  594. private _renderingModeGroupObservable;
  595. constructor(props: IScenePropertyGridComponentProps);
  596. setRenderingModes(point: boolean, wireframe: boolean): void;
  597. switchIBL(): void;
  598. updateEnvironmentTexture(file: File): void;
  599. updateGravity(newValue: Vector3): void;
  600. updateTimeStep(newValue: number): void;
  601. render(): JSX.Element;
  602. }
  603. }
  604. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lights/commonLightPropertyGridComponent" {
  605. import * as React from "react";
  606. import { Observable } from "babylonjs/Misc/observable";
  607. import { Light } from "babylonjs/Lights/light";
  608. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  609. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  610. interface ICommonLightPropertyGridComponentProps {
  611. light: Light;
  612. lockObject: LockObject;
  613. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  614. }
  615. export class CommonLightPropertyGridComponent extends React.Component<ICommonLightPropertyGridComponentProps> {
  616. constructor(props: ICommonLightPropertyGridComponentProps);
  617. render(): JSX.Element;
  618. }
  619. }
  620. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lights/hemisphericLightPropertyGridComponent" {
  621. import * as React from "react";
  622. import { Observable } from "babylonjs/Misc/observable";
  623. import { HemisphericLight } from "babylonjs/Lights/hemisphericLight";
  624. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  625. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  626. interface IHemisphericLightPropertyGridComponentProps {
  627. light: HemisphericLight;
  628. lockObject: LockObject;
  629. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  630. }
  631. export class HemisphericLightPropertyGridComponent extends React.Component<IHemisphericLightPropertyGridComponentProps> {
  632. constructor(props: IHemisphericLightPropertyGridComponentProps);
  633. render(): JSX.Element;
  634. }
  635. }
  636. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lights/commonShadowLightPropertyGridComponent" {
  637. import * as React from "react";
  638. import { Observable } from "babylonjs/Misc/observable";
  639. import { IShadowLight } from "babylonjs/Lights/shadowLight";
  640. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  641. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  642. interface ICommonShadowLightPropertyGridComponentProps {
  643. light: IShadowLight;
  644. lockObject: LockObject;
  645. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  646. }
  647. export class CommonShadowLightPropertyGridComponent extends React.Component<ICommonShadowLightPropertyGridComponentProps> {
  648. constructor(props: ICommonShadowLightPropertyGridComponentProps);
  649. render(): JSX.Element;
  650. }
  651. }
  652. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lights/pointLightPropertyGridComponent" {
  653. import * as React from "react";
  654. import { Observable } from "babylonjs/Misc/observable";
  655. import { PointLight } from "babylonjs/Lights/pointLight";
  656. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  657. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  658. interface IPointLightPropertyGridComponentProps {
  659. light: PointLight;
  660. lockObject: LockObject;
  661. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  662. }
  663. export class PointLightPropertyGridComponent extends React.Component<IPointLightPropertyGridComponentProps> {
  664. constructor(props: IPointLightPropertyGridComponentProps);
  665. render(): JSX.Element;
  666. }
  667. }
  668. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/cameras/commonCameraPropertyGridComponent" {
  669. import * as React from "react";
  670. import { Camera } from "babylonjs/Cameras/camera";
  671. import { Observable } from "babylonjs/Misc/observable";
  672. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  673. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  674. interface ICommonCameraPropertyGridComponentProps {
  675. camera: Camera;
  676. lockObject: LockObject;
  677. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  678. }
  679. export class CommonCameraPropertyGridComponent extends React.Component<ICommonCameraPropertyGridComponentProps, {
  680. mode: number;
  681. }> {
  682. constructor(props: ICommonCameraPropertyGridComponentProps);
  683. render(): JSX.Element;
  684. }
  685. }
  686. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/cameras/freeCameraPropertyGridComponent" {
  687. import * as React from "react";
  688. import { FreeCamera } from "babylonjs/Cameras/freeCamera";
  689. import { Observable } from "babylonjs/Misc/observable";
  690. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  691. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  692. interface IFreeCameraPropertyGridComponentProps {
  693. camera: FreeCamera;
  694. lockObject: LockObject;
  695. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  696. }
  697. export class FreeCameraPropertyGridComponent extends React.Component<IFreeCameraPropertyGridComponentProps> {
  698. constructor(props: IFreeCameraPropertyGridComponentProps);
  699. render(): JSX.Element;
  700. }
  701. }
  702. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/cameras/arcRotateCameraPropertyGridComponent" {
  703. import * as React from "react";
  704. import { ArcRotateCamera } from "babylonjs/Cameras/arcRotateCamera";
  705. import { Observable } from "babylonjs/Misc/observable";
  706. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  707. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  708. interface IArcRotateCameraPropertyGridComponentProps {
  709. camera: ArcRotateCamera;
  710. lockObject: LockObject;
  711. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  712. }
  713. export class ArcRotateCameraPropertyGridComponent extends React.Component<IArcRotateCameraPropertyGridComponentProps> {
  714. constructor(props: IArcRotateCameraPropertyGridComponentProps);
  715. render(): JSX.Element;
  716. }
  717. }
  718. declare module "babylonjs-inspector/components/actionTabs/lines/quaternionLineComponent" {
  719. import * as React from "react";
  720. import { Observable } from "babylonjs/Misc/observable";
  721. import { Quaternion } from "babylonjs/Maths/math";
  722. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  723. interface IQuaternionLineComponentProps {
  724. label: string;
  725. target: any;
  726. propertyName: string;
  727. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  728. }
  729. export class QuaternionLineComponent extends React.Component<IQuaternionLineComponentProps, {
  730. isExpanded: boolean;
  731. value: Quaternion;
  732. }> {
  733. private _localChange;
  734. constructor(props: IQuaternionLineComponentProps);
  735. shouldComponentUpdate(nextProps: IQuaternionLineComponentProps, nextState: {
  736. isExpanded: boolean;
  737. value: Quaternion;
  738. }): boolean;
  739. switchExpandState(): void;
  740. raiseOnPropertyChanged(currentValue: Quaternion, previousValue: Quaternion): void;
  741. updateQuaternion(): void;
  742. updateStateX(value: number): void;
  743. updateStateY(value: number): void;
  744. updateStateZ(value: number): void;
  745. updateStateW(value: number): void;
  746. render(): JSX.Element;
  747. }
  748. }
  749. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/meshes/axesViewerComponent" {
  750. import * as React from "react";
  751. import { TransformNode } from "babylonjs/Meshes/transformNode";
  752. interface IAxisViewerComponentProps {
  753. node: TransformNode;
  754. }
  755. export class AxesViewerComponent extends React.Component<IAxisViewerComponentProps, {
  756. displayAxis: boolean;
  757. }> {
  758. constructor(props: IAxisViewerComponentProps);
  759. displayAxes(): void;
  760. render(): JSX.Element;
  761. }
  762. }
  763. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/meshes/meshPropertyGridComponent" {
  764. import * as React from "react";
  765. import { Observable } from "babylonjs/Misc/observable";
  766. import { Mesh } from "babylonjs/Meshes/mesh";
  767. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  768. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  769. interface IMeshPropertyGridComponentProps {
  770. mesh: Mesh;
  771. lockObject: LockObject;
  772. onSelectionChangedObservable?: Observable<any>;
  773. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  774. }
  775. export class MeshPropertyGridComponent extends React.Component<IMeshPropertyGridComponentProps, {
  776. displayNormals: boolean;
  777. renderNormalVectors: boolean;
  778. }> {
  779. constructor(props: IMeshPropertyGridComponentProps);
  780. renderNormalVectors(): void;
  781. displayNormals(): void;
  782. onMaterialLink(): void;
  783. convertPhysicsTypeToString(): string;
  784. render(): JSX.Element;
  785. }
  786. }
  787. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/meshes/transformNodePropertyGridComponent" {
  788. import * as React from "react";
  789. import { TransformNode } from "babylonjs/Meshes/transformNode";
  790. import { Observable } from "babylonjs/Misc/observable";
  791. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  792. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  793. interface ITransformNodePropertyGridComponentProps {
  794. transformNode: TransformNode;
  795. lockObject: LockObject;
  796. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  797. }
  798. export class TransformNodePropertyGridComponent extends React.Component<ITransformNodePropertyGridComponentProps> {
  799. constructor(props: ITransformNodePropertyGridComponentProps);
  800. render(): JSX.Element;
  801. }
  802. }
  803. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/materials/backgroundMaterialPropertyGridComponent" {
  804. import * as React from "react";
  805. import { Observable } from "babylonjs/Misc/observable";
  806. import { BackgroundMaterial } from "babylonjs/Materials/Background/backgroundMaterial";
  807. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  808. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  809. interface IBackgroundMaterialPropertyGridComponentProps {
  810. material: BackgroundMaterial;
  811. lockObject: LockObject;
  812. onSelectionChangedObservable?: Observable<any>;
  813. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  814. }
  815. export class BackgroundMaterialPropertyGridComponent extends React.Component<IBackgroundMaterialPropertyGridComponentProps> {
  816. constructor(props: IBackgroundMaterialPropertyGridComponentProps);
  817. renderTextures(): JSX.Element;
  818. render(): JSX.Element;
  819. }
  820. }
  821. declare module "babylonjs-inspector/components/actionTabs/lines/textInputLineComponent" {
  822. import * as React from "react";
  823. import { Observable } from "babylonjs/Misc/observable";
  824. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  825. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  826. interface ITextInputLineComponentProps {
  827. label: string;
  828. lockObject: LockObject;
  829. target?: any;
  830. propertyName?: string;
  831. value?: string;
  832. onChange?: (value: string) => void;
  833. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  834. }
  835. export class TextInputLineComponent extends React.Component<ITextInputLineComponentProps, {
  836. value: string;
  837. }> {
  838. private _localChange;
  839. constructor(props: ITextInputLineComponentProps);
  840. componentWillUnmount(): void;
  841. shouldComponentUpdate(nextProps: ITextInputLineComponentProps, nextState: {
  842. value: string;
  843. }): boolean;
  844. raiseOnPropertyChanged(newValue: string, previousValue: string): void;
  845. updateValue(value: string): void;
  846. render(): JSX.Element;
  847. }
  848. }
  849. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/gui/commonControlPropertyGridComponent" {
  850. import * as React from "react";
  851. import { Observable } from "babylonjs/Misc/observable";
  852. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  853. import { Control } from "babylonjs-gui/2D/controls/control";
  854. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  855. interface ICommonControlPropertyGridComponentProps {
  856. control: Control;
  857. lockObject: LockObject;
  858. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  859. }
  860. export class CommonControlPropertyGridComponent extends React.Component<ICommonControlPropertyGridComponentProps> {
  861. constructor(props: ICommonControlPropertyGridComponentProps);
  862. renderGridInformation(): JSX.Element | null;
  863. render(): JSX.Element;
  864. }
  865. }
  866. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/gui/controlPropertyGridComponent" {
  867. import * as React from "react";
  868. import { Observable } from "babylonjs/Misc/observable";
  869. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  870. import { Control } from "babylonjs-gui/2D/controls/control";
  871. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  872. interface IControlPropertyGridComponentProps {
  873. control: Control;
  874. lockObject: LockObject;
  875. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  876. }
  877. export class ControlPropertyGridComponent extends React.Component<IControlPropertyGridComponentProps> {
  878. constructor(props: IControlPropertyGridComponentProps);
  879. render(): JSX.Element;
  880. }
  881. }
  882. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/gui/textBlockPropertyGridComponent" {
  883. import * as React from "react";
  884. import { Observable } from "babylonjs/Misc/observable";
  885. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  886. import { TextBlock } from "babylonjs-gui/2D/controls/textBlock";
  887. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  888. interface ITextBlockPropertyGridComponentProps {
  889. textBlock: TextBlock;
  890. lockObject: LockObject;
  891. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  892. }
  893. export class TextBlockPropertyGridComponent extends React.Component<ITextBlockPropertyGridComponentProps> {
  894. constructor(props: ITextBlockPropertyGridComponentProps);
  895. render(): JSX.Element;
  896. }
  897. }
  898. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/gui/inputTextPropertyGridComponent" {
  899. import * as React from "react";
  900. import { Observable } from "babylonjs/Misc/observable";
  901. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  902. import { InputText } from "babylonjs-gui/2D/controls/inputText";
  903. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  904. interface IInputTextPropertyGridComponentProps {
  905. inputText: InputText;
  906. lockObject: LockObject;
  907. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  908. }
  909. export class InputTextPropertyGridComponent extends React.Component<IInputTextPropertyGridComponentProps> {
  910. constructor(props: IInputTextPropertyGridComponentProps);
  911. render(): JSX.Element;
  912. }
  913. }
  914. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/gui/colorPickerPropertyGridComponent" {
  915. import * as React from "react";
  916. import { Observable } from "babylonjs/Misc/observable";
  917. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  918. import { ColorPicker } from "babylonjs-gui/2D/controls/colorpicker";
  919. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  920. interface IColorPickerPropertyGridComponentProps {
  921. colorPicker: ColorPicker;
  922. lockObject: LockObject;
  923. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  924. }
  925. export class ColorPickerPropertyGridComponent extends React.Component<IColorPickerPropertyGridComponentProps> {
  926. constructor(props: IColorPickerPropertyGridComponentProps);
  927. render(): JSX.Element;
  928. }
  929. }
  930. declare module "babylonjs-inspector/components/actionTabs/lines/buttonLineComponent" {
  931. import * as React from "react";
  932. export interface IButtonLineComponentProps {
  933. label: string;
  934. onClick: () => void;
  935. }
  936. export class ButtonLineComponent extends React.Component<IButtonLineComponentProps> {
  937. constructor(props: IButtonLineComponentProps);
  938. render(): JSX.Element;
  939. }
  940. }
  941. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/animationGroupPropertyGridComponent" {
  942. import * as React from "react";
  943. import { Observable } from "babylonjs/Misc/observable";
  944. import { AnimationGroup } from "babylonjs/Animations/animationGroup";
  945. import { Scene } from "babylonjs/scene";
  946. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  947. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  948. interface IAnimationGroupGridComponentProps {
  949. animationGroup: AnimationGroup;
  950. scene: Scene;
  951. lockObject: LockObject;
  952. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  953. }
  954. export class AnimationGroupGridComponent extends React.Component<IAnimationGroupGridComponentProps, {
  955. playButtonText: string;
  956. currentFrame: number;
  957. }> {
  958. private _onAnimationGroupPlayObserver;
  959. private _onAnimationGroupPauseObserver;
  960. private _onBeforeRenderObserver;
  961. constructor(props: IAnimationGroupGridComponentProps);
  962. disconnect(animationGroup: AnimationGroup): void;
  963. connect(animationGroup: AnimationGroup): void;
  964. updateCurrentFrame(animationGroup: AnimationGroup): void;
  965. shouldComponentUpdate(nextProps: IAnimationGroupGridComponentProps): boolean;
  966. componentWillMount(): void;
  967. componentWillUnmount(): void;
  968. playOrPause(): void;
  969. onCurrentFrameChange(value: number): void;
  970. render(): JSX.Element;
  971. }
  972. }
  973. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/gui/imagePropertyGridComponent" {
  974. import * as React from "react";
  975. import { Observable } from "babylonjs/Misc/observable";
  976. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  977. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  978. import { Image } from "babylonjs-gui/2D/controls/image";
  979. interface IImagePropertyGridComponentProps {
  980. image: Image;
  981. lockObject: LockObject;
  982. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  983. }
  984. export class ImagePropertyGridComponent extends React.Component<IImagePropertyGridComponentProps> {
  985. constructor(props: IImagePropertyGridComponentProps);
  986. render(): JSX.Element;
  987. }
  988. }
  989. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/gui/sliderPropertyGridComponent" {
  990. import * as React from "react";
  991. import { Observable } from "babylonjs/Misc/observable";
  992. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  993. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  994. import { Slider } from "babylonjs-gui/2D/controls/sliders/slider";
  995. interface ISliderPropertyGridComponentProps {
  996. slider: Slider;
  997. lockObject: LockObject;
  998. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  999. }
  1000. export class SliderPropertyGridComponent extends React.Component<ISliderPropertyGridComponentProps> {
  1001. constructor(props: ISliderPropertyGridComponentProps);
  1002. render(): JSX.Element;
  1003. }
  1004. }
  1005. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/gui/imageBasedSliderPropertyGridComponent" {
  1006. import * as React from "react";
  1007. import { Observable } from "babylonjs/Misc/observable";
  1008. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  1009. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  1010. import { ImageBasedSlider } from "babylonjs-gui/2D/controls/sliders/imageBasedSlider";
  1011. interface IImageBasedSliderPropertyGridComponentProps {
  1012. imageBasedSlider: ImageBasedSlider;
  1013. lockObject: LockObject;
  1014. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1015. }
  1016. export class ImageBasedSliderPropertyGridComponent extends React.Component<IImageBasedSliderPropertyGridComponentProps> {
  1017. constructor(props: IImageBasedSliderPropertyGridComponentProps);
  1018. render(): JSX.Element;
  1019. }
  1020. }
  1021. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/gui/rectanglePropertyGridComponent" {
  1022. import * as React from "react";
  1023. import { Observable } from "babylonjs/Misc/observable";
  1024. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  1025. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  1026. import { Rectangle } from "babylonjs-gui/2D/controls/rectangle";
  1027. interface IRectanglePropertyGridComponentProps {
  1028. rectangle: Rectangle;
  1029. lockObject: LockObject;
  1030. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1031. }
  1032. export class RectanglePropertyGridComponent extends React.Component<IRectanglePropertyGridComponentProps> {
  1033. constructor(props: IRectanglePropertyGridComponentProps);
  1034. render(): JSX.Element;
  1035. }
  1036. }
  1037. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/gui/ellipsePropertyGridComponent" {
  1038. import * as React from "react";
  1039. import { Observable } from "babylonjs/Misc/observable";
  1040. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  1041. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  1042. import { Ellipse } from "babylonjs-gui/2D/controls/ellipse";
  1043. interface IEllipsePropertyGridComponentProps {
  1044. ellipse: Ellipse;
  1045. lockObject: LockObject;
  1046. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1047. }
  1048. export class EllipsePropertyGridComponent extends React.Component<IEllipsePropertyGridComponentProps> {
  1049. constructor(props: IEllipsePropertyGridComponentProps);
  1050. render(): JSX.Element;
  1051. }
  1052. }
  1053. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/gui/checkboxPropertyGridComponent" {
  1054. import * as React from "react";
  1055. import { Observable } from "babylonjs/Misc/observable";
  1056. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  1057. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  1058. import { Checkbox } from "babylonjs-gui/2D/controls/checkbox";
  1059. interface ICheckboxPropertyGridComponentProps {
  1060. checkbox: Checkbox;
  1061. lockObject: LockObject;
  1062. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1063. }
  1064. export class CheckboxPropertyGridComponent extends React.Component<ICheckboxPropertyGridComponentProps> {
  1065. constructor(props: ICheckboxPropertyGridComponentProps);
  1066. render(): JSX.Element;
  1067. }
  1068. }
  1069. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/gui/radioButtonPropertyGridComponent" {
  1070. import * as React from "react";
  1071. import { Observable } from "babylonjs/Misc/observable";
  1072. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  1073. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  1074. import { RadioButton } from "babylonjs-gui/2D/controls/radioButton";
  1075. interface IRadioButtonPropertyGridComponentProps {
  1076. radioButton: RadioButton;
  1077. lockObject: LockObject;
  1078. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1079. }
  1080. export class RadioButtonPropertyGridComponent extends React.Component<IRadioButtonPropertyGridComponentProps> {
  1081. constructor(props: IRadioButtonPropertyGridComponentProps);
  1082. render(): JSX.Element;
  1083. }
  1084. }
  1085. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/gui/linePropertyGridComponent" {
  1086. import * as React from "react";
  1087. import { Observable } from "babylonjs/Misc/observable";
  1088. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  1089. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  1090. import { Line } from "babylonjs-gui/2D/controls/line";
  1091. interface ILinePropertyGridComponentProps {
  1092. line: Line;
  1093. lockObject: LockObject;
  1094. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1095. }
  1096. export class LinePropertyGridComponent extends React.Component<ILinePropertyGridComponentProps> {
  1097. constructor(props: ILinePropertyGridComponentProps);
  1098. onDashChange(value: string): void;
  1099. render(): JSX.Element;
  1100. }
  1101. }
  1102. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/gui/scrollViewerPropertyGridComponent" {
  1103. import * as React from "react";
  1104. import { Observable } from "babylonjs/Misc/observable";
  1105. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  1106. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  1107. import { ScrollViewer } from "babylonjs-gui/2D/controls/scrollViewers/scrollViewer";
  1108. interface IScrollViewerPropertyGridComponentProps {
  1109. scrollViewer: ScrollViewer;
  1110. lockObject: LockObject;
  1111. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1112. }
  1113. export class ScrollViewerPropertyGridComponent extends React.Component<IScrollViewerPropertyGridComponentProps> {
  1114. constructor(props: IScrollViewerPropertyGridComponentProps);
  1115. render(): JSX.Element;
  1116. }
  1117. }
  1118. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/gui/gridPropertyGridComponent" {
  1119. import * as React from "react";
  1120. import { Observable } from "babylonjs/Misc/observable";
  1121. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  1122. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  1123. import { Grid } from "babylonjs-gui/2D/controls/grid";
  1124. interface IGridPropertyGridComponentProps {
  1125. grid: Grid;
  1126. lockObject: LockObject;
  1127. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1128. }
  1129. export class GridPropertyGridComponent extends React.Component<IGridPropertyGridComponentProps> {
  1130. constructor(props: IGridPropertyGridComponentProps);
  1131. renderRows(): JSX.Element[];
  1132. renderColumns(): JSX.Element[];
  1133. render(): JSX.Element;
  1134. }
  1135. }
  1136. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/materials/pbrMetallicRoughnessMaterialPropertyGridComponent" {
  1137. import * as React from "react";
  1138. import { Observable } from "babylonjs/Misc/observable";
  1139. import { PBRMetallicRoughnessMaterial } from "babylonjs/Materials/PBR/pbrMetallicRoughnessMaterial";
  1140. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  1141. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  1142. interface IPBRMetallicRoughnessMaterialPropertyGridComponentProps {
  1143. material: PBRMetallicRoughnessMaterial;
  1144. lockObject: LockObject;
  1145. onSelectionChangedObservable?: Observable<any>;
  1146. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1147. }
  1148. export class PBRMetallicRoughnessMaterialPropertyGridComponent extends React.Component<IPBRMetallicRoughnessMaterialPropertyGridComponentProps> {
  1149. constructor(props: IPBRMetallicRoughnessMaterialPropertyGridComponentProps);
  1150. renderTextures(): JSX.Element | null;
  1151. render(): JSX.Element;
  1152. }
  1153. }
  1154. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/materials/pbrSpecularGlossinessMaterialPropertyGridComponent" {
  1155. import * as React from "react";
  1156. import { Observable } from "babylonjs/Misc/observable";
  1157. import { PBRSpecularGlossinessMaterial } from "babylonjs/Materials/PBR/pbrSpecularGlossinessMaterial";
  1158. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  1159. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  1160. interface IPBRSpecularGlossinessMaterialPropertyGridComponentProps {
  1161. material: PBRSpecularGlossinessMaterial;
  1162. lockObject: LockObject;
  1163. onSelectionChangedObservable?: Observable<any>;
  1164. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1165. }
  1166. export class PBRSpecularGlossinessMaterialPropertyGridComponent extends React.Component<IPBRSpecularGlossinessMaterialPropertyGridComponentProps> {
  1167. constructor(props: IPBRSpecularGlossinessMaterialPropertyGridComponentProps);
  1168. renderTextures(): JSX.Element | null;
  1169. render(): JSX.Element;
  1170. }
  1171. }
  1172. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/gui/stackPanelPropertyGridComponent" {
  1173. import * as React from "react";
  1174. import { Observable } from "babylonjs/Misc/observable";
  1175. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  1176. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  1177. import { StackPanel } from "babylonjs-gui/2D/controls/stackPanel";
  1178. interface IStackPanelPropertyGridComponentProps {
  1179. stackPanel: StackPanel;
  1180. lockObject: LockObject;
  1181. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1182. }
  1183. export class StackPanelPropertyGridComponent extends React.Component<IStackPanelPropertyGridComponentProps> {
  1184. constructor(props: IStackPanelPropertyGridComponentProps);
  1185. render(): JSX.Element;
  1186. }
  1187. }
  1188. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGridTabComponent" {
  1189. import { PaneComponent, IPaneComponentProps } from "babylonjs-inspector/components/actionTabs/paneComponent";
  1190. export class PropertyGridTabComponent extends PaneComponent {
  1191. private _timerIntervalId;
  1192. private _lockObject;
  1193. constructor(props: IPaneComponentProps);
  1194. timerRefresh(): void;
  1195. componentWillMount(): void;
  1196. componentWillUnmount(): void;
  1197. render(): JSX.Element | null;
  1198. }
  1199. }
  1200. declare module "babylonjs-inspector/components/headerComponent" {
  1201. import * as React from "react";
  1202. import { Observable } from "babylonjs/Misc/observable";
  1203. export interface IHeaderComponentProps {
  1204. title: string;
  1205. handleBack?: boolean;
  1206. noExpand?: boolean;
  1207. noClose?: boolean;
  1208. noCommands?: boolean;
  1209. onPopup: () => void;
  1210. onClose: () => void;
  1211. onSelectionChangedObservable?: Observable<any>;
  1212. }
  1213. export class HeaderComponent extends React.Component<IHeaderComponentProps, {
  1214. isBackVisible: boolean;
  1215. }> {
  1216. private _backStack;
  1217. private _onSelectionChangeObserver;
  1218. constructor(props: IHeaderComponentProps);
  1219. componentWillMount(): void;
  1220. componentWillUnmount(): void;
  1221. goBack(): void;
  1222. renderLogo(): JSX.Element | null;
  1223. render(): JSX.Element;
  1224. }
  1225. }
  1226. declare module "babylonjs-inspector/components/actionTabs/lines/messageLineComponent" {
  1227. import * as React from "react";
  1228. interface IMessageLineComponentProps {
  1229. text: string;
  1230. color?: string;
  1231. }
  1232. export class MessageLineComponent extends React.Component<IMessageLineComponentProps> {
  1233. constructor(props: IMessageLineComponentProps);
  1234. render(): JSX.Element;
  1235. }
  1236. }
  1237. declare module "babylonjs-inspector/components/actionTabs/tabs/tools/gltfComponent" {
  1238. import * as React from "react";
  1239. import { Scene } from "babylonjs/scene";
  1240. import { GlobalState } from "babylonjs-inspector/components/globalState";
  1241. interface IGLTFComponentProps {
  1242. scene: Scene;
  1243. globalState: GlobalState;
  1244. }
  1245. export class GLTFComponent extends React.Component<IGLTFComponentProps> {
  1246. constructor(props: IGLTFComponentProps);
  1247. openValidationDetails(): void;
  1248. prepareText(singularForm: string, count: number): string;
  1249. renderValidation(): JSX.Element;
  1250. render(): JSX.Element;
  1251. }
  1252. }
  1253. declare module "babylonjs-inspector/components/actionTabs/tabs/toolsTabComponent" {
  1254. import { PaneComponent, IPaneComponentProps } from "babylonjs-inspector/components/actionTabs/paneComponent";
  1255. import { TransformNode } from "babylonjs/Meshes/transformNode";
  1256. export class ToolsTabComponent extends PaneComponent {
  1257. private _videoRecorder;
  1258. constructor(props: IPaneComponentProps);
  1259. componentWillMount(): void;
  1260. componentWillUnmount(): void;
  1261. captureScreenshot(): void;
  1262. recordVideo(): void;
  1263. shouldExport(transformNode: TransformNode): boolean;
  1264. exportGLTF(): void;
  1265. exportBabylon(): void;
  1266. createEnvTexture(): void;
  1267. render(): JSX.Element | null;
  1268. }
  1269. }
  1270. declare module "babylonjs-inspector/components/actionTabs/actionTabsComponent" {
  1271. import * as React from "react";
  1272. import { Scene } from "babylonjs/scene";
  1273. import { GlobalState } from "babylonjs-inspector/components/globalState";
  1274. interface IActionTabsComponentProps {
  1275. scene: Scene;
  1276. noCommands?: boolean;
  1277. noHeader?: boolean;
  1278. noExpand?: boolean;
  1279. noClose?: boolean;
  1280. popupMode?: boolean;
  1281. onPopup?: () => void;
  1282. onClose?: () => void;
  1283. globalState: GlobalState;
  1284. }
  1285. export class ActionTabsComponent extends React.Component<IActionTabsComponentProps, {
  1286. selectedEntity: any;
  1287. selectedIndex: number;
  1288. }> {
  1289. private _onSelectionChangeObserver;
  1290. private _onTabChangedObserver;
  1291. private _once;
  1292. constructor(props: IActionTabsComponentProps);
  1293. componentWillMount(): void;
  1294. componentWillUnmount(): void;
  1295. changeSelectedTab(index: number): void;
  1296. renderContent(): JSX.Element;
  1297. onClose(): void;
  1298. onPopup(): void;
  1299. render(): JSX.Element;
  1300. }
  1301. }
  1302. declare module "babylonjs-inspector/components/sceneExplorer/treeItemLabelComponent" {
  1303. import * as React from "react";
  1304. interface ITreeItemLabelComponentProps {
  1305. label: string;
  1306. onClick?: () => void;
  1307. color: string;
  1308. }
  1309. export class TreeItemLabelComponent extends React.Component<ITreeItemLabelComponentProps> {
  1310. constructor(props: ITreeItemLabelComponentProps);
  1311. onClick(): void;
  1312. render(): JSX.Element;
  1313. }
  1314. }
  1315. declare module "babylonjs-inspector/components/sceneExplorer/extensionsComponent" {
  1316. import * as React from "react";
  1317. import { IExplorerExtensibilityGroup } from "babylonjs/Debug/debugLayer";
  1318. interface IExtensionsComponentProps {
  1319. target: any;
  1320. extensibilityGroups?: IExplorerExtensibilityGroup[];
  1321. }
  1322. export class ExtensionsComponent extends React.Component<IExtensionsComponentProps, {
  1323. popupVisible: boolean;
  1324. }> {
  1325. private _popup;
  1326. constructor(props: IExtensionsComponentProps);
  1327. showPopup(): void;
  1328. componentDidMount(): void;
  1329. componentDidUpdate(): void;
  1330. render(): JSX.Element | null;
  1331. }
  1332. }
  1333. declare module "babylonjs-inspector/components/sceneExplorer/entities/meshTreeItemComponent" {
  1334. import { IExplorerExtensibilityGroup } from "babylonjs/Debug/debugLayer";
  1335. import { AbstractMesh } from "babylonjs/Meshes/abstractMesh";
  1336. import * as React from "react";
  1337. interface IMeshTreeItemComponentProps {
  1338. mesh: AbstractMesh;
  1339. extensibilityGroups?: IExplorerExtensibilityGroup[];
  1340. onClick: () => void;
  1341. }
  1342. export class MeshTreeItemComponent extends React.Component<IMeshTreeItemComponentProps, {
  1343. isGizmoEnabled: boolean;
  1344. isVisible: boolean;
  1345. }> {
  1346. constructor(props: IMeshTreeItemComponentProps);
  1347. showGizmos(): void;
  1348. switchVisibility(): void;
  1349. render(): JSX.Element;
  1350. }
  1351. }
  1352. declare module "babylonjs-inspector/components/sceneExplorer/entities/cameraTreeItemComponent" {
  1353. import { IExplorerExtensibilityGroup } from "babylonjs/Debug/debugLayer";
  1354. import { Camera } from "babylonjs/Cameras/camera";
  1355. import * as React from "react";
  1356. interface ICameraTreeItemComponentProps {
  1357. camera: Camera;
  1358. extensibilityGroups?: IExplorerExtensibilityGroup[];
  1359. onClick: () => void;
  1360. }
  1361. export class CameraTreeItemComponent extends React.Component<ICameraTreeItemComponentProps, {
  1362. isActive: boolean;
  1363. }> {
  1364. private _onActiveCameraObserver;
  1365. constructor(props: ICameraTreeItemComponentProps);
  1366. setActive(): void;
  1367. componentWillMount(): void;
  1368. componentWillUnmount(): void;
  1369. render(): JSX.Element;
  1370. }
  1371. }
  1372. declare module "babylonjs-inspector/components/sceneExplorer/entities/lightTreeItemComponent" {
  1373. import { IExplorerExtensibilityGroup } from "babylonjs/Debug/debugLayer";
  1374. import { Light } from "babylonjs/Lights/light";
  1375. import * as React from "react";
  1376. import { GlobalState } from "babylonjs-inspector/components/globalState";
  1377. interface ILightTreeItemComponentProps {
  1378. light: Light;
  1379. extensibilityGroups?: IExplorerExtensibilityGroup[];
  1380. onClick: () => void;
  1381. globalState: GlobalState;
  1382. }
  1383. export class LightTreeItemComponent extends React.Component<ILightTreeItemComponentProps, {
  1384. isEnabled: boolean;
  1385. }> {
  1386. constructor(props: ILightTreeItemComponentProps);
  1387. switchIsEnabled(): void;
  1388. render(): JSX.Element;
  1389. }
  1390. }
  1391. declare module "babylonjs-inspector/components/sceneExplorer/entities/materialTreeItemComponent" {
  1392. import { IExplorerExtensibilityGroup } from "babylonjs/Debug/debugLayer";
  1393. import { Material } from "babylonjs/Materials/material";
  1394. import * as React from 'react';
  1395. interface IMaterialTreeItemComponentProps {
  1396. material: Material;
  1397. extensibilityGroups?: IExplorerExtensibilityGroup[];
  1398. onClick: () => void;
  1399. }
  1400. export class MaterialTreeItemComponent extends React.Component<IMaterialTreeItemComponentProps> {
  1401. constructor(props: IMaterialTreeItemComponentProps);
  1402. render(): JSX.Element;
  1403. }
  1404. }
  1405. declare module "babylonjs-inspector/components/sceneExplorer/entities/textureTreeItemComponent" {
  1406. import { IExplorerExtensibilityGroup } from "babylonjs/Debug/debugLayer";
  1407. import { Texture } from "babylonjs/Materials/Textures/texture";
  1408. import * as React from 'react';
  1409. interface ITextureTreeItemComponentProps {
  1410. texture: Texture;
  1411. extensibilityGroups?: IExplorerExtensibilityGroup[];
  1412. onClick: () => void;
  1413. }
  1414. export class TextureTreeItemComponent extends React.Component<ITextureTreeItemComponentProps> {
  1415. constructor(props: ITextureTreeItemComponentProps);
  1416. render(): JSX.Element;
  1417. }
  1418. }
  1419. declare module "babylonjs-inspector/components/sceneExplorer/entities/transformNodeTreeItemComponent" {
  1420. import { IExplorerExtensibilityGroup } from "babylonjs/Debug/debugLayer";
  1421. import { TransformNode } from "babylonjs/Meshes/transformNode";
  1422. import * as React from "react";
  1423. interface ITransformNodeItemComponentProps {
  1424. transformNode: TransformNode;
  1425. extensibilityGroups?: IExplorerExtensibilityGroup[];
  1426. onClick: () => void;
  1427. }
  1428. export class TransformNodeItemComponent extends React.Component<ITransformNodeItemComponentProps> {
  1429. constructor(props: ITransformNodeItemComponentProps);
  1430. render(): JSX.Element;
  1431. }
  1432. }
  1433. declare module "babylonjs-inspector/components/sceneExplorer/entities/gui/controlTreeItemComponent" {
  1434. import { IExplorerExtensibilityGroup } from "babylonjs/Debug/debugLayer";
  1435. import { Control } from "babylonjs-gui/2D/controls/control";
  1436. import * as React from 'react';
  1437. interface IControlTreeItemComponentProps {
  1438. control: Control;
  1439. extensibilityGroups?: IExplorerExtensibilityGroup[];
  1440. onClick: () => void;
  1441. }
  1442. export class ControlTreeItemComponent extends React.Component<IControlTreeItemComponentProps, {
  1443. isActive: boolean;
  1444. isVisible: boolean;
  1445. }> {
  1446. constructor(props: IControlTreeItemComponentProps);
  1447. highlight(): void;
  1448. switchVisibility(): void;
  1449. render(): JSX.Element;
  1450. }
  1451. }
  1452. declare module "babylonjs-inspector/components/sceneExplorer/entities/gui/advancedDynamicTextureTreeItemComponent" {
  1453. import { Observable } from "babylonjs/Misc/observable";
  1454. import { IExplorerExtensibilityGroup } from "babylonjs/Debug/debugLayer";
  1455. import { AdvancedDynamicTexture } from 'babylonjs-gui/2D/advancedDynamicTexture';
  1456. import * as React from 'react';
  1457. interface IAdvancedDynamicTextureTreeItemComponentProps {
  1458. texture: AdvancedDynamicTexture;
  1459. extensibilityGroups?: IExplorerExtensibilityGroup[];
  1460. onSelectionChangedObservable?: Observable<any>;
  1461. onClick: () => void;
  1462. }
  1463. export class AdvancedDynamicTextureTreeItemComponent extends React.Component<IAdvancedDynamicTextureTreeItemComponentProps, {
  1464. isInPickingMode: boolean;
  1465. }> {
  1466. private _onControlPickedObserver;
  1467. constructor(props: IAdvancedDynamicTextureTreeItemComponentProps);
  1468. componentWillUnmount(): void;
  1469. onPickingMode(): void;
  1470. render(): JSX.Element;
  1471. }
  1472. }
  1473. declare module "babylonjs-inspector/components/sceneExplorer/entities/animationGroupTreeItemComponent" {
  1474. import { AnimationGroup } from "babylonjs/Animations/animationGroup";
  1475. import { IExplorerExtensibilityGroup } from "babylonjs/Debug/debugLayer";
  1476. import * as React from "react";
  1477. interface IAnimationGroupItemComponentProps {
  1478. animationGroup: AnimationGroup;
  1479. extensibilityGroups?: IExplorerExtensibilityGroup[];
  1480. onClick: () => void;
  1481. }
  1482. export class AnimationGroupItemComponent extends React.Component<IAnimationGroupItemComponentProps> {
  1483. constructor(props: IAnimationGroupItemComponentProps);
  1484. render(): JSX.Element;
  1485. }
  1486. }
  1487. declare module "babylonjs-inspector/components/sceneExplorer/treeItemSpecializedComponent" {
  1488. import { IExplorerExtensibilityGroup } from "babylonjs/Debug/debugLayer";
  1489. import * as React from "react";
  1490. import { GlobalState } from "babylonjs-inspector/components/globalState";
  1491. interface ITreeItemSpecializedComponentProps {
  1492. label: string;
  1493. entity?: any;
  1494. extensibilityGroups?: IExplorerExtensibilityGroup[];
  1495. globalState: GlobalState;
  1496. onClick?: () => void;
  1497. }
  1498. export class TreeItemSpecializedComponent extends React.Component<ITreeItemSpecializedComponentProps> {
  1499. constructor(props: ITreeItemSpecializedComponentProps);
  1500. onClick(): void;
  1501. render(): JSX.Element;
  1502. }
  1503. }
  1504. declare module "babylonjs-inspector/tools" {
  1505. export class Tools {
  1506. static LookForItem(item: any, selectedEntity: any): boolean;
  1507. private static _RecursiveRemoveHiddenMeshesAndHoistChildren;
  1508. static SortAndFilter(parent: any, items: any[]): any[];
  1509. }
  1510. }
  1511. declare module "babylonjs-inspector/components/sceneExplorer/treeItemSelectableComponent" {
  1512. import { Nullable } from "babylonjs/types";
  1513. import { IExplorerExtensibilityGroup } from "babylonjs/Debug/debugLayer";
  1514. import * as React from "react";
  1515. import { GlobalState } from "babylonjs-inspector/components/globalState";
  1516. export interface ITreeItemSelectableComponentProps {
  1517. entity: any;
  1518. selectedEntity?: any;
  1519. mustExpand?: boolean;
  1520. offset: number;
  1521. globalState: GlobalState;
  1522. extensibilityGroups?: IExplorerExtensibilityGroup[];
  1523. filter: Nullable<string>;
  1524. }
  1525. export class TreeItemSelectableComponent extends React.Component<ITreeItemSelectableComponentProps, {
  1526. isExpanded: boolean;
  1527. isSelected: boolean;
  1528. }> {
  1529. private _wasSelected;
  1530. constructor(props: ITreeItemSelectableComponentProps);
  1531. switchExpandedState(): void;
  1532. shouldComponentUpdate(nextProps: ITreeItemSelectableComponentProps, nextState: {
  1533. isExpanded: boolean;
  1534. isSelected: boolean;
  1535. }): boolean;
  1536. scrollIntoView(): void;
  1537. componentDidMount(): void;
  1538. componentDidUpdate(): void;
  1539. onSelect(): void;
  1540. renderChildren(): JSX.Element[] | null;
  1541. render(): JSX.Element | null;
  1542. }
  1543. }
  1544. declare module "babylonjs-inspector/components/sceneExplorer/treeItemComponent" {
  1545. import * as React from "react";
  1546. import { Nullable } from "babylonjs/types";
  1547. import { IExplorerExtensibilityGroup } from "babylonjs/Debug/debugLayer";
  1548. import { GlobalState } from "babylonjs-inspector/components/globalState";
  1549. export interface ITreeItemComponentProps {
  1550. items?: Nullable<any[]>;
  1551. label: string;
  1552. offset: number;
  1553. filter: Nullable<string>;
  1554. globalState: GlobalState;
  1555. entity?: any;
  1556. selectedEntity: any;
  1557. extensibilityGroups?: IExplorerExtensibilityGroup[];
  1558. }
  1559. export class TreeItemComponent extends React.Component<ITreeItemComponentProps, {
  1560. isExpanded: boolean;
  1561. mustExpand: boolean;
  1562. }> {
  1563. constructor(props: ITreeItemComponentProps);
  1564. switchExpandedState(): void;
  1565. shouldComponentUpdate(nextProps: ITreeItemComponentProps, nextState: {
  1566. isExpanded: boolean;
  1567. }): boolean;
  1568. expandAll(expand: boolean): void;
  1569. render(): JSX.Element;
  1570. }
  1571. }
  1572. declare module "babylonjs-inspector/components/sceneExplorer/entities/sceneTreeItemComponent" {
  1573. import { Observable } from "babylonjs/Misc/observable";
  1574. import { IExplorerExtensibilityGroup } from "babylonjs/Debug/debugLayer";
  1575. import { Scene } from "babylonjs/scene";
  1576. import * as React from "react";
  1577. interface ISceneTreeItemComponentProps {
  1578. scene: Scene;
  1579. onRefresh: () => void;
  1580. selectedEntity?: any;
  1581. extensibilityGroups?: IExplorerExtensibilityGroup[];
  1582. onSelectionChangedObservable?: Observable<any>;
  1583. }
  1584. export class SceneTreeItemComponent extends React.Component<ISceneTreeItemComponentProps, {
  1585. isSelected: boolean;
  1586. isInPickingMode: boolean;
  1587. gizmoMode: number;
  1588. }> {
  1589. private _onPointerObserver;
  1590. private _onSelectionChangeObserver;
  1591. private _selectedEntity;
  1592. constructor(props: ISceneTreeItemComponentProps);
  1593. shouldComponentUpdate(nextProps: ISceneTreeItemComponentProps, nextState: {
  1594. isSelected: boolean;
  1595. isInPickingMode: boolean;
  1596. }): boolean;
  1597. componentWillMount(): void;
  1598. componentWillUnmount(): void;
  1599. onSelect(): void;
  1600. onPickingMode(): void;
  1601. setGizmoMode(mode: number): void;
  1602. render(): JSX.Element;
  1603. }
  1604. }
  1605. declare module "babylonjs-inspector/components/sceneExplorer/sceneExplorerComponent" {
  1606. import * as React from "react";
  1607. import { Nullable } from "babylonjs/types";
  1608. import { IExplorerExtensibilityGroup } from "babylonjs/Debug/debugLayer";
  1609. import { Scene } from "babylonjs/scene";
  1610. import { GlobalState } from "babylonjs-inspector/components/globalState";
  1611. interface ISceneExplorerFilterComponentProps {
  1612. onFilter: (filter: string) => void;
  1613. }
  1614. export class SceneExplorerFilterComponent extends React.Component<ISceneExplorerFilterComponentProps> {
  1615. constructor(props: ISceneExplorerFilterComponentProps);
  1616. render(): JSX.Element;
  1617. }
  1618. interface ISceneExplorerComponentProps {
  1619. scene: Scene;
  1620. noCommands?: boolean;
  1621. noHeader?: boolean;
  1622. noExpand?: boolean;
  1623. noClose?: boolean;
  1624. extensibilityGroups?: IExplorerExtensibilityGroup[];
  1625. globalState: GlobalState;
  1626. popupMode?: boolean;
  1627. onPopup?: () => void;
  1628. onClose?: () => void;
  1629. }
  1630. export class SceneExplorerComponent extends React.Component<ISceneExplorerComponentProps, {
  1631. filter: Nullable<string>;
  1632. selectedEntity: any;
  1633. scene: Scene;
  1634. }> {
  1635. private _onSelectionChangeObserver;
  1636. private _onNewSceneAddedObserver;
  1637. private _once;
  1638. private sceneMutationFunc;
  1639. constructor(props: ISceneExplorerComponentProps);
  1640. processMutation(): void;
  1641. componentWillMount(): void;
  1642. componentWillUnmount(): void;
  1643. filterContent(filter: string): void;
  1644. findSiblings(parent: any, items: any[], target: any, goNext: boolean, data: {
  1645. previousOne?: any;
  1646. found?: boolean;
  1647. }): boolean;
  1648. processKeys(keyEvent: React.KeyboardEvent<HTMLDivElement>): void;
  1649. renderContent(): JSX.Element | null;
  1650. onClose(): void;
  1651. onPopup(): void;
  1652. render(): JSX.Element;
  1653. }
  1654. }
  1655. declare module "babylonjs-inspector/components/embedHost/embedHostComponent" {
  1656. import * as React from "react";
  1657. import { Scene } from "babylonjs/scene";
  1658. import { GlobalState } from "babylonjs-inspector/components/globalState";
  1659. interface IEmbedHostComponentProps {
  1660. scene: Scene;
  1661. globalState: GlobalState;
  1662. popupMode: boolean;
  1663. noClose?: boolean;
  1664. noExpand?: boolean;
  1665. onClose: () => void;
  1666. onPopup: () => void;
  1667. }
  1668. export class EmbedHostComponent extends React.Component<IEmbedHostComponentProps> {
  1669. private _once;
  1670. constructor(props: IEmbedHostComponentProps);
  1671. componentDidMount(): void;
  1672. renderContent(): JSX.Element;
  1673. render(): JSX.Element;
  1674. }
  1675. }
  1676. declare module "babylonjs-inspector/inspector" {
  1677. import { IInspectorOptions } from "babylonjs/Debug/debugLayer";
  1678. import { Observable } from "babylonjs/Misc/observable";
  1679. import { Scene } from "babylonjs/scene";
  1680. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  1681. export class Inspector {
  1682. private static _SceneExplorerHost;
  1683. private static _ActionTabsHost;
  1684. private static _EmbedHost;
  1685. private static _NewCanvasContainer;
  1686. private static _SceneExplorerWindow;
  1687. private static _ActionTabsWindow;
  1688. private static _EmbedHostWindow;
  1689. private static _Scene;
  1690. private static _OpenedPane;
  1691. private static _OnBeforeRenderObserver;
  1692. static OnSelectionChangeObservable: Observable<string>;
  1693. static OnPropertyChangedObservable: Observable<PropertyChangedEvent>;
  1694. private static _GlobalState;
  1695. private static _CopyStyles;
  1696. private static _CreateSceneExplorer;
  1697. private static _CreateActionTabs;
  1698. private static _CreateEmbedHost;
  1699. private static _CreatePopup;
  1700. static readonly IsVisible: boolean;
  1701. static EarlyAttachToLoader(): void;
  1702. static Show(scene: Scene, userOptions: Partial<IInspectorOptions>): void;
  1703. private static _CreateCanvasContainer;
  1704. private static _DestroyCanvasContainer;
  1705. private static _Cleanup;
  1706. private static _RemoveElementFromDOM;
  1707. static Hide(): void;
  1708. }
  1709. }
  1710. declare module "babylonjs-inspector/index" {
  1711. export * from "babylonjs-inspector/inspector";
  1712. }
  1713. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lights/directionalLightPropertyGridComponent" {
  1714. import * as React from "react";
  1715. import { Observable } from "babylonjs/Misc/observable";
  1716. import { DirectionalLight } from "babylonjs/Lights/directionalLight";
  1717. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  1718. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  1719. interface IDirectionalLightPropertyGridComponentProps {
  1720. light: DirectionalLight;
  1721. lockObject: LockObject;
  1722. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1723. }
  1724. export class DirectionalLightPropertyGridComponent extends React.Component<IDirectionalLightPropertyGridComponentProps> {
  1725. constructor(props: IDirectionalLightPropertyGridComponentProps);
  1726. render(): JSX.Element;
  1727. }
  1728. }
  1729. declare module "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lights/spotLightPropertyGridComponent" {
  1730. import * as React from "react";
  1731. import { Observable } from "babylonjs/Misc/observable";
  1732. import { SpotLight } from "babylonjs/Lights/spotLight";
  1733. import { PropertyChangedEvent } from "babylonjs-inspector/components/propertyChangedEvent";
  1734. import { LockObject } from "babylonjs-inspector/components/actionTabs/tabs/propertyGrids/lockObject";
  1735. interface ISpotLightPropertyGridComponentProps {
  1736. light: SpotLight;
  1737. lockObject: LockObject;
  1738. onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
  1739. }
  1740. export class SpotLightPropertyGridComponent extends React.Component<ISpotLightPropertyGridComponentProps> {
  1741. constructor(props: ISpotLightPropertyGridComponentProps);
  1742. render(): JSX.Element;
  1743. }
  1744. }
  1745. declare module "babylonjs-inspector/legacy/legacy" {
  1746. export * from "babylonjs-inspector/index";
  1747. }
  1748. declare module "babylonjs-inspector" {
  1749. export * from "babylonjs-inspector/legacy/legacy";
  1750. }
  1751. /// <reference types="react" />
  1752. declare module INSPECTOR {
  1753. export class PropertyChangedEvent {
  1754. object: any;
  1755. property: string;
  1756. value: any;
  1757. initialValue: any;
  1758. }
  1759. }
  1760. declare module INSPECTOR {
  1761. export class GlobalState {
  1762. onSelectionChangedObservable: BABYLON.Observable<string>;
  1763. onPropertyChangedObservable: BABYLON.Observable<PropertyChangedEvent>;
  1764. onInspectorClosedObservable: BABYLON.Observable<BABYLON.Scene>;
  1765. onTabChangedObservable: BABYLON.Observable<number>;
  1766. onPluginActivatedObserver: BABYLON.Nullable<BABYLON.Observer<BABYLON.ISceneLoaderPlugin | BABYLON.ISceneLoaderPluginAsync>>;
  1767. validationResults: BABYLON.GLTF2.IGLTFValidationResults;
  1768. onValidationResultsUpdatedObservable: BABYLON.Observable<BABYLON.GLTF2.IGLTFValidationResults>;
  1769. onExtensionLoadedObservable: BABYLON.Observable<BABYLON.IGLTFLoaderExtension>;
  1770. glTFLoaderExtensionDefaults: {
  1771. [name: string]: {
  1772. [key: string]: any;
  1773. };
  1774. };
  1775. glTFLoaderDefaults: {
  1776. [key: string]: any;
  1777. };
  1778. blockMutationUpdates: boolean;
  1779. prepareGLTFPlugin(loader: BABYLON.GLTFFileLoader): void;
  1780. }
  1781. }
  1782. declare module INSPECTOR {
  1783. export interface IPaneComponentProps {
  1784. title: string;
  1785. scene: BABYLON.Scene;
  1786. selectedEntity?: any;
  1787. onSelectionChangedObservable?: BABYLON.Observable<any>;
  1788. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  1789. globalState: GlobalState;
  1790. }
  1791. export class PaneComponent extends React.Component<IPaneComponentProps, {
  1792. tag: any;
  1793. }> {
  1794. constructor(props: IPaneComponentProps);
  1795. render(): JSX.Element | null;
  1796. }
  1797. }
  1798. declare module INSPECTOR {
  1799. interface ITabsComponentProps {
  1800. children: any[];
  1801. selectedIndex: number;
  1802. onSelectedIndexChange: (value: number) => void;
  1803. }
  1804. export class TabsComponent extends React.Component<ITabsComponentProps> {
  1805. constructor(props: ITabsComponentProps);
  1806. onSelect(index: number): void;
  1807. renderLabel(child: PaneComponent, index: number): JSX.Element;
  1808. render(): JSX.Element;
  1809. }
  1810. }
  1811. declare module INSPECTOR {
  1812. interface ITextLineComponentProps {
  1813. label: string;
  1814. value: string;
  1815. color?: string;
  1816. underline?: boolean;
  1817. onLink?: () => void;
  1818. }
  1819. export class TextLineComponent extends React.Component<ITextLineComponentProps> {
  1820. constructor(props: ITextLineComponentProps);
  1821. onLink(): void;
  1822. renderContent(): JSX.Element;
  1823. render(): JSX.Element;
  1824. }
  1825. }
  1826. declare module INSPECTOR {
  1827. interface ILineContainerComponentProps {
  1828. title: string;
  1829. children: any[] | any;
  1830. closed?: boolean;
  1831. }
  1832. export class LineContainerComponent extends React.Component<ILineContainerComponentProps, {
  1833. isExpanded: boolean;
  1834. }> {
  1835. private static _InMemoryStorage;
  1836. constructor(props: ILineContainerComponentProps);
  1837. switchExpandedState(): void;
  1838. renderHeader(): JSX.Element;
  1839. render(): JSX.Element;
  1840. }
  1841. }
  1842. declare module INSPECTOR {
  1843. interface IValueLineComponentProps {
  1844. label: string;
  1845. value: number;
  1846. color?: string;
  1847. fractionDigits?: number;
  1848. units?: string;
  1849. }
  1850. export class ValueLineComponent extends React.Component<IValueLineComponentProps> {
  1851. constructor(props: IValueLineComponentProps);
  1852. render(): JSX.Element;
  1853. }
  1854. }
  1855. declare module INSPECTOR {
  1856. export interface IBooleanLineComponentProps {
  1857. label: string;
  1858. value: boolean;
  1859. }
  1860. export class BooleanLineComponent extends React.Component<IBooleanLineComponentProps> {
  1861. constructor(props: IBooleanLineComponentProps);
  1862. render(): JSX.Element;
  1863. }
  1864. }
  1865. declare module INSPECTOR {
  1866. export class StatisticsTabComponent extends PaneComponent {
  1867. private _sceneInstrumentation;
  1868. private _engineInstrumentation;
  1869. private _timerIntervalId;
  1870. constructor(props: IPaneComponentProps);
  1871. componentWillMount(): void;
  1872. componentWillUnmount(): void;
  1873. render(): JSX.Element | null;
  1874. }
  1875. }
  1876. declare module INSPECTOR {
  1877. export interface ICheckBoxLineComponentProps {
  1878. label: string;
  1879. target?: any;
  1880. propertyName?: string;
  1881. isSelected?: () => boolean;
  1882. onSelect?: (value: boolean) => void;
  1883. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  1884. }
  1885. export class CheckBoxLineComponent extends React.Component<ICheckBoxLineComponentProps, {
  1886. isSelected: boolean;
  1887. }> {
  1888. private static _UniqueIdSeed;
  1889. private _uniqueId;
  1890. private _localChange;
  1891. constructor(props: ICheckBoxLineComponentProps);
  1892. shouldComponentUpdate(nextProps: ICheckBoxLineComponentProps, nextState: {
  1893. isSelected: boolean;
  1894. }): boolean;
  1895. onChange(): void;
  1896. render(): JSX.Element;
  1897. }
  1898. }
  1899. declare module INSPECTOR {
  1900. interface IRenderGridPropertyGridComponentProps {
  1901. scene: BABYLON.Scene;
  1902. }
  1903. export class RenderGridPropertyGridComponent extends React.Component<IRenderGridPropertyGridComponentProps, {
  1904. isEnabled: boolean;
  1905. }> {
  1906. private _gridMesh;
  1907. constructor(props: IRenderGridPropertyGridComponentProps);
  1908. componentWillMount(): void;
  1909. addOrRemoveGrid(): void;
  1910. render(): JSX.Element;
  1911. }
  1912. }
  1913. declare module INSPECTOR {
  1914. export class DebugTabComponent extends PaneComponent {
  1915. private _skeletonViewersEnabled;
  1916. private _physicsViewersEnabled;
  1917. private _skeletonViewers;
  1918. constructor(props: IPaneComponentProps);
  1919. componentWillMount(): void;
  1920. componentWillUnmount(): void;
  1921. switchSkeletonViewers(): void;
  1922. switchPhysicsViewers(): void;
  1923. render(): JSX.Element | null;
  1924. }
  1925. }
  1926. declare module INSPECTOR {
  1927. interface ISliderLineComponentProps {
  1928. label: string;
  1929. target?: any;
  1930. propertyName?: string;
  1931. minimum: number;
  1932. maximum: number;
  1933. step: number;
  1934. directValue?: number;
  1935. onChange?: (value: number) => void;
  1936. onInput?: (value: number) => void;
  1937. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  1938. }
  1939. export class SliderLineComponent extends React.Component<ISliderLineComponentProps, {
  1940. value: number;
  1941. }> {
  1942. private _localChange;
  1943. constructor(props: ISliderLineComponentProps);
  1944. shouldComponentUpdate(nextProps: ISliderLineComponentProps, nextState: {
  1945. value: number;
  1946. }): boolean;
  1947. onChange(newValueString: any): void;
  1948. onInput(newValueString: any): void;
  1949. render(): JSX.Element;
  1950. }
  1951. }
  1952. declare module INSPECTOR {
  1953. class ListLineOption {
  1954. label: string;
  1955. value: number;
  1956. }
  1957. interface IOptionsLineComponentProps {
  1958. label: string;
  1959. target: any;
  1960. propertyName: string;
  1961. options: ListLineOption[];
  1962. noDirectUpdate?: boolean;
  1963. onSelect?: (value: number) => void;
  1964. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  1965. }
  1966. export class OptionsLineComponent extends React.Component<IOptionsLineComponentProps, {
  1967. value: number;
  1968. }> {
  1969. private _localChange;
  1970. constructor(props: IOptionsLineComponentProps);
  1971. shouldComponentUpdate(nextProps: IOptionsLineComponentProps, nextState: {
  1972. value: number;
  1973. }): boolean;
  1974. raiseOnPropertyChanged(newValue: number, previousValue: number): void;
  1975. updateValue(valueString: string): void;
  1976. render(): JSX.Element;
  1977. }
  1978. }
  1979. declare module INSPECTOR {
  1980. /**
  1981. * Class used to provide lock mechanism
  1982. */
  1983. export class LockObject {
  1984. /**
  1985. * Gets or set if the lock is engaged
  1986. */
  1987. lock: boolean;
  1988. }
  1989. }
  1990. declare module INSPECTOR {
  1991. interface ICommonMaterialPropertyGridComponentProps {
  1992. material: BABYLON.Material;
  1993. lockObject: LockObject;
  1994. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  1995. }
  1996. export class CommonMaterialPropertyGridComponent extends React.Component<ICommonMaterialPropertyGridComponentProps> {
  1997. constructor(props: ICommonMaterialPropertyGridComponentProps);
  1998. render(): JSX.Element;
  1999. }
  2000. }
  2001. declare module INSPECTOR {
  2002. interface IMaterialPropertyGridComponentProps {
  2003. material: BABYLON.Material;
  2004. lockObject: LockObject;
  2005. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2006. }
  2007. export class MaterialPropertyGridComponent extends React.Component<IMaterialPropertyGridComponentProps> {
  2008. constructor(props: IMaterialPropertyGridComponentProps);
  2009. render(): JSX.Element;
  2010. }
  2011. }
  2012. declare module INSPECTOR {
  2013. interface INumericInputComponentProps {
  2014. label: string;
  2015. value: number;
  2016. onChange: (value: number) => void;
  2017. }
  2018. export class NumericInputComponent extends React.Component<INumericInputComponentProps, {
  2019. value: string;
  2020. }> {
  2021. private _localChange;
  2022. constructor(props: INumericInputComponentProps);
  2023. shouldComponentUpdate(nextProps: INumericInputComponentProps, nextState: {
  2024. value: string;
  2025. }): boolean;
  2026. updateValue(evt: any): void;
  2027. render(): JSX.Element;
  2028. }
  2029. }
  2030. declare module INSPECTOR {
  2031. export interface IColor3LineComponentProps {
  2032. label: string;
  2033. target: any;
  2034. propertyName: string;
  2035. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2036. }
  2037. export class Color3LineComponent extends React.Component<IColor3LineComponentProps, {
  2038. isExpanded: boolean;
  2039. color: BABYLON.Color3;
  2040. }> {
  2041. private _localChange;
  2042. constructor(props: IColor3LineComponentProps);
  2043. shouldComponentUpdate(nextProps: IColor3LineComponentProps, nextState: {
  2044. color: BABYLON.Color3;
  2045. }): boolean;
  2046. onChange(newValue: string): void;
  2047. switchExpandState(): void;
  2048. raiseOnPropertyChanged(previousValue: BABYLON.Color3): void;
  2049. updateStateR(value: number): void;
  2050. updateStateG(value: number): void;
  2051. updateStateB(value: number): void;
  2052. copyToClipboard(): void;
  2053. render(): JSX.Element;
  2054. }
  2055. }
  2056. declare module INSPECTOR {
  2057. export interface ITextureLinkLineComponentProps {
  2058. label: string;
  2059. texture: BABYLON.Nullable<BABYLON.BaseTexture>;
  2060. material?: BABYLON.Material;
  2061. onSelectionChangedObservable?: BABYLON.Observable<any>;
  2062. onDebugSelectionChangeObservable?: BABYLON.Observable<BABYLON.BaseTexture>;
  2063. }
  2064. export class TextureLinkLineComponent extends React.Component<ITextureLinkLineComponentProps, {
  2065. isDebugSelected: boolean;
  2066. }> {
  2067. private _onDebugSelectionChangeObserver;
  2068. constructor(props: ITextureLinkLineComponentProps);
  2069. componentWillMount(): void;
  2070. componentWillUnmount(): void;
  2071. debugTexture(): void;
  2072. onLink(): void;
  2073. render(): JSX.Element | null;
  2074. }
  2075. }
  2076. declare module INSPECTOR {
  2077. interface IStandardMaterialPropertyGridComponentProps {
  2078. material: BABYLON.StandardMaterial;
  2079. lockObject: LockObject;
  2080. onSelectionChangedObservable?: BABYLON.Observable<any>;
  2081. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2082. }
  2083. export class StandardMaterialPropertyGridComponent extends React.Component<IStandardMaterialPropertyGridComponentProps> {
  2084. constructor(props: IStandardMaterialPropertyGridComponentProps);
  2085. renderTextures(): JSX.Element | null;
  2086. render(): JSX.Element;
  2087. }
  2088. }
  2089. declare module INSPECTOR {
  2090. interface ITextureLineComponentProps {
  2091. texture: BABYLON.BaseTexture;
  2092. width: number;
  2093. height: number;
  2094. globalState: GlobalState;
  2095. }
  2096. export class TextureLineComponent extends React.Component<ITextureLineComponentProps, {
  2097. displayRed: boolean;
  2098. displayGreen: boolean;
  2099. displayBlue: boolean;
  2100. displayAlpha: boolean;
  2101. face: number;
  2102. }> {
  2103. constructor(props: ITextureLineComponentProps);
  2104. shouldComponentUpdate(nextProps: ITextureLineComponentProps, nextState: {
  2105. displayRed: boolean;
  2106. displayGreen: boolean;
  2107. displayBlue: boolean;
  2108. displayAlpha: boolean;
  2109. face: number;
  2110. }): boolean;
  2111. componentDidMount(): void;
  2112. componentDidUpdate(): void;
  2113. updatePreview(): void;
  2114. render(): JSX.Element;
  2115. }
  2116. }
  2117. declare module INSPECTOR {
  2118. interface IFloatLineComponentProps {
  2119. label: string;
  2120. target: any;
  2121. propertyName: string;
  2122. lockObject?: LockObject;
  2123. onChange?: (newValue: number) => void;
  2124. isInteger?: boolean;
  2125. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2126. additionalClass?: string;
  2127. }
  2128. export class FloatLineComponent extends React.Component<IFloatLineComponentProps, {
  2129. value: string;
  2130. }> {
  2131. private _localChange;
  2132. private _store;
  2133. constructor(props: IFloatLineComponentProps);
  2134. componentWillUnmount(): void;
  2135. shouldComponentUpdate(nextProps: IFloatLineComponentProps, nextState: {
  2136. value: string;
  2137. }): boolean;
  2138. raiseOnPropertyChanged(newValue: number, previousValue: number): void;
  2139. updateValue(valueString: string): void;
  2140. lock(): void;
  2141. unlock(): void;
  2142. render(): JSX.Element;
  2143. }
  2144. }
  2145. declare module INSPECTOR {
  2146. interface IFileButtonLineComponentProps {
  2147. label: string;
  2148. onClick: (file: File) => void;
  2149. accept: string;
  2150. }
  2151. export class FileButtonLineComponent extends React.Component<IFileButtonLineComponentProps> {
  2152. constructor(props: IFileButtonLineComponentProps);
  2153. onChange(evt: any): void;
  2154. render(): JSX.Element;
  2155. }
  2156. }
  2157. declare module INSPECTOR {
  2158. interface ITexturePropertyGridComponentProps {
  2159. texture: BABYLON.BaseTexture;
  2160. lockObject: LockObject;
  2161. globalState: GlobalState;
  2162. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2163. }
  2164. export class TexturePropertyGridComponent extends React.Component<ITexturePropertyGridComponentProps> {
  2165. private _adtInstrumentation;
  2166. constructor(props: ITexturePropertyGridComponentProps);
  2167. componentWillMount(): void;
  2168. componentWillUnmount(): void;
  2169. updateTexture(file: File): void;
  2170. render(): JSX.Element;
  2171. }
  2172. }
  2173. declare module INSPECTOR {
  2174. interface IPBRMaterialPropertyGridComponentProps {
  2175. material: BABYLON.PBRMaterial;
  2176. lockObject: LockObject;
  2177. onSelectionChangedObservable?: BABYLON.Observable<any>;
  2178. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2179. }
  2180. export class PBRMaterialPropertyGridComponent extends React.Component<IPBRMaterialPropertyGridComponentProps> {
  2181. constructor(props: IPBRMaterialPropertyGridComponentProps);
  2182. renderTextures(): JSX.Element | null;
  2183. render(): JSX.Element;
  2184. }
  2185. }
  2186. declare module INSPECTOR {
  2187. interface IRadioButtonLineComponentProps {
  2188. onSelectionChangedObservable: BABYLON.Observable<RadioButtonLineComponent>;
  2189. label: string;
  2190. isSelected: () => boolean;
  2191. onSelect: () => void;
  2192. }
  2193. export class RadioButtonLineComponent extends React.Component<IRadioButtonLineComponentProps, {
  2194. isSelected: boolean;
  2195. }> {
  2196. private _onSelectionChangedObserver;
  2197. constructor(props: IRadioButtonLineComponentProps);
  2198. componentWillMount(): void;
  2199. componentWillUnmount(): void;
  2200. onChange(): void;
  2201. render(): JSX.Element;
  2202. }
  2203. }
  2204. declare module INSPECTOR {
  2205. interface IFogPropertyGridComponentProps {
  2206. scene: BABYLON.Scene;
  2207. lockObject: LockObject;
  2208. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2209. }
  2210. export class FogPropertyGridComponent extends React.Component<IFogPropertyGridComponentProps, {
  2211. mode: number;
  2212. }> {
  2213. constructor(props: IFogPropertyGridComponentProps);
  2214. render(): JSX.Element;
  2215. }
  2216. }
  2217. declare module INSPECTOR {
  2218. interface IVector3LineComponentProps {
  2219. label: string;
  2220. target: any;
  2221. propertyName: string;
  2222. onChange?: (newvalue: BABYLON.Vector3) => void;
  2223. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2224. }
  2225. export class Vector3LineComponent extends React.Component<IVector3LineComponentProps, {
  2226. isExpanded: boolean;
  2227. value: BABYLON.Vector3;
  2228. }> {
  2229. private _localChange;
  2230. constructor(props: IVector3LineComponentProps);
  2231. shouldComponentUpdate(nextProps: IVector3LineComponentProps, nextState: {
  2232. isExpanded: boolean;
  2233. value: BABYLON.Vector3;
  2234. }): boolean;
  2235. switchExpandState(): void;
  2236. raiseOnPropertyChanged(previousValue: BABYLON.Vector3): void;
  2237. updateStateX(value: number): void;
  2238. updateStateY(value: number): void;
  2239. updateStateZ(value: number): void;
  2240. render(): JSX.Element;
  2241. }
  2242. }
  2243. declare module INSPECTOR {
  2244. interface IScenePropertyGridComponentProps {
  2245. scene: BABYLON.Scene;
  2246. lockObject: LockObject;
  2247. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2248. onSelectionChangedObservable?: BABYLON.Observable<any>;
  2249. }
  2250. export class ScenePropertyGridComponent extends React.Component<IScenePropertyGridComponentProps> {
  2251. private _storedEnvironmentTexture;
  2252. private _renderingModeGroupObservable;
  2253. constructor(props: IScenePropertyGridComponentProps);
  2254. setRenderingModes(point: boolean, wireframe: boolean): void;
  2255. switchIBL(): void;
  2256. updateEnvironmentTexture(file: File): void;
  2257. updateGravity(newValue: BABYLON.Vector3): void;
  2258. updateTimeStep(newValue: number): void;
  2259. render(): JSX.Element;
  2260. }
  2261. }
  2262. declare module INSPECTOR {
  2263. interface ICommonLightPropertyGridComponentProps {
  2264. light: BABYLON.Light;
  2265. lockObject: LockObject;
  2266. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2267. }
  2268. export class CommonLightPropertyGridComponent extends React.Component<ICommonLightPropertyGridComponentProps> {
  2269. constructor(props: ICommonLightPropertyGridComponentProps);
  2270. render(): JSX.Element;
  2271. }
  2272. }
  2273. declare module INSPECTOR {
  2274. interface IHemisphericLightPropertyGridComponentProps {
  2275. light: BABYLON.HemisphericLight;
  2276. lockObject: LockObject;
  2277. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2278. }
  2279. export class HemisphericLightPropertyGridComponent extends React.Component<IHemisphericLightPropertyGridComponentProps> {
  2280. constructor(props: IHemisphericLightPropertyGridComponentProps);
  2281. render(): JSX.Element;
  2282. }
  2283. }
  2284. declare module INSPECTOR {
  2285. interface ICommonShadowLightPropertyGridComponentProps {
  2286. light: BABYLON.IShadowLight;
  2287. lockObject: LockObject;
  2288. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2289. }
  2290. export class CommonShadowLightPropertyGridComponent extends React.Component<ICommonShadowLightPropertyGridComponentProps> {
  2291. constructor(props: ICommonShadowLightPropertyGridComponentProps);
  2292. render(): JSX.Element;
  2293. }
  2294. }
  2295. declare module INSPECTOR {
  2296. interface IPointLightPropertyGridComponentProps {
  2297. light: BABYLON.PointLight;
  2298. lockObject: LockObject;
  2299. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2300. }
  2301. export class PointLightPropertyGridComponent extends React.Component<IPointLightPropertyGridComponentProps> {
  2302. constructor(props: IPointLightPropertyGridComponentProps);
  2303. render(): JSX.Element;
  2304. }
  2305. }
  2306. declare module INSPECTOR {
  2307. interface ICommonCameraPropertyGridComponentProps {
  2308. camera: BABYLON.Camera;
  2309. lockObject: LockObject;
  2310. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2311. }
  2312. export class CommonCameraPropertyGridComponent extends React.Component<ICommonCameraPropertyGridComponentProps, {
  2313. mode: number;
  2314. }> {
  2315. constructor(props: ICommonCameraPropertyGridComponentProps);
  2316. render(): JSX.Element;
  2317. }
  2318. }
  2319. declare module INSPECTOR {
  2320. interface IFreeCameraPropertyGridComponentProps {
  2321. camera: BABYLON.FreeCamera;
  2322. lockObject: LockObject;
  2323. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2324. }
  2325. export class FreeCameraPropertyGridComponent extends React.Component<IFreeCameraPropertyGridComponentProps> {
  2326. constructor(props: IFreeCameraPropertyGridComponentProps);
  2327. render(): JSX.Element;
  2328. }
  2329. }
  2330. declare module INSPECTOR {
  2331. interface IArcRotateCameraPropertyGridComponentProps {
  2332. camera: BABYLON.ArcRotateCamera;
  2333. lockObject: LockObject;
  2334. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2335. }
  2336. export class ArcRotateCameraPropertyGridComponent extends React.Component<IArcRotateCameraPropertyGridComponentProps> {
  2337. constructor(props: IArcRotateCameraPropertyGridComponentProps);
  2338. render(): JSX.Element;
  2339. }
  2340. }
  2341. declare module INSPECTOR {
  2342. interface IQuaternionLineComponentProps {
  2343. label: string;
  2344. target: any;
  2345. propertyName: string;
  2346. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2347. }
  2348. export class QuaternionLineComponent extends React.Component<IQuaternionLineComponentProps, {
  2349. isExpanded: boolean;
  2350. value: BABYLON.Quaternion;
  2351. }> {
  2352. private _localChange;
  2353. constructor(props: IQuaternionLineComponentProps);
  2354. shouldComponentUpdate(nextProps: IQuaternionLineComponentProps, nextState: {
  2355. isExpanded: boolean;
  2356. value: BABYLON.Quaternion;
  2357. }): boolean;
  2358. switchExpandState(): void;
  2359. raiseOnPropertyChanged(currentValue: BABYLON.Quaternion, previousValue: BABYLON.Quaternion): void;
  2360. updateQuaternion(): void;
  2361. updateStateX(value: number): void;
  2362. updateStateY(value: number): void;
  2363. updateStateZ(value: number): void;
  2364. updateStateW(value: number): void;
  2365. render(): JSX.Element;
  2366. }
  2367. }
  2368. declare module INSPECTOR {
  2369. interface IAxisViewerComponentProps {
  2370. node: BABYLON.TransformNode;
  2371. }
  2372. export class AxesViewerComponent extends React.Component<IAxisViewerComponentProps, {
  2373. displayAxis: boolean;
  2374. }> {
  2375. constructor(props: IAxisViewerComponentProps);
  2376. displayAxes(): void;
  2377. render(): JSX.Element;
  2378. }
  2379. }
  2380. declare module INSPECTOR {
  2381. interface IMeshPropertyGridComponentProps {
  2382. mesh: BABYLON.Mesh;
  2383. lockObject: LockObject;
  2384. onSelectionChangedObservable?: BABYLON.Observable<any>;
  2385. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2386. }
  2387. export class MeshPropertyGridComponent extends React.Component<IMeshPropertyGridComponentProps, {
  2388. displayNormals: boolean;
  2389. renderNormalVectors: boolean;
  2390. }> {
  2391. constructor(props: IMeshPropertyGridComponentProps);
  2392. renderNormalVectors(): void;
  2393. displayNormals(): void;
  2394. onMaterialLink(): void;
  2395. convertPhysicsTypeToString(): string;
  2396. render(): JSX.Element;
  2397. }
  2398. }
  2399. declare module INSPECTOR {
  2400. interface ITransformNodePropertyGridComponentProps {
  2401. transformNode: BABYLON.TransformNode;
  2402. lockObject: LockObject;
  2403. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2404. }
  2405. export class TransformNodePropertyGridComponent extends React.Component<ITransformNodePropertyGridComponentProps> {
  2406. constructor(props: ITransformNodePropertyGridComponentProps);
  2407. render(): JSX.Element;
  2408. }
  2409. }
  2410. declare module INSPECTOR {
  2411. interface IBackgroundMaterialPropertyGridComponentProps {
  2412. material: BABYLON.BackgroundMaterial;
  2413. lockObject: LockObject;
  2414. onSelectionChangedObservable?: BABYLON.Observable<any>;
  2415. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2416. }
  2417. export class BackgroundMaterialPropertyGridComponent extends React.Component<IBackgroundMaterialPropertyGridComponentProps> {
  2418. constructor(props: IBackgroundMaterialPropertyGridComponentProps);
  2419. renderTextures(): JSX.Element;
  2420. render(): JSX.Element;
  2421. }
  2422. }
  2423. declare module INSPECTOR {
  2424. interface ITextInputLineComponentProps {
  2425. label: string;
  2426. lockObject: LockObject;
  2427. target?: any;
  2428. propertyName?: string;
  2429. value?: string;
  2430. onChange?: (value: string) => void;
  2431. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2432. }
  2433. export class TextInputLineComponent extends React.Component<ITextInputLineComponentProps, {
  2434. value: string;
  2435. }> {
  2436. private _localChange;
  2437. constructor(props: ITextInputLineComponentProps);
  2438. componentWillUnmount(): void;
  2439. shouldComponentUpdate(nextProps: ITextInputLineComponentProps, nextState: {
  2440. value: string;
  2441. }): boolean;
  2442. raiseOnPropertyChanged(newValue: string, previousValue: string): void;
  2443. updateValue(value: string): void;
  2444. render(): JSX.Element;
  2445. }
  2446. }
  2447. declare module INSPECTOR {
  2448. interface ICommonControlPropertyGridComponentProps {
  2449. control: BABYLON.GUI.Control;
  2450. lockObject: LockObject;
  2451. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2452. }
  2453. export class CommonControlPropertyGridComponent extends React.Component<ICommonControlPropertyGridComponentProps> {
  2454. constructor(props: ICommonControlPropertyGridComponentProps);
  2455. renderGridInformation(): JSX.Element | null;
  2456. render(): JSX.Element;
  2457. }
  2458. }
  2459. declare module INSPECTOR {
  2460. interface IControlPropertyGridComponentProps {
  2461. control: BABYLON.GUI.Control;
  2462. lockObject: LockObject;
  2463. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2464. }
  2465. export class ControlPropertyGridComponent extends React.Component<IControlPropertyGridComponentProps> {
  2466. constructor(props: IControlPropertyGridComponentProps);
  2467. render(): JSX.Element;
  2468. }
  2469. }
  2470. declare module INSPECTOR {
  2471. interface ITextBlockPropertyGridComponentProps {
  2472. textBlock: BABYLON.GUI.TextBlock;
  2473. lockObject: LockObject;
  2474. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2475. }
  2476. export class TextBlockPropertyGridComponent extends React.Component<ITextBlockPropertyGridComponentProps> {
  2477. constructor(props: ITextBlockPropertyGridComponentProps);
  2478. render(): JSX.Element;
  2479. }
  2480. }
  2481. declare module INSPECTOR {
  2482. interface IInputTextPropertyGridComponentProps {
  2483. inputText: BABYLON.GUI.InputText;
  2484. lockObject: LockObject;
  2485. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2486. }
  2487. export class InputTextPropertyGridComponent extends React.Component<IInputTextPropertyGridComponentProps> {
  2488. constructor(props: IInputTextPropertyGridComponentProps);
  2489. render(): JSX.Element;
  2490. }
  2491. }
  2492. declare module INSPECTOR {
  2493. interface IColorPickerPropertyGridComponentProps {
  2494. colorPicker: BABYLON.GUI.ColorPicker;
  2495. lockObject: LockObject;
  2496. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2497. }
  2498. export class ColorPickerPropertyGridComponent extends React.Component<IColorPickerPropertyGridComponentProps> {
  2499. constructor(props: IColorPickerPropertyGridComponentProps);
  2500. render(): JSX.Element;
  2501. }
  2502. }
  2503. declare module INSPECTOR {
  2504. export interface IButtonLineComponentProps {
  2505. label: string;
  2506. onClick: () => void;
  2507. }
  2508. export class ButtonLineComponent extends React.Component<IButtonLineComponentProps> {
  2509. constructor(props: IButtonLineComponentProps);
  2510. render(): JSX.Element;
  2511. }
  2512. }
  2513. declare module INSPECTOR {
  2514. interface IAnimationGroupGridComponentProps {
  2515. animationGroup: BABYLON.AnimationGroup;
  2516. scene: BABYLON.Scene;
  2517. lockObject: LockObject;
  2518. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2519. }
  2520. export class AnimationGroupGridComponent extends React.Component<IAnimationGroupGridComponentProps, {
  2521. playButtonText: string;
  2522. currentFrame: number;
  2523. }> {
  2524. private _onAnimationGroupPlayObserver;
  2525. private _onAnimationGroupPauseObserver;
  2526. private _onBeforeRenderObserver;
  2527. constructor(props: IAnimationGroupGridComponentProps);
  2528. disconnect(animationGroup: BABYLON.AnimationGroup): void;
  2529. connect(animationGroup: BABYLON.AnimationGroup): void;
  2530. updateCurrentFrame(animationGroup: BABYLON.AnimationGroup): void;
  2531. shouldComponentUpdate(nextProps: IAnimationGroupGridComponentProps): boolean;
  2532. componentWillMount(): void;
  2533. componentWillUnmount(): void;
  2534. playOrPause(): void;
  2535. onCurrentFrameChange(value: number): void;
  2536. render(): JSX.Element;
  2537. }
  2538. }
  2539. declare module INSPECTOR {
  2540. interface IImagePropertyGridComponentProps {
  2541. image: BABYLON.GUI.Image;
  2542. lockObject: LockObject;
  2543. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2544. }
  2545. export class ImagePropertyGridComponent extends React.Component<IImagePropertyGridComponentProps> {
  2546. constructor(props: IImagePropertyGridComponentProps);
  2547. render(): JSX.Element;
  2548. }
  2549. }
  2550. declare module INSPECTOR {
  2551. interface ISliderPropertyGridComponentProps {
  2552. slider: BABYLON.GUI.Slider;
  2553. lockObject: LockObject;
  2554. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2555. }
  2556. export class SliderPropertyGridComponent extends React.Component<ISliderPropertyGridComponentProps> {
  2557. constructor(props: ISliderPropertyGridComponentProps);
  2558. render(): JSX.Element;
  2559. }
  2560. }
  2561. declare module INSPECTOR {
  2562. interface IImageBasedSliderPropertyGridComponentProps {
  2563. imageBasedSlider: BABYLON.GUI.ImageBasedSlider;
  2564. lockObject: LockObject;
  2565. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2566. }
  2567. export class ImageBasedSliderPropertyGridComponent extends React.Component<IImageBasedSliderPropertyGridComponentProps> {
  2568. constructor(props: IImageBasedSliderPropertyGridComponentProps);
  2569. render(): JSX.Element;
  2570. }
  2571. }
  2572. declare module INSPECTOR {
  2573. interface IRectanglePropertyGridComponentProps {
  2574. rectangle: BABYLON.GUI.Rectangle;
  2575. lockObject: LockObject;
  2576. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2577. }
  2578. export class RectanglePropertyGridComponent extends React.Component<IRectanglePropertyGridComponentProps> {
  2579. constructor(props: IRectanglePropertyGridComponentProps);
  2580. render(): JSX.Element;
  2581. }
  2582. }
  2583. declare module INSPECTOR {
  2584. interface IEllipsePropertyGridComponentProps {
  2585. ellipse: BABYLON.GUI.Ellipse;
  2586. lockObject: LockObject;
  2587. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2588. }
  2589. export class EllipsePropertyGridComponent extends React.Component<IEllipsePropertyGridComponentProps> {
  2590. constructor(props: IEllipsePropertyGridComponentProps);
  2591. render(): JSX.Element;
  2592. }
  2593. }
  2594. declare module INSPECTOR {
  2595. interface ICheckboxPropertyGridComponentProps {
  2596. checkbox: BABYLON.GUI.Checkbox;
  2597. lockObject: LockObject;
  2598. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2599. }
  2600. export class CheckboxPropertyGridComponent extends React.Component<ICheckboxPropertyGridComponentProps> {
  2601. constructor(props: ICheckboxPropertyGridComponentProps);
  2602. render(): JSX.Element;
  2603. }
  2604. }
  2605. declare module INSPECTOR {
  2606. interface IRadioButtonPropertyGridComponentProps {
  2607. radioButton: BABYLON.GUI.RadioButton;
  2608. lockObject: LockObject;
  2609. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2610. }
  2611. export class RadioButtonPropertyGridComponent extends React.Component<IRadioButtonPropertyGridComponentProps> {
  2612. constructor(props: IRadioButtonPropertyGridComponentProps);
  2613. render(): JSX.Element;
  2614. }
  2615. }
  2616. declare module INSPECTOR {
  2617. interface ILinePropertyGridComponentProps {
  2618. line: BABYLON.GUI.Line;
  2619. lockObject: LockObject;
  2620. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2621. }
  2622. export class LinePropertyGridComponent extends React.Component<ILinePropertyGridComponentProps> {
  2623. constructor(props: ILinePropertyGridComponentProps);
  2624. onDashChange(value: string): void;
  2625. render(): JSX.Element;
  2626. }
  2627. }
  2628. declare module INSPECTOR {
  2629. interface IScrollViewerPropertyGridComponentProps {
  2630. scrollViewer: BABYLON.GUI.ScrollViewer;
  2631. lockObject: LockObject;
  2632. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2633. }
  2634. export class ScrollViewerPropertyGridComponent extends React.Component<IScrollViewerPropertyGridComponentProps> {
  2635. constructor(props: IScrollViewerPropertyGridComponentProps);
  2636. render(): JSX.Element;
  2637. }
  2638. }
  2639. declare module INSPECTOR {
  2640. interface IGridPropertyGridComponentProps {
  2641. grid: BABYLON.GUI.Grid;
  2642. lockObject: LockObject;
  2643. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2644. }
  2645. export class GridPropertyGridComponent extends React.Component<IGridPropertyGridComponentProps> {
  2646. constructor(props: IGridPropertyGridComponentProps);
  2647. renderRows(): JSX.Element[];
  2648. renderColumns(): JSX.Element[];
  2649. render(): JSX.Element;
  2650. }
  2651. }
  2652. declare module INSPECTOR {
  2653. interface IPBRMetallicRoughnessMaterialPropertyGridComponentProps {
  2654. material: BABYLON.PBRMetallicRoughnessMaterial;
  2655. lockObject: LockObject;
  2656. onSelectionChangedObservable?: BABYLON.Observable<any>;
  2657. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2658. }
  2659. export class PBRMetallicRoughnessMaterialPropertyGridComponent extends React.Component<IPBRMetallicRoughnessMaterialPropertyGridComponentProps> {
  2660. constructor(props: IPBRMetallicRoughnessMaterialPropertyGridComponentProps);
  2661. renderTextures(): JSX.Element | null;
  2662. render(): JSX.Element;
  2663. }
  2664. }
  2665. declare module INSPECTOR {
  2666. interface IPBRSpecularGlossinessMaterialPropertyGridComponentProps {
  2667. material: BABYLON.PBRSpecularGlossinessMaterial;
  2668. lockObject: LockObject;
  2669. onSelectionChangedObservable?: BABYLON.Observable<any>;
  2670. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2671. }
  2672. export class PBRSpecularGlossinessMaterialPropertyGridComponent extends React.Component<IPBRSpecularGlossinessMaterialPropertyGridComponentProps> {
  2673. constructor(props: IPBRSpecularGlossinessMaterialPropertyGridComponentProps);
  2674. renderTextures(): JSX.Element | null;
  2675. render(): JSX.Element;
  2676. }
  2677. }
  2678. declare module INSPECTOR {
  2679. interface IStackPanelPropertyGridComponentProps {
  2680. stackPanel: BABYLON.GUI.StackPanel;
  2681. lockObject: LockObject;
  2682. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  2683. }
  2684. export class StackPanelPropertyGridComponent extends React.Component<IStackPanelPropertyGridComponentProps> {
  2685. constructor(props: IStackPanelPropertyGridComponentProps);
  2686. render(): JSX.Element;
  2687. }
  2688. }
  2689. declare module INSPECTOR {
  2690. export class PropertyGridTabComponent extends PaneComponent {
  2691. private _timerIntervalId;
  2692. private _lockObject;
  2693. constructor(props: IPaneComponentProps);
  2694. timerRefresh(): void;
  2695. componentWillMount(): void;
  2696. componentWillUnmount(): void;
  2697. render(): JSX.Element | null;
  2698. }
  2699. }
  2700. declare module INSPECTOR {
  2701. export interface IHeaderComponentProps {
  2702. title: string;
  2703. handleBack?: boolean;
  2704. noExpand?: boolean;
  2705. noClose?: boolean;
  2706. noCommands?: boolean;
  2707. onPopup: () => void;
  2708. onClose: () => void;
  2709. onSelectionChangedObservable?: BABYLON.Observable<any>;
  2710. }
  2711. export class HeaderComponent extends React.Component<IHeaderComponentProps, {
  2712. isBackVisible: boolean;
  2713. }> {
  2714. private _backStack;
  2715. private _onSelectionChangeObserver;
  2716. constructor(props: IHeaderComponentProps);
  2717. componentWillMount(): void;
  2718. componentWillUnmount(): void;
  2719. goBack(): void;
  2720. renderLogo(): JSX.Element | null;
  2721. render(): JSX.Element;
  2722. }
  2723. }
  2724. declare module INSPECTOR {
  2725. interface IMessageLineComponentProps {
  2726. text: string;
  2727. color?: string;
  2728. }
  2729. export class MessageLineComponent extends React.Component<IMessageLineComponentProps> {
  2730. constructor(props: IMessageLineComponentProps);
  2731. render(): JSX.Element;
  2732. }
  2733. }
  2734. declare module INSPECTOR {
  2735. interface IGLTFComponentProps {
  2736. scene: BABYLON.Scene;
  2737. globalState: GlobalState;
  2738. }
  2739. export class GLTFComponent extends React.Component<IGLTFComponentProps> {
  2740. constructor(props: IGLTFComponentProps);
  2741. openValidationDetails(): void;
  2742. prepareText(singularForm: string, count: number): string;
  2743. renderValidation(): JSX.Element;
  2744. render(): JSX.Element;
  2745. }
  2746. }
  2747. declare module INSPECTOR {
  2748. export class ToolsTabComponent extends PaneComponent {
  2749. private _videoRecorder;
  2750. constructor(props: IPaneComponentProps);
  2751. componentWillMount(): void;
  2752. componentWillUnmount(): void;
  2753. captureScreenshot(): void;
  2754. recordVideo(): void;
  2755. shouldExport(transformNode: BABYLON.TransformNode): boolean;
  2756. exportGLTF(): void;
  2757. exportBabylon(): void;
  2758. createEnvTexture(): void;
  2759. render(): JSX.Element | null;
  2760. }
  2761. }
  2762. declare module INSPECTOR {
  2763. interface IActionTabsComponentProps {
  2764. scene: BABYLON.Scene;
  2765. noCommands?: boolean;
  2766. noHeader?: boolean;
  2767. noExpand?: boolean;
  2768. noClose?: boolean;
  2769. popupMode?: boolean;
  2770. onPopup?: () => void;
  2771. onClose?: () => void;
  2772. globalState: GlobalState;
  2773. }
  2774. export class ActionTabsComponent extends React.Component<IActionTabsComponentProps, {
  2775. selectedEntity: any;
  2776. selectedIndex: number;
  2777. }> {
  2778. private _onSelectionChangeObserver;
  2779. private _onTabChangedObserver;
  2780. private _once;
  2781. constructor(props: IActionTabsComponentProps);
  2782. componentWillMount(): void;
  2783. componentWillUnmount(): void;
  2784. changeSelectedTab(index: number): void;
  2785. renderContent(): JSX.Element;
  2786. onClose(): void;
  2787. onPopup(): void;
  2788. render(): JSX.Element;
  2789. }
  2790. }
  2791. declare module INSPECTOR {
  2792. interface ITreeItemLabelComponentProps {
  2793. label: string;
  2794. onClick?: () => void;
  2795. color: string;
  2796. }
  2797. export class TreeItemLabelComponent extends React.Component<ITreeItemLabelComponentProps> {
  2798. constructor(props: ITreeItemLabelComponentProps);
  2799. onClick(): void;
  2800. render(): JSX.Element;
  2801. }
  2802. }
  2803. declare module INSPECTOR {
  2804. interface IExtensionsComponentProps {
  2805. target: any;
  2806. extensibilityGroups?: BABYLON.IExplorerExtensibilityGroup[];
  2807. }
  2808. export class ExtensionsComponent extends React.Component<IExtensionsComponentProps, {
  2809. popupVisible: boolean;
  2810. }> {
  2811. private _popup;
  2812. constructor(props: IExtensionsComponentProps);
  2813. showPopup(): void;
  2814. componentDidMount(): void;
  2815. componentDidUpdate(): void;
  2816. render(): JSX.Element | null;
  2817. }
  2818. }
  2819. declare module INSPECTOR {
  2820. interface IMeshTreeItemComponentProps {
  2821. mesh: BABYLON.AbstractMesh;
  2822. extensibilityGroups?: BABYLON.IExplorerExtensibilityGroup[];
  2823. onClick: () => void;
  2824. }
  2825. export class MeshTreeItemComponent extends React.Component<IMeshTreeItemComponentProps, {
  2826. isGizmoEnabled: boolean;
  2827. isVisible: boolean;
  2828. }> {
  2829. constructor(props: IMeshTreeItemComponentProps);
  2830. showGizmos(): void;
  2831. switchVisibility(): void;
  2832. render(): JSX.Element;
  2833. }
  2834. }
  2835. declare module INSPECTOR {
  2836. interface ICameraTreeItemComponentProps {
  2837. camera: BABYLON.Camera;
  2838. extensibilityGroups?: BABYLON.IExplorerExtensibilityGroup[];
  2839. onClick: () => void;
  2840. }
  2841. export class CameraTreeItemComponent extends React.Component<ICameraTreeItemComponentProps, {
  2842. isActive: boolean;
  2843. }> {
  2844. private _onActiveCameraObserver;
  2845. constructor(props: ICameraTreeItemComponentProps);
  2846. setActive(): void;
  2847. componentWillMount(): void;
  2848. componentWillUnmount(): void;
  2849. render(): JSX.Element;
  2850. }
  2851. }
  2852. declare module INSPECTOR {
  2853. interface ILightTreeItemComponentProps {
  2854. light: BABYLON.Light;
  2855. extensibilityGroups?: BABYLON.IExplorerExtensibilityGroup[];
  2856. onClick: () => void;
  2857. globalState: GlobalState;
  2858. }
  2859. export class LightTreeItemComponent extends React.Component<ILightTreeItemComponentProps, {
  2860. isEnabled: boolean;
  2861. }> {
  2862. constructor(props: ILightTreeItemComponentProps);
  2863. switchIsEnabled(): void;
  2864. render(): JSX.Element;
  2865. }
  2866. }
  2867. declare module INSPECTOR {
  2868. interface IMaterialTreeItemComponentProps {
  2869. material: BABYLON.Material;
  2870. extensibilityGroups?: BABYLON.IExplorerExtensibilityGroup[];
  2871. onClick: () => void;
  2872. }
  2873. export class MaterialTreeItemComponent extends React.Component<IMaterialTreeItemComponentProps> {
  2874. constructor(props: IMaterialTreeItemComponentProps);
  2875. render(): JSX.Element;
  2876. }
  2877. }
  2878. declare module INSPECTOR {
  2879. interface ITextureTreeItemComponentProps {
  2880. texture: BABYLON.Texture;
  2881. extensibilityGroups?: BABYLON.IExplorerExtensibilityGroup[];
  2882. onClick: () => void;
  2883. }
  2884. export class TextureTreeItemComponent extends React.Component<ITextureTreeItemComponentProps> {
  2885. constructor(props: ITextureTreeItemComponentProps);
  2886. render(): JSX.Element;
  2887. }
  2888. }
  2889. declare module INSPECTOR {
  2890. interface ITransformNodeItemComponentProps {
  2891. transformNode: BABYLON.TransformNode;
  2892. extensibilityGroups?: BABYLON.IExplorerExtensibilityGroup[];
  2893. onClick: () => void;
  2894. }
  2895. export class TransformNodeItemComponent extends React.Component<ITransformNodeItemComponentProps> {
  2896. constructor(props: ITransformNodeItemComponentProps);
  2897. render(): JSX.Element;
  2898. }
  2899. }
  2900. declare module INSPECTOR {
  2901. interface IControlTreeItemComponentProps {
  2902. control: BABYLON.GUI.Control;
  2903. extensibilityGroups?: BABYLON.IExplorerExtensibilityGroup[];
  2904. onClick: () => void;
  2905. }
  2906. export class ControlTreeItemComponent extends React.Component<IControlTreeItemComponentProps, {
  2907. isActive: boolean;
  2908. isVisible: boolean;
  2909. }> {
  2910. constructor(props: IControlTreeItemComponentProps);
  2911. highlight(): void;
  2912. switchVisibility(): void;
  2913. render(): JSX.Element;
  2914. }
  2915. }
  2916. declare module INSPECTOR {
  2917. interface IAdvancedDynamicTextureTreeItemComponentProps {
  2918. texture: BABYLON.GUI.AdvancedDynamicTexture;
  2919. extensibilityGroups?: BABYLON.IExplorerExtensibilityGroup[];
  2920. onSelectionChangedObservable?: BABYLON.Observable<any>;
  2921. onClick: () => void;
  2922. }
  2923. export class AdvancedDynamicTextureTreeItemComponent extends React.Component<IAdvancedDynamicTextureTreeItemComponentProps, {
  2924. isInPickingMode: boolean;
  2925. }> {
  2926. private _onControlPickedObserver;
  2927. constructor(props: IAdvancedDynamicTextureTreeItemComponentProps);
  2928. componentWillUnmount(): void;
  2929. onPickingMode(): void;
  2930. render(): JSX.Element;
  2931. }
  2932. }
  2933. declare module INSPECTOR {
  2934. interface IAnimationGroupItemComponentProps {
  2935. animationGroup: BABYLON.AnimationGroup;
  2936. extensibilityGroups?: BABYLON.IExplorerExtensibilityGroup[];
  2937. onClick: () => void;
  2938. }
  2939. export class AnimationGroupItemComponent extends React.Component<IAnimationGroupItemComponentProps> {
  2940. constructor(props: IAnimationGroupItemComponentProps);
  2941. render(): JSX.Element;
  2942. }
  2943. }
  2944. declare module INSPECTOR {
  2945. interface ITreeItemSpecializedComponentProps {
  2946. label: string;
  2947. entity?: any;
  2948. extensibilityGroups?: BABYLON.IExplorerExtensibilityGroup[];
  2949. globalState: GlobalState;
  2950. onClick?: () => void;
  2951. }
  2952. export class TreeItemSpecializedComponent extends React.Component<ITreeItemSpecializedComponentProps> {
  2953. constructor(props: ITreeItemSpecializedComponentProps);
  2954. onClick(): void;
  2955. render(): JSX.Element;
  2956. }
  2957. }
  2958. declare module INSPECTOR {
  2959. export class Tools {
  2960. static LookForItem(item: any, selectedEntity: any): boolean;
  2961. private static _RecursiveRemoveHiddenMeshesAndHoistChildren;
  2962. static SortAndFilter(parent: any, items: any[]): any[];
  2963. }
  2964. }
  2965. declare module INSPECTOR {
  2966. export interface ITreeItemSelectableComponentProps {
  2967. entity: any;
  2968. selectedEntity?: any;
  2969. mustExpand?: boolean;
  2970. offset: number;
  2971. globalState: GlobalState;
  2972. extensibilityGroups?: BABYLON.IExplorerExtensibilityGroup[];
  2973. filter: BABYLON.Nullable<string>;
  2974. }
  2975. export class TreeItemSelectableComponent extends React.Component<ITreeItemSelectableComponentProps, {
  2976. isExpanded: boolean;
  2977. isSelected: boolean;
  2978. }> {
  2979. private _wasSelected;
  2980. constructor(props: ITreeItemSelectableComponentProps);
  2981. switchExpandedState(): void;
  2982. shouldComponentUpdate(nextProps: ITreeItemSelectableComponentProps, nextState: {
  2983. isExpanded: boolean;
  2984. isSelected: boolean;
  2985. }): boolean;
  2986. scrollIntoView(): void;
  2987. componentDidMount(): void;
  2988. componentDidUpdate(): void;
  2989. onSelect(): void;
  2990. renderChildren(): JSX.Element[] | null;
  2991. render(): JSX.Element | null;
  2992. }
  2993. }
  2994. declare module INSPECTOR {
  2995. export interface ITreeItemComponentProps {
  2996. items?: BABYLON.Nullable<any[]>;
  2997. label: string;
  2998. offset: number;
  2999. filter: BABYLON.Nullable<string>;
  3000. globalState: GlobalState;
  3001. entity?: any;
  3002. selectedEntity: any;
  3003. extensibilityGroups?: BABYLON.IExplorerExtensibilityGroup[];
  3004. }
  3005. export class TreeItemComponent extends React.Component<ITreeItemComponentProps, {
  3006. isExpanded: boolean;
  3007. mustExpand: boolean;
  3008. }> {
  3009. constructor(props: ITreeItemComponentProps);
  3010. switchExpandedState(): void;
  3011. shouldComponentUpdate(nextProps: ITreeItemComponentProps, nextState: {
  3012. isExpanded: boolean;
  3013. }): boolean;
  3014. expandAll(expand: boolean): void;
  3015. render(): JSX.Element;
  3016. }
  3017. }
  3018. declare module INSPECTOR {
  3019. interface ISceneTreeItemComponentProps {
  3020. scene: BABYLON.Scene;
  3021. onRefresh: () => void;
  3022. selectedEntity?: any;
  3023. extensibilityGroups?: BABYLON.IExplorerExtensibilityGroup[];
  3024. onSelectionChangedObservable?: BABYLON.Observable<any>;
  3025. }
  3026. export class SceneTreeItemComponent extends React.Component<ISceneTreeItemComponentProps, {
  3027. isSelected: boolean;
  3028. isInPickingMode: boolean;
  3029. gizmoMode: number;
  3030. }> {
  3031. private _onPointerObserver;
  3032. private _onSelectionChangeObserver;
  3033. private _selectedEntity;
  3034. constructor(props: ISceneTreeItemComponentProps);
  3035. shouldComponentUpdate(nextProps: ISceneTreeItemComponentProps, nextState: {
  3036. isSelected: boolean;
  3037. isInPickingMode: boolean;
  3038. }): boolean;
  3039. componentWillMount(): void;
  3040. componentWillUnmount(): void;
  3041. onSelect(): void;
  3042. onPickingMode(): void;
  3043. setGizmoMode(mode: number): void;
  3044. render(): JSX.Element;
  3045. }
  3046. }
  3047. declare module INSPECTOR {
  3048. interface ISceneExplorerFilterComponentProps {
  3049. onFilter: (filter: string) => void;
  3050. }
  3051. export class SceneExplorerFilterComponent extends React.Component<ISceneExplorerFilterComponentProps> {
  3052. constructor(props: ISceneExplorerFilterComponentProps);
  3053. render(): JSX.Element;
  3054. }
  3055. interface ISceneExplorerComponentProps {
  3056. scene: BABYLON.Scene;
  3057. noCommands?: boolean;
  3058. noHeader?: boolean;
  3059. noExpand?: boolean;
  3060. noClose?: boolean;
  3061. extensibilityGroups?: BABYLON.IExplorerExtensibilityGroup[];
  3062. globalState: GlobalState;
  3063. popupMode?: boolean;
  3064. onPopup?: () => void;
  3065. onClose?: () => void;
  3066. }
  3067. export class SceneExplorerComponent extends React.Component<ISceneExplorerComponentProps, {
  3068. filter: BABYLON.Nullable<string>;
  3069. selectedEntity: any;
  3070. scene: BABYLON.Scene;
  3071. }> {
  3072. private _onSelectionChangeObserver;
  3073. private _onNewSceneAddedObserver;
  3074. private _once;
  3075. private sceneMutationFunc;
  3076. constructor(props: ISceneExplorerComponentProps);
  3077. processMutation(): void;
  3078. componentWillMount(): void;
  3079. componentWillUnmount(): void;
  3080. filterContent(filter: string): void;
  3081. findSiblings(parent: any, items: any[], target: any, goNext: boolean, data: {
  3082. previousOne?: any;
  3083. found?: boolean;
  3084. }): boolean;
  3085. processKeys(keyEvent: React.KeyboardEvent<HTMLDivElement>): void;
  3086. renderContent(): JSX.Element | null;
  3087. onClose(): void;
  3088. onPopup(): void;
  3089. render(): JSX.Element;
  3090. }
  3091. }
  3092. declare module INSPECTOR {
  3093. interface IEmbedHostComponentProps {
  3094. scene: BABYLON.Scene;
  3095. globalState: GlobalState;
  3096. popupMode: boolean;
  3097. noClose?: boolean;
  3098. noExpand?: boolean;
  3099. onClose: () => void;
  3100. onPopup: () => void;
  3101. }
  3102. export class EmbedHostComponent extends React.Component<IEmbedHostComponentProps> {
  3103. private _once;
  3104. constructor(props: IEmbedHostComponentProps);
  3105. componentDidMount(): void;
  3106. renderContent(): JSX.Element;
  3107. render(): JSX.Element;
  3108. }
  3109. }
  3110. declare module INSPECTOR {
  3111. export class Inspector {
  3112. private static _SceneExplorerHost;
  3113. private static _ActionTabsHost;
  3114. private static _EmbedHost;
  3115. private static _NewCanvasContainer;
  3116. private static _SceneExplorerWindow;
  3117. private static _ActionTabsWindow;
  3118. private static _EmbedHostWindow;
  3119. private static _Scene;
  3120. private static _OpenedPane;
  3121. private static _OnBeforeRenderObserver;
  3122. static OnSelectionChangeObservable: BABYLON.Observable<string>;
  3123. static OnPropertyChangedObservable: BABYLON.Observable<PropertyChangedEvent>;
  3124. private static _GlobalState;
  3125. private static _CopyStyles;
  3126. private static _CreateSceneExplorer;
  3127. private static _CreateActionTabs;
  3128. private static _CreateEmbedHost;
  3129. private static _CreatePopup;
  3130. static readonly IsVisible: boolean;
  3131. static EarlyAttachToLoader(): void;
  3132. static Show(scene: BABYLON.Scene, userOptions: Partial<BABYLON.IInspectorOptions>): void;
  3133. private static _CreateCanvasContainer;
  3134. private static _DestroyCanvasContainer;
  3135. private static _Cleanup;
  3136. private static _RemoveElementFromDOM;
  3137. static Hide(): void;
  3138. }
  3139. }
  3140. declare module INSPECTOR {
  3141. interface IDirectionalLightPropertyGridComponentProps {
  3142. light: BABYLON.DirectionalLight;
  3143. lockObject: LockObject;
  3144. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  3145. }
  3146. export class DirectionalLightPropertyGridComponent extends React.Component<IDirectionalLightPropertyGridComponentProps> {
  3147. constructor(props: IDirectionalLightPropertyGridComponentProps);
  3148. render(): JSX.Element;
  3149. }
  3150. }
  3151. declare module INSPECTOR {
  3152. interface ISpotLightPropertyGridComponentProps {
  3153. light: BABYLON.SpotLight;
  3154. lockObject: LockObject;
  3155. onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
  3156. }
  3157. export class SpotLightPropertyGridComponent extends React.Component<ISpotLightPropertyGridComponentProps> {
  3158. constructor(props: ISpotLightPropertyGridComponentProps);
  3159. render(): JSX.Element;
  3160. }
  3161. }