123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609 |
- /// <reference types="react" />
- declare module NODEEDITOR {
- /**
- * Port model
- */
- export class DefaultPortModel extends PortModel {
- /**
- * If the port is input or output
- */
- position: string | "input" | "output";
- /**
- * What the port is connected to
- */
- connection: BABYLON.Nullable<BABYLON.NodeMaterialConnectionPoint>;
- static idCounter: number;
- constructor(name: string, type?: string);
- syncWithNodeMaterialConnectionPoint(connection: BABYLON.NodeMaterialConnectionPoint): void;
- getNodeModel(): DefaultNodeModel;
- link(outPort: DefaultPortModel): LinkModel<import("storm-react-diagrams").LinkModelListener>;
- getInputFromBlock(): void;
- createLinkModel(): LinkModel;
- getValue: Function;
- static SortInputOutput(a: BABYLON.Nullable<DefaultPortModel>, b: BABYLON.Nullable<DefaultPortModel>): {
- input: DefaultPortModel;
- output: DefaultPortModel;
- } | null;
- }
- }
- declare module NODEEDITOR {
- interface ITextLineComponentProps {
- label: string;
- value: string;
- color?: string;
- underline?: boolean;
- onLink?: () => void;
- }
- export class TextLineComponent extends React.Component<ITextLineComponentProps> {
- constructor(props: ITextLineComponentProps);
- onLink(): void;
- renderContent(): JSX.Element;
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- /**
- * Generic node model which stores information about a node editor block
- */
- export class GenericNodeModel extends DefaultNodeModel {
- /**
- * Labels for the block
- */
- header: string;
- /**
- * BABYLON.Vector2 for the node if it exists
- */
- vector2: BABYLON.Nullable<BABYLON.Vector2>;
- /**
- * BABYLON.Vector3 for the node if it exists
- */
- vector3: BABYLON.Nullable<BABYLON.Vector3>;
- /**
- * BABYLON.Vector4 for the node if it exists
- */
- vector4: BABYLON.Nullable<BABYLON.Vector4>;
- /**
- * BABYLON.Matrix for the node if it exists
- */
- matrix: BABYLON.Nullable<BABYLON.Matrix>;
- /**
- * Constructs the node model
- */
- constructor();
- prepare(options: NodeCreationOptions, nodes: Array<DefaultNodeModel>, model: DiagramModel, graphEditor: GraphEditor, filterInputs: string[]): void;
- renderProperties(globalState: GlobalState): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- /**
- * GenericNodeWidgetProps
- */
- export interface GenericNodeWidgetProps {
- node: BABYLON.Nullable<GenericNodeModel>;
- globalState: GlobalState;
- }
- /**
- * GenericNodeWidgetState
- */
- export interface GenericNodeWidgetState {
- }
- /**
- * Used to display a node block for the node editor
- */
- export class GenericNodeWidget extends React.Component<GenericNodeWidgetProps, GenericNodeWidgetState> {
- /**
- * Creates a GenericNodeWidget
- * @param props
- */
- constructor(props: GenericNodeWidgetProps);
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- /**
- * Node factory which creates editor nodes
- */
- export class GenericNodeFactory extends SRD.AbstractNodeFactory {
- private _globalState;
- /**
- * Constructs a GenericNodeFactory
- */
- constructor(globalState: GlobalState);
- /**
- * Generates a node widget
- * @param diagramEngine diagram engine
- * @param node node to generate
- * @returns node widget jsx
- */
- generateReactWidget(diagramEngine: SRD.DiagramEngine, node: GenericNodeModel): JSX.Element;
- /**
- * Gets a new instance of a node model
- * @returns generic node model
- */
- getNewInstance(): GenericNodeModel;
- }
- }
- declare module NODEEDITOR {
- interface ILineContainerComponentProps {
- title: string;
- children: any[] | any;
- closed?: boolean;
- }
- export class LineContainerComponent extends React.Component<ILineContainerComponentProps, {
- isExpanded: boolean;
- }> {
- private static _InMemoryStorage;
- constructor(props: ILineContainerComponentProps);
- switchExpandedState(): void;
- renderHeader(): JSX.Element;
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- export interface IButtonLineComponentProps {
- label: string;
- onClick: () => void;
- }
- export class ButtonLineComponent extends React.Component<IButtonLineComponentProps> {
- constructor(props: IButtonLineComponentProps);
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- interface INodeListComponentProps {
- globalState: GlobalState;
- onAddValueNode: (b: string) => void;
- onAddNodeFromClass: (ObjectClass: typeof BABYLON.NodeMaterialBlock) => void;
- }
- export class NodeListComponent extends React.Component<INodeListComponentProps> {
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- interface IPropertyTabComponentProps {
- globalState: GlobalState;
- }
- export class PropertyTabComponent extends React.Component<IPropertyTabComponentProps, {
- currentNode: BABYLON.Nullable<DefaultNodeModel>;
- }> {
- constructor(props: IPropertyTabComponentProps);
- componentWillMount(): void;
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- interface IPortalProps {
- globalState: GlobalState;
- }
- export class Portal extends React.Component<IPortalProps> {
- render(): React.ReactPortal;
- }
- }
- declare module NODEEDITOR {
- interface IFileButtonLineComponentProps {
- label: string;
- onClick: (file: File) => void;
- accept: string;
- }
- export class FileButtonLineComponent extends React.Component<IFileButtonLineComponentProps> {
- constructor(props: IFileButtonLineComponentProps);
- onChange(evt: any): void;
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- interface ITexturePropertyTabComponentProps {
- globalState: GlobalState;
- node: TextureNodeModel;
- }
- export class TexturePropertyTabComponent extends React.Component<ITexturePropertyTabComponentProps> {
- /**
- * Replaces the texture of the node
- * @param file the file of the texture to use
- */
- replaceTexture(file: File): void;
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- /**
- * BABYLON.Texture node model which stores information about a node editor block
- */
- export class TextureNodeModel extends DefaultNodeModel {
- /**
- * BABYLON.Texture for the node if it exists
- */
- texture: BABYLON.Nullable<BABYLON.Texture>;
- /**
- * Constructs the node model
- */
- constructor();
- renderProperties(globalState: GlobalState): JSX.Element;
- prepare(options: NodeCreationOptions, nodes: Array<DefaultNodeModel>, model: DiagramModel, graphEditor: GraphEditor, filterInputs: string[]): void;
- }
- }
- declare module NODEEDITOR {
- interface ITextureLineComponentProps {
- texture: BABYLON.BaseTexture;
- width: number;
- height: number;
- globalState?: any;
- hideChannelSelect?: boolean;
- }
- export class TextureLineComponent extends React.Component<ITextureLineComponentProps, {
- displayRed: boolean;
- displayGreen: boolean;
- displayBlue: boolean;
- displayAlpha: boolean;
- face: number;
- }> {
- constructor(props: ITextureLineComponentProps);
- shouldComponentUpdate(nextProps: ITextureLineComponentProps, nextState: {
- displayRed: boolean;
- displayGreen: boolean;
- displayBlue: boolean;
- displayAlpha: boolean;
- face: number;
- }): boolean;
- componentDidMount(): void;
- componentDidUpdate(): void;
- updatePreview(): void;
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- /**
- * GenericNodeWidgetProps
- */
- export interface TextureNodeWidgetProps {
- node: BABYLON.Nullable<TextureNodeModel>;
- globalState: GlobalState;
- }
- /**
- * Used to display a node block for the node editor
- */
- export class TextureNodeWidget extends React.Component<TextureNodeWidgetProps> {
- /**
- * Creates a GenericNodeWidget
- * @param props
- */
- constructor(props: TextureNodeWidgetProps);
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- /**
- * Node factory which creates editor nodes
- */
- export class TextureNodeFactory extends SRD.AbstractNodeFactory {
- private _globalState;
- /**
- * Constructs a TextureNodeFactory
- */
- constructor(globalState: GlobalState);
- /**
- * Generates a node widget
- * @param diagramEngine diagram engine
- * @param node node to generate
- * @returns node widget jsx
- */
- generateReactWidget(diagramEngine: SRD.DiagramEngine, node: TextureNodeModel): JSX.Element;
- /**
- * Gets a new instance of a node model
- * @returns texture node model
- */
- getNewInstance(): TextureNodeModel;
- }
- }
- declare module NODEEDITOR {
- interface INumericInputComponentProps {
- label: string;
- value: number;
- step?: number;
- onChange: (value: number) => void;
- }
- export class NumericInputComponent extends React.Component<INumericInputComponentProps, {
- value: string;
- }> {
- static defaultProps: {
- step: number;
- };
- private _localChange;
- constructor(props: INumericInputComponentProps);
- shouldComponentUpdate(nextProps: INumericInputComponentProps, nextState: {
- value: string;
- }): boolean;
- updateValue(evt: any): void;
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- export class PropertyChangedEvent {
- object: any;
- property: string;
- value: any;
- initialValue: any;
- }
- }
- declare module NODEEDITOR {
- interface IVector2LineComponentProps {
- label: string;
- target: any;
- propertyName: string;
- step?: number;
- onChange?: (newvalue: BABYLON.Vector2) => void;
- onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
- }
- export class Vector2LineComponent extends React.Component<IVector2LineComponentProps, {
- isExpanded: boolean;
- value: BABYLON.Vector2;
- }> {
- static defaultProps: {
- step: number;
- };
- private _localChange;
- constructor(props: IVector2LineComponentProps);
- shouldComponentUpdate(nextProps: IVector2LineComponentProps, nextState: {
- isExpanded: boolean;
- value: BABYLON.Vector2;
- }): boolean;
- switchExpandState(): void;
- raiseOnPropertyChanged(previousValue: BABYLON.Vector2): void;
- updateStateX(value: number): void;
- updateStateY(value: number): void;
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- interface IVector2PropertyTabComponentProps {
- globalState: GlobalState;
- connection: BABYLON.NodeMaterialConnectionPoint;
- }
- export class Vector2PropertyTabComponent extends React.Component<IVector2PropertyTabComponentProps> {
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- interface IVector3LineComponentProps {
- label: string;
- target: any;
- propertyName: string;
- step?: number;
- onChange?: (newvalue: BABYLON.Vector3) => void;
- onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
- }
- export class Vector3LineComponent extends React.Component<IVector3LineComponentProps, {
- isExpanded: boolean;
- value: BABYLON.Vector3;
- }> {
- static defaultProps: {
- step: number;
- };
- private _localChange;
- constructor(props: IVector3LineComponentProps);
- shouldComponentUpdate(nextProps: IVector3LineComponentProps, nextState: {
- isExpanded: boolean;
- value: BABYLON.Vector3;
- }): boolean;
- switchExpandState(): void;
- raiseOnPropertyChanged(previousValue: BABYLON.Vector3): void;
- updateVector3(): void;
- updateStateX(value: number): void;
- updateStateY(value: number): void;
- updateStateZ(value: number): void;
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- interface IVector3PropertyTabComponentProps {
- globalState: GlobalState;
- connection: BABYLON.NodeMaterialConnectionPoint;
- }
- export class Vector3PropertyTabComponent extends React.Component<IVector3PropertyTabComponentProps> {
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- export interface ICheckBoxLineComponentProps {
- label: string;
- target?: any;
- propertyName?: string;
- isSelected?: () => boolean;
- onSelect?: (value: boolean) => void;
- onValueChanged?: () => void;
- onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
- }
- export class CheckBoxLineComponent extends React.Component<ICheckBoxLineComponentProps, {
- isSelected: boolean;
- }> {
- private static _UniqueIdSeed;
- private _uniqueId;
- private _localChange;
- constructor(props: ICheckBoxLineComponentProps);
- shouldComponentUpdate(nextProps: ICheckBoxLineComponentProps, nextState: {
- isSelected: boolean;
- }): boolean;
- onChange(): void;
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- class ListLineOption {
- label: string;
- value: number;
- }
- interface IOptionsLineComponentProps {
- label: string;
- target: any;
- propertyName: string;
- options: ListLineOption[];
- noDirectUpdate?: boolean;
- onSelect?: (value: number) => void;
- onPropertyChangedObservable?: BABYLON.Observable<PropertyChangedEvent>;
- }
- export class OptionsLineComponent extends React.Component<IOptionsLineComponentProps, {
- value: number;
- }> {
- private _localChange;
- constructor(props: IOptionsLineComponentProps);
- shouldComponentUpdate(nextProps: IOptionsLineComponentProps, nextState: {
- value: number;
- }): boolean;
- raiseOnPropertyChanged(newValue: number, previousValue: number): void;
- updateValue(valueString: string): void;
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- interface IInputPropertyTabComponentProps {
- globalState: GlobalState;
- inputNode: InputNodeModel;
- }
- export class InputPropertyTabComponentProps extends React.Component<IInputPropertyTabComponentProps> {
- constructor(props: IInputPropertyTabComponentProps);
- renderValue(globalState: GlobalState): JSX.Element | null;
- setDefaultValue(): void;
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- /**
- * Generic node model which stores information about a node editor block
- */
- export class InputNodeModel extends DefaultNodeModel {
- connection?: BABYLON.NodeMaterialConnectionPoint;
- /**
- * Constructs the node model
- */
- constructor();
- renderProperties(globalState: GlobalState): JSX.Element | null;
- }
- }
- declare module NODEEDITOR {
- /**
- * GenericNodeWidgetProps
- */
- export interface InputNodeWidgetProps {
- node: BABYLON.Nullable<InputNodeModel>;
- globalState: GlobalState;
- }
- /**
- * Used to display a node block for the node editor
- */
- export class InputNodeWidget extends React.Component<InputNodeWidgetProps> {
- /**
- * Creates a GenericNodeWidget
- * @param props
- */
- constructor(props: InputNodeWidgetProps);
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- /**
- * Node factory which creates editor nodes
- */
- export class InputNodeFactory extends SRD.AbstractNodeFactory {
- private _globalState;
- /**
- * Constructs a GenericNodeFactory
- */
- constructor(globalState: GlobalState);
- /**
- * Generates a node widget
- * @param diagramEngine diagram engine
- * @param node node to generate
- * @returns node widget jsx
- */
- generateReactWidget(diagramEngine: SRD.DiagramEngine, node: InputNodeModel): JSX.Element;
- /**
- * Gets a new instance of a node model
- * @returns input node model
- */
- getNewInstance(): InputNodeModel;
- }
- }
- declare module NODEEDITOR {
- interface IGraphEditorProps {
- globalState: GlobalState;
- }
- export class NodeCreationOptions {
- column: number;
- nodeMaterialBlock?: BABYLON.NodeMaterialBlock;
- type?: string;
- connection?: BABYLON.NodeMaterialConnectionPoint;
- }
- export class GraphEditor extends React.Component<IGraphEditorProps> {
- private _engine;
- private _model;
- private _nodes;
- /**
- * Current row/column position used when adding new nodes
- */
- private _rowPos;
- /**
- * Creates a node and recursivly creates its parent nodes from it's input
- * @param nodeMaterialBlock
- */
- createNodeFromObject(options: NodeCreationOptions): DefaultNodeModel;
- componentDidMount(): void;
- componentWillUnmount(): void;
- constructor(props: IGraphEditorProps);
- addNodeFromClass(ObjectClass: typeof BABYLON.NodeMaterialBlock): DefaultNodeModel;
- addValueNode(type: string, column?: number, connection?: BABYLON.NodeMaterialConnectionPoint): DefaultNodeModel;
- render(): JSX.Element;
- }
- }
- declare module NODEEDITOR {
- /**
- * Generic node model which stores information about a node editor block
- */
- export class DefaultNodeModel extends NodeModel {
- /**
- * The babylon block this node represents
- */
- block: BABYLON.Nullable<BABYLON.NodeMaterialBlock>;
- ports: {
- [s: string]: DefaultPortModel;
- };
- /**
- * Constructs the node model
- */
- constructor(key: string);
- prepare(options: NodeCreationOptions, nodes: Array<DefaultNodeModel>, model: DiagramModel, graphEditor: GraphEditor, filterInputs: string[]): void;
- renderProperties(globalState: GlobalState): JSX.Element | null;
- }
- }
- declare module NODEEDITOR {
- export class GlobalState {
- nodeMaterial?: BABYLON.NodeMaterial;
- hostElement: HTMLElement;
- hostDocument: HTMLDocument;
- onSelectionChangedObservable: BABYLON.Observable<BABYLON.Nullable<DefaultNodeModel>>;
- onRebuildRequiredObservable: BABYLON.Observable<void>;
- }
- }
- declare module NODEEDITOR {
- export class Popup {
- static CreatePopup(title: string, windowVariableName: string, width?: number, height?: number): HTMLDivElement | null;
- private static _CopyStyles;
- }
- }
- declare module NODEEDITOR {
- /**
- * Interface used to specify creation options for the node editor
- */
- export interface INodeEditorOptions {
- nodeMaterial: BABYLON.NodeMaterial;
- }
- /**
- * Class used to create a node editor
- */
- export class NodeEditor {
- /**
- * Show the node editor
- * @param options defines the options to use to configure the node editor
- */
- static Show(options: INodeEditorOptions): void;
- }
- }
|