import { NodeMaterial } from "babylonjs/Materials/Node/nodeMaterial" import { Nullable } from "babylonjs/types" import { Observable } from 'babylonjs/Misc/observable'; import { DefaultNodeModel } from './components/diagram/defaultNodeModel'; import { LogEntry } from './components/log/logComponent'; import { NodeModel } from 'storm-react-diagrams'; import { INodeLocationInfo } from './nodeLocationInfo'; import { NodeMaterialBlock } from 'babylonjs/Materials/Node/nodeMaterialBlock'; import { PreviewMeshType } from './components/preview/previewMeshType'; import { DataStorage } from './dataStorage'; import { Color4 } from 'babylonjs/Maths/math.color'; export class GlobalState { nodeMaterial: NodeMaterial; hostElement: HTMLElement; hostDocument: HTMLDocument; onSelectionChangedObservable = new Observable>(); onRebuildRequiredObservable = new Observable(); onResetRequiredObservable = new Observable>(); onUpdateRequiredObservable = new Observable(); onZoomToFitRequiredObservable = new Observable(); onReOrganizedRequiredObservable = new Observable(); onLogRequiredObservable = new Observable(); onErrorMessageDialogRequiredObservable = new Observable(); onPreviewCommandActivated = new Observable(); onPreviewBackgroundChanged = new Observable(); onAnimationCommandActivated = new Observable(); onGetNodeFromBlock: (block: NodeMaterialBlock) => NodeModel; previewMeshType: PreviewMeshType; previewMeshFile: File; rotatePreview: boolean; backgroundColor: Color4; blockKeyboardEvents = false; customSave?: {label: string, action: (data: string) => Promise}; public constructor() { this.previewMeshType = DataStorage.ReadNumber("PreviewMeshType", PreviewMeshType.Box); let r = DataStorage.ReadNumber("BackgroundColorR", 0.37); let g = DataStorage.ReadNumber("BackgroundColorG", 0.37); let b = DataStorage.ReadNumber("BackgroundColorB", 0.37); this.backgroundColor = new Color4(r, g, b, 1.0); } }